/*
Theme Name: Light by CMC Agency
Theme URI: https://cmc-agency.me
Author: CMC AGENCY
Author URI: https://cmc-agency.me
Description: Light est un thème sur-mesure ultra minimaliste.
Version: 1.0
License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Text Domain: light
Tags: light, minimal, blog
*/

/* Styles généraux */
body {
  color: #333333;
  margin: 0 !important;
  transition: background-color 0.5s, color 0.5s;
}

.hide, .hidden {
  display: none !important;
}

/* Style de base pour les boutons (Néomorphisme sobre) */
.buttoninterface {
  display: flex;
  justify-content: center;
  padding: 6px;
  border-radius: 8px;
  background: #222;
  box-shadow: 4px 4px 8px rgba(0, 0, 0, 0.3), -4px -4px 8px rgba(255, 255, 255, 0.2);
  color: #fff;
  width: 40px;
  height: 40px;
  text-align: center;
  cursor: pointer;
  transition: all 0.3s ease;
  border: none;
}

/* =========================================
 HEADER STYLES
========================================= */

#tc-header {
  position: fixed;
  padding: 10px;
  top: 0;
  left: 0;
  right: 0;
  z-index: 9999;
  transition: all .35s ease;
}

#tc-header.scrolled {
  background: rgb(255 255 255 / 37%);
  backdrop-filter: blur(14px);
  box-shadow: 0 10px 40px rgba(0, 0, 0, .18);
}

.tc-nav {
  height: 100px;
  padding: 0 5vw;
  display: flex;
  align-items: center;
  justify-content: space-between;
  position: relative;
}

/* Logo - Position relative */
.tc-nav__logo-wrapper {
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}

.tc-nav__logo {
  display: flex;
  align-items: center;
  justify-content: center;
  text-decoration: none;
}

.tc-nav__logo img {
  height: 80px;
  width: auto;
  display: block;
  object-fit: contain;
}

/* Desktop Menu */
.tc-nav__desktop {
  display: flex;
  align-items: center;
  gap: 2.2rem;
}

.tc-nav__link {
  font-family: 'Montserrat', sans-serif;
  font-size: .72rem;
  letter-spacing: .22em;
  text-transform: uppercase;
  color: #F5F1EB;
  opacity: .82;
  transition: all .25s ease;
  text-decoration: none;
}

.tc-nav__link:hover {
  opacity: 1;
  color: #D5BD96;
}

.tc-lang-toggle {
  border: 1px solid rgba(213, 189, 150, .45);
  background: transparent;
  color: #D5BD96;
  padding: .55rem .95rem;
  border-radius: 999px;
  font-size: .62rem;
  letter-spacing: .18em;
  text-transform: uppercase;
  transition: all .25s ease;
  cursor: pointer;
}

.tc-lang-toggle:hover {
  background: #D5BD96;
  color: #00314B;
}

/* Mobile Hamburger */
.tc-menu-btn {
  width: 52px;
  height: 52px;
  border-radius: 16px;
  border: 1px solid rgba(255, 255, 255, .14);
  background: rgba(255, 255, 255, .08);
  backdrop-filter: blur(12px);
  display: none;
  align-items: center;
  justify-content: center;
  flex-direction: column;
  gap: 5px;
  cursor: pointer;
  transition: all .3s ease;
  position: fixed;
  top: 14px;
  right: 20px;
  z-index: 100100;
}

.tc-menu-btn span {
  width: 20px;
  height: 2px;
  border-radius: 10px;
  background: #fff;
  transition: all .3s ease;
  display: block;
}

.tc-menu-btn.active span:nth-child(1) {
  transform: translateY(7px) rotate(45deg);
}

.tc-menu-btn.active span:nth-child(2) {
  opacity: 0;
}

.tc-menu-btn.active span:nth-child(3) {
  transform: translateY(-7px) rotate(-45deg);
}

/* Mobile Popup */
.tc-mobile-menu {
  position: fixed;
  inset: 0;
  background: linear-gradient(135deg, rgba(0, 49, 75, .98), rgba(7, 22, 32, .98));
  backdrop-filter: blur(22px);
  z-index: 10000;
  display: flex;
  align-items: center;
  justify-content: center;
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
  transition: opacity .35s ease, visibility .35s ease;
}

.tc-mobile-menu.open {
  opacity: 1;
  visibility: visible;
  pointer-events: auto;
  z-index: 100;
}

.tc-mobile-menu__inner {
  width: 100%;
  max-width: 420px;
  padding: 2rem;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 1rem;
}

.tc-mobile-menu__link {
  width: 100%;
  text-align: center;
  padding: 1.15rem 1.5rem;
  border-radius: 22px;
  background: rgba(255, 255, 255, .05);
  border: 1px solid rgba(255, 255, 255, .08);
  color: #fff;
  text-decoration: none;
  font-size: .95rem;
  letter-spacing: .18em;
  text-transform: uppercase;
  font-weight: 600;
  transition: all .25s ease;
}

.tc-mobile-menu__link:hover {
  background: #D5BD96;
  color: #00314B;
  transform: translateY(-2px);
}

.tc-mobile-lang {
  margin-top: 1rem;
  width: 100%;
}

.tc-mobile-lang button {
  width: 100%;
  height: 58px;
  border-radius: 18px;
  border: none;
  background: #D5BD96;
  color: #00314B;
  font-size: .72rem;
  letter-spacing: .18em;
  text-transform: uppercase;
  font-weight: 700;
  cursor: pointer;
}

body.tc-menu-open {
  overflow: hidden;
}

/* =========================================
 FOOTER STYLES
========================================= */

.tc-footer__logo img {
  height: 80px;
  width: auto;
  display: block;
}

/* =========================================
 RESPONSIVE - TABLETTE & MOBILE
========================================= */

@media(max-width: 900px) {

  .tc-nav {
      height: 82px;
      padding: 0 1.4rem;
  }

  .tc-nav__desktop {
      display: none;
  }

  .tc-menu-btn {
      display: flex;
  }

  /* Logo plus gros sur mobile */
  .tc-nav__logo img {
      height: 95px;
  }
}

@media(min-width: 901px) {

  .tc-mobile-menu {
      display: none;
  }
}

/* Tablettes (601px - 900px) */
@media(min-width: 601px) and (max-width: 900px) {

  .tc-nav__logo img {
      height: 90px;
  }
}

/* Petits mobiles (<= 480px) - logo encore plus gros */
@media(max-width: 480px) {

  .tc-nav {
      padding: 0 1rem;
  }

  .tc-nav__logo img {
      height: 85px;
  }

  .tc-footer__logo img {
      height: 54px;
  }
}

/* Très petits mobiles (<= 380px) */
@media(max-width: 380px) {

  .tc-nav__logo img {
      height: 75px;
  }
}

/* Ancienne compatibilité (<= 600px) */
@media(max-width: 600px) {

  .tc-nav__logo img {
      height: 90px;
  }

  .tc-footer__logo img {
      height: 54px;
  }
}

/* ══ STATEMENT (agrandi avec logo tampon en bas) ══ */
.tc-statement {
  background: var(--light-blue);
  padding: 8rem 4vw 5rem; /* plus haut et plus de padding en bas */
  text-align: center;
  position: relative;
  overflow: hidden;
  min-height: 500px;
  display: flex;
  align-items: center;
  justify-content: center;
}

.tc-statement__inner {
  position: relative;
  z-index: 2;
  max-width: 900px;
  margin: 0 auto;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 0.5rem;
}

.tc-statement__h2 {
  font-family: var(--fh);
  font-size: clamp(2.6rem, 5.5vw, 5rem);
  color: var(--navy);
  text-transform: uppercase;
  line-height: 1.06;
  letter-spacing: -0.01em;
  margin-bottom: 0.5rem;
  position: relative;
  z-index: 2;
}

.tc-statement__script {
  font-family: var(--fs);
  font-size: clamp(1.6rem, 3vw, 2.6rem);
  color: var(--gold);
  position: relative;
  z-index: 2;
  margin-bottom: 2.5rem;
}

/* Logo tampon en dessous du texte */
.tc-statement__logo-stamp {
  width: 160px;
  max-width: 30%;
  opacity: 0.08; /* très faible opacité pour effet tampon */
  pointer-events: none;
  user-select: none;
  margin-top: 0.5rem;
}

.tc-statement__logo-img {
  width: 100%;
  height: auto;
  display: block;
  /* Transformation du logo doré en bleu foncé (#00314B) */
  filter: brightness(0) saturate(100%) invert(11%) sepia(94%) saturate(3211%) hue-rotate(196deg) brightness(36%) contrast(117%);
}

/* Responsive */
@media(max-width: 860px) {
  .tc-statement {
    padding: 6rem 4vw 4rem;
    min-height: 400px;
  }
  .tc-statement__logo-stamp {
    width: 120px;
    opacity: 0.06;
  }
}

@media(max-width: 600px) {
  .tc-statement {
    padding: 4rem 4vw 3rem;
    min-height: 300px;
  }
  .tc-statement__logo-stamp {
    width: 90px;
    opacity: 0.05;
  }
}

/* =========================================
   FONT FACE CORRIGÉES (chemins relatifs)
========================================= */

@font-face {
  font-family: 'DellaRespira';
  src: url('DellaRespira-Regular.ttf') format('truetype');
  font-weight: normal;
  font-display: swap;
}
@font-face {
  font-family: 'Birthstone';
  src: url('Birthstone-Regular.ttf') format('truetype');
  font-weight: normal;
  font-display: swap;
}

/* =========================================
   VARIABLES & RESET GÉNÉRAL
========================================= */

:root{
  --navy:#00314B;--steel:#A6B7CB;--gold:#D5BD96;
  --cream:#F5F1EB;--white:#fff;--light-blue:#EEF4FA;
  --dark:#071620;--text-mid:#4a6070;
  --fh:'DellaRespira',Georgia,serif;
  --fs:'Birthstone',cursive;
  --fb:'Montserrat',sans-serif;
  --ease:cubic-bezier(.25,.46,.45,.94);
  --r:16px;
  --shadow-card:0 4px 28px rgba(0,49,75,.08);
  --shadow-hover:0 14px 48px rgba(0,49,75,.14);
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;}
html{scroll-behavior:smooth;}
body{font-family:var(--fb);background:var(--white);color:var(--navy);overflow-x:hidden;-webkit-font-smoothing:antialiased;}
img{display:block;width:100%;height:100%;object-fit:cover;}
a{text-decoration:none;color:inherit;}
button{cursor:pointer;border:none;background:none;font-family:inherit;}
input,select,textarea,button{font-family:var(--fb);}

/* ── HEADER ── */
#tc-header{position:fixed;top:0;left:0;right:0;z-index:900;transition:background .4s var(--ease),backdrop-filter .4s;}
.tc-nav{display:flex;align-items:center;justify-content:space-between;height:80px;padding:0 5vw;}
.tc-nav__left,.tc-nav__right{display:flex;align-items:center;gap:2.4rem;}
.tc-nav__link{font-size:.68rem;letter-spacing:.2em;text-transform:uppercase;color:var(--white);opacity:.85;transition:opacity .2s;}
#tc-header.scrolled .tc-nav__link{color:var(--navy);}
.tc-nav__link:hover{opacity:1;}
.tc-nav__logo{font-family:var(--fh);font-size:1.7rem;color:var(--white);letter-spacing:.06em;text-transform:uppercase;transition:color .3s;}
#tc-header.scrolled .tc-nav__logo{color:var(--navy);}
.tc-nav__logo-gold{color:var(--gold);}
.tc-lang-toggle{font-size:.62rem;letter-spacing:.18em;text-transform:uppercase;color:var(--gold);border:1px solid var(--gold);padding:.32rem .8rem;border-radius:50px;transition:all .2s;}
#tc-header.scrolled .tc-lang-toggle{color:var(--navy);border-color:var(--navy);}
.tc-lang-toggle:hover{background:var(--gold);color:var(--navy);}

/* ── BUTTONS ── */
.tc-btn{display:inline-flex;align-items:center;gap:.4rem;padding:.88rem 2.2rem;font-size:.7rem;letter-spacing:.18em;text-transform:uppercase;font-weight:600;border-radius:50px;transition:all .25s;white-space:nowrap;}
.tc-btn--gold{background:var(--gold);color:var(--navy);border:1px solid var(--gold);}
.tc-btn--gold:hover{background:transparent;color:var(--gold);}
.tc-btn--ghost{border:1px solid rgba(255,255,255,.55);color:var(--white);}
.tc-btn--ghost:hover{border-color:var(--white);background:rgba(255,255,255,.12);}
.tc-btn--outline-navy{border:1.5px solid var(--navy);color:var(--navy);}
.tc-btn--outline-navy:hover{background:var(--navy);color:var(--cream);}
.tc-btn--full{width:100%;justify-content:center;border-radius:var(--r);font-size:.75rem;padding:1rem 2rem;}

/* ── LABELS ── */
.tc-label-gold{display:block;font-size:.62rem;letter-spacing:.3em;text-transform:uppercase;color:var(--gold);margin-bottom:.9rem;font-weight:600;}
.tc-label-navy{display:block;font-size:.62rem;letter-spacing:.3em;text-transform:uppercase;color:var(--navy);margin-bottom:.9rem;font-weight:600;}

/* ══ HERO ══ */
.tc-hero{position:relative;height:100vh;min-height:680px;display:flex;align-items:center;overflow:hidden;}
.tc-hero__media{position:absolute;inset:0;overflow:hidden;}
.tc-hero__bg{width:100%;height:100%;object-fit:cover;transform:scale(1.07);animation:hzoom 16s var(--ease) forwards;will-change:transform;}
@keyframes hzoom{to{transform:scale(1);}}
/* vignette plus forte pour la lisibilité */
.tc-hero__vignette{position:absolute;inset:0;background:linear-gradient(135deg,rgba(0,22,40,.25) 0%,rgba(0,49,75,.65) 50%,rgba(0,16,32,.9) 100%);}
.tc-hero__inner{position:relative;z-index:2;padding:0 9vw;max-width:820px;animation:fadeUp .9s var(--ease) .25s both;}
@keyframes fadeUp{from{opacity:0;transform:translateY(28px);}to{opacity:1;transform:translateY(0);}}
.tc-eyebrow{font-size:.64rem;letter-spacing:.3em;text-transform:uppercase;color:var(--gold);margin-bottom:1.6rem;font-weight:600;}
.tc-hero__h1{display:flex;flex-direction:column;gap:.2rem;margin-bottom:1.8rem;}
.tc-hero__h1-top{font-family:var(--fh);font-size:clamp(2.8rem,6vw,5.8rem);color:var(--white);text-transform:uppercase;line-height:.96;letter-spacing:-.01em;}
.tc-hero__h1-script{font-family:var(--fs);font-style:normal;font-size:clamp(2rem,4.2vw,4rem);color:var(--gold);line-height:1.05;margin-left:.1rem;}
.tc-hero__h1-sub{font-family:var(--fb);font-size:clamp(.85rem,1.6vw,1.1rem);color:rgba(245,241,235,.7);text-transform:uppercase;letter-spacing:.2em;line-height:1.4;margin-top:.4rem;font-weight:300;}
.tc-hero__body{font-size:.9rem;color:rgba(245,241,235,.85);line-height:1.8;max-width:480px;font-weight:300;margin-bottom:2.5rem;}
.tc-hero__ctas{display:flex;gap:1rem;flex-wrap:wrap;}
.tc-hero__scroll{position:absolute;right:4rem;bottom:3.5rem;z-index:2;display:flex;flex-direction:column;align-items:center;gap:.5rem;}
.tc-hero__scroll-line{display:block;width:1px;height:55px;background:linear-gradient(to bottom,transparent,var(--gold));animation:pulse 2.2s ease-in-out infinite;}
@keyframes pulse{0%,100%{opacity:.25;}50%{opacity:1;}}
.tc-hero__scroll-label{font-size:.57rem;letter-spacing:.24em;text-transform:uppercase;color:var(--gold);writing-mode:vertical-rl;}

/* ══ SERVICES — TRUE INFINITE CAROUSEL ══ */
.tc-svc{background:var(--white);padding:7rem 0 6rem;overflow:hidden;}
.tc-svc__header{text-align:center;padding:0 2rem 4rem;max-width:640px;margin:0 auto;}
.tc-svc__title{font-family:var(--fh);font-size:clamp(2rem,4vw,3.4rem);color:var(--navy);text-transform:uppercase;letter-spacing:-.01em;margin-bottom:1rem;}
.tc-svc__intro{font-size:.86rem;color:var(--text-mid);font-weight:300;line-height:1.8;}

.tc-carousel-track-outer{
  position:relative;
  width:100%;
  overflow:hidden;
  perspective:1400px;
  padding:3rem 0 4rem;
  cursor:grab;
  user-select:none;
}
.tc-carousel-track-outer:active{cursor:grabbing;}
.tc-carousel-track{
  display:flex;
  gap:2rem;
  width:max-content;
  will-change:transform;
  padding:0;
}
.tc-card3d{
  position:relative;
  flex:0 0 360px;
  height:480px;
  border-radius:24px;
  overflow:visible;
  box-shadow:0 8px 40px rgba(0,49,75,.14),0 2px 8px rgba(0,49,75,.06);
  transform-style:preserve-3d;
  transition:box-shadow .55s cubic-bezier(.25,.46,.45,.94),opacity .55s,transform .55s cubic-bezier(.25,.46,.45,.94);
  cursor:pointer;
  border:1.5px solid rgba(213,189,150,.18);
  background:var(--white);
}
.tc-card3d__zoom-wrap{
  position:relative;
  width:100%;
  height:100%;
  border-radius:24px;
  overflow:hidden;
  transition:transform 0.35s cubic-bezier(0.2,0.9,0.4,1.1),box-shadow 0.35s ease;
  will-change:transform;
  z-index:1;
}
.tc-card3d:hover .tc-card3d__zoom-wrap{
  transform:scale(1.07);
  box-shadow:0 25px 50px -12px rgba(0,49,75,0.35);
  z-index:100;
}
.tc-card3d:hover{z-index:20;}
.tc-card3d.tc-depth--left{
  transform:perspective(900px) rotateY(22deg) scale(.88);
  box-shadow:0 4px 24px rgba(0,49,75,.10);
  opacity:.8;
}
.tc-card3d.tc-depth--right{
  transform:perspective(900px) rotateY(-22deg) scale(.88);
  box-shadow:0 4px 24px rgba(0,49,75,.10);
  opacity:.8;
}
.tc-card3d.tc-depth--far-left{
  transform:perspective(900px) rotateY(34deg) scale(.76);
  box-shadow:none;
  opacity:.45;
}
.tc-card3d.tc-depth--far-right{
  transform:perspective(900px) rotateY(-34deg) scale(.76);
  box-shadow:none;
  opacity:.45;
}
.tc-card3d.tc-depth--center{
  transform:perspective(900px) rotateY(0deg) scale(1.05);
  box-shadow:0 20px 64px rgba(0,49,75,.22),0 4px 16px rgba(0,49,75,.1);
  opacity:1;
  border-color:rgba(213,189,150,.6);
  z-index:10;
}
.tc-card3d.tc-depth--hidden{
  opacity:0;
  pointer-events:none;
}
.tc-card3d__img{position:absolute;inset:0;}
.tc-card3d__img img{width:100%;height:100%;object-fit:cover;filter:brightness(.72);transition:filter .5s,transform .7s cubic-bezier(.25,.46,.45,.94);}
.tc-card3d.tc-depth--center .tc-card3d__img img{filter:brightness(.55);transform:scale(1.06);}
.tc-card3d__overlay{
  position:absolute;inset:0;
  display:flex;flex-direction:column;
  justify-content:flex-end;
  padding:2rem 2rem 2.4rem;
  background:linear-gradient(to top,rgba(0,22,40,.88) 0%,rgba(0,22,40,0) 60%);
}
.tc-card3d__num{
  font-family:var(--fh);font-size:.62rem;letter-spacing:.24em;
  color:var(--gold);margin-bottom:.5rem;font-weight:700;text-transform:uppercase;
  opacity:0;transform:translateY(8px);
  transition:opacity .4s .05s,transform .4s .05s;
}
.tc-card3d.tc-depth--center .tc-card3d__num{opacity:1;transform:none;}
.tc-card3d__name{
  font-family:var(--fh);font-size:1.45rem;color:var(--white);
  text-transform:uppercase;letter-spacing:.04em;line-height:1.1;margin-bottom:.9rem;
}
.tc-card3d__cta{
  font-size:.62rem;letter-spacing:.22em;text-transform:uppercase;
  color:var(--gold);font-weight:700;
  opacity:0;transform:translateY(6px);
  transition:opacity .35s .1s,transform .35s .1s;
}
.tc-card3d.tc-depth--center .tc-card3d__cta{opacity:1;transform:none;}
.tc-carousel-arrow{
  position:absolute;top:50%;transform:translateY(-50%);
  width:52px;height:52px;border-radius:50%;
  background:rgba(255,255,255,.9);backdrop-filter:blur(10px);
  border:1.5px solid rgba(213,189,150,.4);
  color:var(--navy);font-size:1.2rem;
  display:flex;align-items:center;justify-content:center;
  cursor:pointer;transition:all .25s;z-index:20;
  box-shadow:0 4px 20px rgba(0,49,75,.12);
}
.tc-carousel-arrow:hover{background:var(--gold);color:var(--navy);border-color:var(--gold);}
.tc-carousel-arrow--prev{left:2rem;}
.tc-carousel-arrow--next{right:2rem;}

/* ══ MODAL (service) ══ */
.tc-overlay{position:fixed;inset:0;z-index:9999;background:rgba(0,22,40,.7);backdrop-filter:blur(10px);display:flex;align-items:center;justify-content:center;opacity:0;pointer-events:none;transition:opacity .3s;padding:1.5rem;}
.tc-overlay.open{opacity:1;pointer-events:all;}
.tc-modal{background:var(--white);border-radius:var(--r);max-width:860px;width:100%;display:flex;overflow:hidden;max-height:90vh;transform:translateY(20px) scale(.97);transition:transform .35s var(--ease);position:relative;}
.tc-overlay.open .tc-modal{transform:none;}
.tc-modal__close{position:absolute;top:1rem;right:1.2rem;width:36px;height:36px;border-radius:50%;background:rgba(0,0,0,.25);color:#fff;font-size:.85rem;display:flex;align-items:center;justify-content:center;z-index:5;transition:background .2s;}
.tc-modal__close:hover{background:var(--navy);}
.tc-modal__media{flex:0 0 42%;overflow:hidden;}
.tc-modal__info{flex:1;padding:3rem 2.5rem;overflow-y:auto;}
.tc-modal__title{font-family:var(--fh);font-size:1.9rem;text-transform:uppercase;color:var(--navy);margin:.6rem 0 1.2rem;letter-spacing:.04em;}
.tc-modal__desc{font-size:.84rem;color:var(--text-mid);font-weight:300;line-height:1.8;margin-bottom:1.5rem;}
.tc-modal__list{list-style:none;margin-bottom:2rem;}
.tc-modal__list li{font-size:.8rem;color:var(--navy);padding:.48rem 0 .48rem 1.4rem;border-bottom:1px solid rgba(0,49,75,.06);position:relative;}
.tc-modal__list li::before{content:'—';position:absolute;left:0;color:var(--gold);}

/* ══ PREVIEW LIGHTBOX (menu photos) ══ */
.tc-preview-overlay{
  position:fixed;inset:0;z-index:10000;background:rgba(0,22,40,.9);backdrop-filter:blur(15px);
  display:flex;align-items:center;justify-content:center;
  opacity:0;pointer-events:none;transition:opacity .3s;
}
.tc-preview-overlay.open{opacity:1;pointer-events:all;}
.tc-preview-modal{
  max-width:85vw;max-height:85vh;background:transparent;border-radius:16px;overflow:hidden;
  box-shadow:0 25px 60px rgba(0,0,0,.4);transform:scale(.96);transition:transform .3s var(--ease);
}
.tc-preview-overlay.open .tc-preview-modal{transform:scale(1);}
.tc-preview-modal img{width:100%;height:auto;display:block;object-fit:contain;max-height:85vh;}
.tc-preview-close{
  position:fixed;top:2rem;right:2.5rem;background:rgba(0,0,0,.5);color:#fff;border:none;
  width:44px;height:44px;border-radius:50%;font-size:1.6rem;display:flex;align-items:center;justify-content:center;
  cursor:pointer;transition:background .2s;z-index:10001;
}
.tc-preview-close:hover{background:var(--gold);color:var(--navy);}

/* ══ STATEMENT ══ */
.tc-statement{background:var(--light-blue);padding:7rem 4vw;text-align:center;}
.tc-statement__h2{font-family:var(--fh);font-size:clamp(2.2rem,5vw,4.6rem);color:var(--navy);text-transform:uppercase;line-height:1.06;letter-spacing:-.01em;margin-bottom:.9rem;}
.tc-statement__script{font-family:var(--fs);font-size:clamp(1.5rem,2.8vw,2.4rem);color:var(--gold);}

/* ══ ABOUT ══ */
.tc-about{display:grid;grid-template-columns:1.05fr 1fr;background:var(--white);align-items:stretch;}
.tc-about__mosaic{display:grid;grid-template-columns:1.45fr 1fr;gap:4px;min-height:580px;}
.tc-about__mosaic-main{overflow:hidden;position:relative;}
.tc-about__mosaic-main img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;transition:transform .7s var(--ease);}
.tc-about__mosaic-main:hover img{transform:scale(1.04);}
.tc-about__mosaic-col{display:grid;grid-template-rows:1fr 1fr;gap:4px;}
.tc-about__mosaic-top,.tc-about__mosaic-bot{overflow:hidden;position:relative;}
.tc-about__mosaic-top img,.tc-about__mosaic-bot img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;transition:transform .7s var(--ease);}
.tc-about__mosaic-top:hover img,.tc-about__mosaic-bot:hover img{transform:scale(1.05);}
.tc-about__text{padding:5rem 4.5rem 5rem 4rem;display:flex;flex-direction:column;justify-content:center;gap:1.4rem;}
.tc-about__h2{font-family:var(--fh);font-size:clamp(1.8rem,3vw,2.8rem);text-transform:uppercase;color:var(--navy);letter-spacing:-.01em;line-height:1.08;}
.tc-about__text p{font-size:.84rem;color:var(--text-mid);font-weight:300;line-height:1.82;}

/* ══ MENU ══ */
.tc-menu{background:var(--cream);padding:7rem 0 5rem;}
.tc-menu__header{text-align:center;padding:0 2rem 4rem;max-width:640px;margin:0 auto;}
.tc-menu__h2{font-family:var(--fh);font-size:clamp(2rem,3.8vw,3.4rem);color:var(--navy);text-transform:uppercase;letter-spacing:-.01em;margin-bottom:1rem;}
.tc-menu__intro{font-size:.86rem;color:var(--text-mid);font-weight:300;max-width:500px;margin:0 auto;line-height:1.8;}
.tc-menu__cats{padding:0 5vw;display:flex;flex-direction:column;gap:1.2rem;}
.tc-menu-cat{background:var(--white);border-radius:var(--r);border:1.5px solid rgba(0,49,75,.07);box-shadow:var(--shadow-card);overflow:hidden;transition:box-shadow .3s;}
.tc-menu-cat:hover{box-shadow:var(--shadow-hover);}
.tc-menu-cat__header{display:flex;align-items:center;justify-content:space-between;padding:1.8rem 2.2rem;cursor:pointer;user-select:none;transition:background .2s;}
.tc-menu-cat__header:hover{background:rgba(213,189,150,.06);}
.tc-menu-cat__left{display:flex;align-items:center;gap:1.4rem;}
.tc-menu-cat__icon{display:flex;align-items:center;justify-content:center;width:48px;height:48px;flex-shrink:0;background:rgba(213,189,150,.08);border:1.5px solid rgba(213,189,150,.25);border-radius:12px;}
.tc-menu-cat__icon svg{display:block;}
.tc-menu-cat__num{display:block;font-size:.62rem;letter-spacing:.24em;color:var(--gold);font-weight:700;text-transform:uppercase;margin-bottom:.2rem;}
.tc-menu-cat__name{font-family:var(--fh);font-size:1.3rem;color:var(--navy);text-transform:uppercase;letter-spacing:.04em;}
.tc-menu-cat__arrow{font-size:1.1rem;color:var(--gold);transition:transform .4s var(--ease);font-weight:700;flex-shrink:0;}
.tc-menu-cat__arrow.open{transform:rotate(180deg);}
.tc-menu-cat__body{max-height:0;overflow:hidden;transition:max-height .6s var(--ease);}
.tc-menu-cat__body.open{max-height:1200px;}
.tc-menu-cat__desc{font-size:.84rem;color:var(--text-mid);font-weight:300;line-height:1.8;padding:0 2.2rem 1.6rem;border-bottom:1px solid rgba(0,49,75,.06);margin-bottom:1.8rem;}

/* Sub-grid */
.tc-menu-sub-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:1.2rem;
  padding:0 2.2rem 2.2rem;
}
.tc-menu-sub-card{border-radius:12px;overflow:hidden;border:1.5px solid rgba(0,49,75,.07);transition:transform .35s var(--ease),box-shadow .35s;background:var(--white);}
.tc-menu-sub-card:hover{transform:translateY(-4px);box-shadow:0 12px 36px rgba(0,49,75,.12);}
.tc-menu-sub-card__img{height:160px;overflow:hidden;}
.tc-menu-sub-card__img img{filter:brightness(.9);transition:transform .6s var(--ease),filter .4s;}
.tc-menu-sub-card:hover .tc-menu-sub-card__img img{transform:scale(1.06);filter:brightness(.78);}
.tc-menu-sub-card__body{padding:1.2rem 1.3rem 1.5rem;}
.tc-menu-sub-tier{display:inline-block;font-size:.6rem;letter-spacing:.2em;text-transform:uppercase;font-weight:700;padding:.3rem .75rem;border-radius:50px;margin-bottom:.8rem;}
.tc-menu-sub-card--classic .tc-menu-sub-tier{background:rgba(166,183,203,.18);color:var(--navy);}
.tc-menu-sub-card--silver .tc-menu-sub-tier{background:rgba(213,189,150,.2);color:#8a6f3e;}
.tc-menu-sub-card--premium .tc-menu-sub-tier{background:rgba(0,49,75,.08);color:var(--navy);}
.tc-menu-sub-card__text{font-size:.78rem;color:var(--text-mid);font-weight:300;line-height:1.65;margin-bottom:.9rem;}
.tc-menu-sub-card__actions{display:flex;justify-content:space-between;align-items:center;margin-top:.5rem;}
.tc-menu-sub-card__cta{font-size:.6rem;letter-spacing:.2em;text-transform:uppercase;color:var(--gold);font-weight:700;transition:letter-spacing .2s;}
.tc-menu-sub-card:hover .tc-menu-sub-card__cta{letter-spacing:.28em;}
.tc-menu-sub-card__preview{font-size:.6rem;letter-spacing:.2em;text-transform:uppercase;background:none;border:1px solid var(--gold);color:var(--navy);padding:.28rem .85rem;border-radius:50px;transition:all .2s;font-weight:600;}
.tc-menu-sub-card__preview:hover{background:var(--gold);color:var(--navy);border-color:var(--gold);}
.tc-menu__custom{font-size:.7rem;letter-spacing:.18em;text-transform:uppercase;color:var(--gold);font-weight:600;padding:0 2.2rem 0;margin-bottom:1.8rem;}
.tc-menu__footer-note{text-align:center;margin:3rem 5vw 0;font-size:.72rem;letter-spacing:.2em;text-transform:uppercase;color:var(--gold);font-weight:600;}

/* ══ PROCESS ══ */
.tc-process{background:var(--white);padding:7rem 8vw;}
.tc-process__header{text-align:center;margin-bottom:4.5rem;}
.tc-process__header h2{font-family:var(--fh);font-size:clamp(1.8rem,3.8vw,3.2rem);text-transform:uppercase;color:var(--navy);letter-spacing:-.01em;}
.tc-process__steps{display:grid;grid-template-columns:1fr auto 1fr auto 1fr auto 1fr;align-items:start;}
.tc-process__step{text-align:center;padding:0 1.5rem;}
.tc-process__num{font-family:var(--fh);font-size:3.2rem;color:var(--gold);opacity:.4;line-height:1;margin-bottom:1rem;}
.tc-process__step h4{font-family:var(--fh);font-size:.92rem;text-transform:uppercase;letter-spacing:.1em;color:var(--navy);margin-bottom:.7rem;}
.tc-process__step p{font-size:.78rem;color:var(--text-mid);font-weight:300;line-height:1.7;}
.tc-process__connector{width:46px;height:1px;background:var(--gold);opacity:.35;margin-top:1.7rem;}

/* ══ ALLERGENS ══ */
.tc-allergens{background:var(--light-blue);padding:5.5rem 8vw;}
.tc-allergens__inner{display:flex;align-items:flex-start;gap:3rem;max-width:940px;margin:0 auto;}
.tc-allergens__shield{font-size:2.2rem;background:rgba(213,189,150,.12);border:1.5px solid rgba(213,189,150,.3);border-radius:50%;width:80px;height:80px;display:flex;align-items:center;justify-content:center;flex-shrink:0;margin-top:.3rem;}
.tc-allergens__text-col h2{font-family:var(--fh);font-size:clamp(1.4rem,2.8vw,2.3rem);text-transform:uppercase;color:var(--navy);letter-spacing:-.01em;margin-bottom:1.1rem;}
.tc-allergens__text-col p{font-size:.84rem;color:var(--text-mid);font-weight:300;line-height:1.82;margin-bottom:1.6rem;}
.tc-allergens__tags{display:flex;flex-wrap:wrap;gap:.5rem;}
.tc-allergens__tags span{font-size:.66rem;letter-spacing:.14em;text-transform:uppercase;padding:.34rem .9rem;border:1.5px solid rgba(0,49,75,.14);border-radius:50px;color:var(--navy);transition:all .2s;cursor:default;}
.tc-allergens__tags span:hover{background:rgba(213,189,150,.12);border-color:var(--gold);color:var(--navy);}

/* ══ CONTACT ══ */
.tc-contact{background:var(--cream);padding:7rem 0 8rem;}
.tc-contact__split{display:grid;grid-template-columns:1fr 1.35fr;gap:5.5rem;max-width:1220px;margin:0 auto;padding:0 6vw;}
.tc-contact__left{display:flex;flex-direction:column;gap:1.4rem;padding-top:1rem;}
.tc-contact__left h2{font-family:var(--fh);font-size:clamp(2rem,3.8vw,3.2rem);text-transform:uppercase;color:var(--navy);letter-spacing:-.01em;line-height:1.05;}
.tc-contact__left p{font-size:.85rem;color:var(--text-mid);font-weight:300;line-height:1.82;}
.tc-contact__info{margin-top:.5rem;}
.tc-contact__email{font-family:var(--fh);font-size:1rem;color:var(--navy);display:block;margin-bottom:.6rem;transition:color .2s;}
.tc-contact__email:hover{color:var(--gold);}
.tc-contact__phones{display:flex;flex-direction:column;gap:.55rem;margin:.2rem 0 .8rem;}
.tc-contact__phone{display:flex;align-items:center;gap:.65rem;font-size:.9rem;color:var(--navy);font-weight:500;text-decoration:none;transition:color .2s;}
.tc-contact__phone:hover{color:var(--gold);}
.tc-contact__phone-flags{font-size:1.05rem;line-height:1;letter-spacing:.05em;}
.tc-contact__slogan{font-family:var(--fs);font-size:1.55rem;color:var(--gold);}
.tc-form{display:flex;flex-direction:column;gap:1.3rem;}
.tc-form__row{display:grid;grid-template-columns:1fr 1fr;gap:1.1rem;}
.tc-form__group{display:flex;flex-direction:column;gap:.45rem;}
.tc-form__group label{font-size:.63rem;letter-spacing:.18em;text-transform:uppercase;color:var(--navy);font-weight:700;}
.tc-form__group input,.tc-form__group select,.tc-form__group textarea{border:1.5px solid rgba(0,49,75,.15);border-radius:10px;padding:.76rem 1rem;background:var(--white);color:var(--navy);outline:none;font-size:.85rem;font-weight:300;transition:border-color .2s,box-shadow .2s;}
.tc-form__group input:focus,.tc-form__group select:focus,.tc-form__group textarea:focus{border-color:var(--navy);box-shadow:0 0 0 3px rgba(0,49,75,.07);}
.tc-form__allergen-box{background:rgba(213,189,150,.1);border:1.5px solid rgba(213,189,150,.4);border-radius:12px;padding:1.2rem 1.2rem 1rem;}
.tc-form__allergen-box label{color:#8a6f3e !important;}
.tc-form__service-box{background:var(--white);border:1.5px solid rgba(0,49,75,.1);border-radius:12px;padding:1.2rem;}
.tc-form__service-options{display:grid;grid-template-columns:1fr 1fr;gap:.8rem;margin-top:.5rem;}
.tc-form__radio-card{cursor:pointer;display:block;}
.tc-form__radio-card input[type="radio"]{display:none;}
.tc-form__radio-inner{display:flex;flex-direction:column;align-items:center;text-align:center;gap:.4rem;padding:1.1rem .8rem;border:1.5px solid rgba(0,49,75,.1);border-radius:10px;transition:all .2s;background:var(--white);}
.tc-form__radio-card input:checked + .tc-form__radio-inner{border-color:var(--gold);background:rgba(213,189,150,.1);}
.tc-form__radio-inner:hover{border-color:rgba(213,189,150,.6);}
.tc-form__radio-icon{font-size:1.6rem;}
.tc-form__radio-inner strong{font-size:.78rem;letter-spacing:.1em;text-transform:uppercase;color:var(--navy);font-weight:700;}
.tc-form__radio-inner small{font-size:.7rem;color:var(--text-mid);font-weight:300;line-height:1.4;}
.tc-form__consent{display:flex;align-items:flex-start;gap:.65rem;font-size:.78rem;color:var(--text-mid);font-weight:300;line-height:1.55;cursor:pointer;}
.tc-form__consent input{accent-color:var(--navy);margin-top:.18rem;flex-shrink:0;}

/* ── FOOTER ── */
#tc-footer{background:var(--dark);padding:4.5rem 6vw 2.5rem;}
.tc-footer__inner{display:flex;justify-content:space-between;align-items:flex-start;gap:2.5rem;flex-wrap:wrap;padding-bottom:2.5rem;border-bottom:1px solid rgba(166,183,203,.08);}
.tc-footer__logo{font-family:var(--fh);font-size:1.7rem;color:var(--white);text-transform:uppercase;letter-spacing:.06em;display:block;margin-bottom:.45rem;}
.tc-footer__logo span{color:var(--gold);}
.tc-footer__tagline{font-size:.68rem;color:var(--steel);letter-spacing:.16em;text-transform:uppercase;}
.tc-footer__links{display:flex;flex-direction:column;gap:.6rem;}
.tc-footer__links a{font-size:.74rem;color:var(--steel);letter-spacing:.12em;text-transform:uppercase;transition:color .2s;}
.tc-footer__links a:hover{color:var(--gold);}
.tc-footer__contact a{font-size:.9rem;color:var(--gold);display:block;margin-bottom:.4rem;}
.tc-footer__contact p{font-size:.68rem;color:var(--steel);text-transform:uppercase;letter-spacing:.1em;}

/* ── REVEAL ── */
.tc-r{opacity:0;transform:translateY(24px);transition:opacity .7s var(--ease),transform .7s var(--ease);}
.tc-r.vis{opacity:1;transform:none;}

/* ── RESPONSIVE ── */
@media(max-width:1100px){
  .tc-about{grid-template-columns:1fr;}
  .tc-about__mosaic{min-height:420px;}
  .tc-about__text{padding:4rem 3rem;}
  .tc-process__steps{grid-template-columns:1fr 1fr;gap:2.5rem;}
  .tc-process__connector{display:none;}
  .tc-contact__split{grid-template-columns:1fr;gap:3rem;}
}
@media(max-width:860px){
  .tc-card3d{flex:0 0 280px;height:380px;}
  .tc-carousel-arrow{width:42px;height:42px;font-size:1rem;}
  .tc-carousel-arrow--prev{left:.8rem;}
  .tc-carousel-arrow--next{right:.8rem;}
  .tc-about__mosaic{grid-template-columns:1fr;min-height:auto;}
  .tc-about__mosaic-main{aspect-ratio:16/7;position:relative;}
  .tc-about__mosaic-col{display:none;}
  .tc-menu__cats{padding:0 4vw;}
  .tc-menu-sub-grid{
    grid-template-columns:repeat(3,280px);
    overflow-x:auto;
    -webkit-overflow-scrolling:touch;
    scroll-snap-type:x mandatory;
    padding:0 1.5rem 1.5rem;
    gap:1rem;
    scrollbar-width:none;
    -ms-overflow-style:none;
  }
  .tc-menu-sub-grid::-webkit-scrollbar{display:none;}
  .tc-menu-sub-card{scroll-snap-align:start;min-width:280px;}
  .tc-allergens__inner{flex-direction:column;gap:1.5rem;}
  .tc-modal{flex-direction:column;max-height:92vh;}
  .tc-modal__media{flex:0 0 220px;}
  .tc-form__service-options{grid-template-columns:1fr;}
}
@media(max-width:600px){
  .tc-nav{height:68px;padding:0 1.4rem;}
  .tc-nav__left,.tc-nav__right{gap:1.2rem;}
  .tc-nav__logo{font-size:1.25rem;}
  .tc-hero__inner{padding:0 6vw;}
  .tc-hero__scroll{right:1.5rem;}
  .tc-card3d{flex:0 0 240px;height:320px;}
  .tc-card3d__name{font-size:1.1rem;}
  .tc-about__mosaic-main{aspect-ratio:4/3;}
  .tc-about__text{padding:2.8rem 1.6rem;}
  .tc-process{padding:5rem 5vw;}
  .tc-process__steps{grid-template-columns:1fr;}
  .tc-allergens{padding:4rem 5vw;}
  .tc-contact__split{padding:0 5vw;}
  .tc-form__row{grid-template-columns:1fr;}
  .tc-menu-cat__header{padding:1.4rem 1.4rem;}
  .tc-menu-sub-grid{
    grid-template-columns:repeat(3,260px);
    padding:0 1rem 1rem;
  }
  .tc-menu-sub-card{min-width:260px;}
  .tc-menu-cat__desc{padding:0 1.4rem 1.4rem;}
}