/* ================================================================
   S2AC Architecture v3.0 — main.css
   Design System Complet — Mode Clair Uniquement
   Palette : Blanc · Beige · Gris Ardoise · Or · Noir Profond
================================================================ */

/* ─── RESET ──────────────────────────────────────────────────── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{font-size:16px;scroll-behavior:smooth;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}
body{background:#fff;color:#1A1A1A;font-family:'DM Sans',system-ui,-apple-system,sans-serif;font-size:15px;font-weight:400;line-height:1.65;overflow-x:hidden}
img,video{max-width:100%;height:auto;display:block}
a{color:inherit;text-decoration:none;transition:color .2s}
button{cursor:pointer;border:none;background:none;font-family:inherit;font-size:inherit}
ul,ol{list-style:none}
input,textarea,select{font-family:inherit;font-size:inherit}
::-webkit-scrollbar{width:3px}
::-webkit-scrollbar-track{background:#F8F6F2}
::-webkit-scrollbar-thumb{background:#B8975A;border-radius:2px}
::selection{background:#B8975A;color:#fff}
.visually-hidden{position:absolute;width:1px;height:1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap}

/* ─── SPACING UTILITIES ─────────────────────────────────────── */
.section      {padding:clamp(72px,10vw,140px) clamp(20px,5vw,80px)}
.section--alt {background:#F8F6F2}
.section--stone{background:#2C2C2C;color:white}
.section--paper-3{background:#F2EFE9}

/* ─── TYPOGRAPHY SCALE ──────────────────────────────────────── */
.t-label  {font-size:11px;font-weight:600;letter-spacing:.35em;text-transform:uppercase;color:#B8975A}
.t-lead   {font-size:17px;font-weight:300;line-height:1.8;color:#3A3A3A}
.t-body   {font-size:15px;font-weight:400;line-height:1.75;color:#3A3A3A}
.t-small  {font-size:13px;font-weight:400;line-height:1.6;color:#6B6B6B}
.t-caption{font-size:11px;font-weight:400;letter-spacing:.15em;color:#9A9A9A}

/* ─── SECTION UTILITIES ─────────────────────────────────────── */
.section-label{display:flex;align-items:center;gap:12px;font-size:11px;font-weight:600;letter-spacing:.35em;text-transform:uppercase;color:#B8975A;margin-bottom:16px}
.section-label::before{content:'';width:32px;height:1.5px;background:#B8975A;flex-shrink:0}
.section-title{font-family:'Cormorant Garamond',Georgia,serif;font-size:clamp(38px,5vw,68px);font-weight:300;line-height:1.05;letter-spacing:-.02em;color:#1A1A1A}
.section-title em{font-style:italic;color:#8A6E3A}
.section-lead{font-size:17px;color:#3A3A3A;line-height:1.75;margin-top:16px;font-weight:300;max-width:640px}
.section-header{margin-bottom:clamp(48px,6vw,80px)}
.section-header--split{display:flex;justify-content:space-between;align-items:flex-end;flex-wrap:wrap;gap:20px}
.section-cta-row{display:flex;gap:14px;justify-content:center;flex-wrap:wrap;margin-top:clamp(40px,5vw,60px)}
.cta-row-left{display:flex;gap:14px;flex-wrap:wrap;margin-top:32px}

.reveal{opacity:0;transform:translateY(32px);transition:opacity .8s cubic-bezier(.16,1,.3,1),transform .8s cubic-bezier(.16,1,.3,1)}
.reveal.is-visible{opacity:1;transform:translateY(0)}
.reveal-delay-1{transition-delay:.10s}
.reveal-delay-2{transition-delay:.20s}
.reveal-delay-3{transition-delay:.30s}

/* ─── HEADER ────────────────────────────────────────────────── */
#site-header{
  position:fixed;top:0;left:0;right:0;z-index:100;
  height:72px;
  background:rgba(255,255,255,.92);
  backdrop-filter:blur(16px) saturate(180%);
  -webkit-backdrop-filter:blur(16px) saturate(180%);
  border-bottom:1px solid rgba(26,26,26,.10);
  display:flex;align-items:center;
  padding:0 clamp(20px,5vw,80px);gap:24px;
  transition:box-shadow .4s
}
#site-header.is-scrolled{box-shadow:0 2px 8px rgba(26,26,26,.06)}

.site-logo{display:flex;flex-direction:column;line-height:1;flex-shrink:0;text-decoration:none}
.logo-main{font-family:'Cormorant Garamond',Georgia,serif;font-size:26px;font-weight:300;letter-spacing:.20em;text-transform:uppercase;color:#1A1A1A;line-height:1}
.logo-tagline{font-size:8px;font-weight:600;letter-spacing:.40em;text-transform:uppercase;color:#B8975A;margin-top:3px;white-space:nowrap}
.logo-img{max-height:44px;width:auto}

.primary-nav{flex:1;display:flex;justify-content:center}
.nav-list{display:flex;align-items:center;gap:2px;list-style:none}
.nav-item{position:relative}
.nav-link{
  display:flex;align-items:center;gap:3px;
  font-size:11px;font-weight:600;letter-spacing:.18em;text-transform:uppercase;
  color:#6B6B6B;padding:8px 13px;transition:color .2s;white-space:nowrap
}
.nav-link:hover,.nav-item.current-menu-item>.nav-link{color:#1A1A1A}
.nav-link-dot{width:4px;height:4px;border-radius:50%;background:#B8975A;opacity:0;transition:opacity .2s;flex-shrink:0}
.nav-item.current-menu-item>.nav-link .nav-link-dot{opacity:1}
.nav-arrow{font-size:14px;color:#9A9A9A;transition:transform .2s}
.nav-item:hover .nav-arrow{transform:rotate(90deg)}

.mega-menu{
  position:absolute;top:calc(100% + 8px);left:50%;
  transform:translateX(-50%) translateY(6px);
  background:#fff;border:1px solid rgba(26,26,26,.10);
  border-radius:8px;box-shadow:0 24px 64px rgba(26,26,26,.12);
  padding:28px;min-width:480px;
  display:grid;grid-template-columns:1fr 1fr 1fr;gap:24px;
  opacity:0;visibility:hidden;pointer-events:none;
  transition:all .4s cubic-bezier(.16,1,.3,1);transform-origin:top center
}
.nav-item.has-mega:hover .mega-menu,
.nav-item.has-mega:focus-within .mega-menu{
  opacity:1;visibility:visible;pointer-events:all;
  transform:translateX(-50%) translateY(0)
}
.mega-col-title{font-size:11px;font-weight:700;letter-spacing:.25em;text-transform:uppercase;color:#B8975A;margin-bottom:12px}
.mega-links{display:flex;flex-direction:column;gap:8px}
.mega-links a{font-size:13px;color:#3A3A3A;padding:2px 0 2px 8px;transition:all .2s;border-left:2px solid transparent}
.mega-links a:hover{color:#1A1A1A;border-left-color:#B8975A;padding-left:12px}
.mega-col--cta{background:#F8F6F2;border-radius:4px;padding:18px}
.mega-cta-desc{font-size:13px;color:#6B6B6B;line-height:1.6;margin-bottom:14px}
.mega-cta-btn{display:inline-flex;align-items:center;gap:6px;font-size:11px;font-weight:700;letter-spacing:.20em;text-transform:uppercase;color:#B8975A;border:1px solid rgba(184,151,90,.25);padding:9px 18px;border-radius:3px;transition:all .2s}
.mega-cta-btn:hover{background:#B8975A;color:white}

.header-actions{display:flex;align-items:center;gap:12px;flex-shrink:0}

.nav-toggle{display:none;flex-direction:column;gap:5px;width:40px;height:40px;padding:10px;border:1px solid rgba(26,26,26,.10);border-radius:3px;transition:border-color .2s}
.nav-toggle:hover{border-color:rgba(184,151,90,.25)}
.bar{display:block;height:1.5px;background:#1A1A1A;border-radius:1px;transition:all .5s cubic-bezier(.16,1,.3,1)}
.bar-1{width:100%}.bar-2{width:100%}.bar-3{width:60%}
.nav-toggle.is-open .bar-1{transform:rotate(45deg) translate(5px,5px)}
.nav-toggle.is-open .bar-2{opacity:0;transform:scaleX(0)}
.nav-toggle.is-open .bar-3{width:100%;transform:rotate(-45deg) translate(5px,-5px)}

/* ─── MOBILE MENU ────────────────────────────────────────────── */
.mobile-menu{
  position:fixed;inset:0;z-index:99;background:#fff;
  display:flex;flex-direction:column;
  transform:translateX(100%);transition:transform .5s cubic-bezier(.16,1,.3,1);
  overflow-y:auto
}
.mobile-menu:not([hidden]){transform:translateX(0)}
.mobile-menu[hidden]{display:flex!important}
.mobile-menu-header{display:flex;align-items:center;justify-content:space-between;padding:20px clamp(20px,5vw,80px);border-bottom:1px solid rgba(26,26,26,.10);flex-shrink:0}
.mobile-close{width:40px;height:40px;border:1px solid rgba(26,26,26,.10);border-radius:50%;display:flex;align-items:center;justify-content:center;color:#3A3A3A;font-size:20px;transition:all .2s}
.mobile-close:hover{border-color:#B8975A;color:#B8975A}
.mobile-nav{flex:1;display:flex;flex-direction:column;padding:36px clamp(20px,5vw,80px) 24px;gap:0}
.mobile-nav-link{font-family:'Cormorant Garamond',Georgia,serif;font-size:clamp(26px,5.5vw,40px);font-weight:300;color:#3A3A3A;padding:12px 0;border-bottom:1px solid rgba(26,26,26,.06);transition:all .2s}
.mobile-nav-link:hover{color:#8A6E3A;padding-left:8px}
.mobile-menu-footer{padding:28px clamp(20px,5vw,80px) 40px;border-top:1px solid rgba(26,26,26,.10);flex-shrink:0;display:flex;flex-direction:column;gap:16px}
.mobile-contact-info{display:flex;flex-direction:column;gap:4px}
.mobile-contact-info a{font-size:13px;color:#6B6B6B;transition:color .2s}
.mobile-contact-info a:hover{color:#B8975A}
.mobile-socials{display:flex;gap:10px}
.mobile-socials a{width:36px;height:36px;border:1px solid rgba(26,26,26,.10);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:700;color:#6B6B6B;transition:all .2s}
.mobile-socials a:hover{border-color:#B8975A;color:#B8975A}
.mobile-overlay{position:fixed;inset:0;z-index:98;background:rgba(0,0,0,.3);opacity:0;pointer-events:none;transition:opacity .4s}
.mobile-overlay.is-visible{opacity:1;pointer-events:all}

/* ─── BUTTONS ───────────────────────────────────────────────── */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:8px;
  font-family:'DM Sans',system-ui,sans-serif;font-size:11px;font-weight:700;
  letter-spacing:.22em;text-transform:uppercase;
  padding:14px 34px;border-radius:3px;
  cursor:pointer;transition:all .4s cubic-bezier(.25,.46,.45,.94);white-space:nowrap;
  border:1.5px solid transparent
}
.btn:focus-visible{outline:2px solid #B8975A;outline-offset:3px}
.btn-primary{background:#1A1A1A;color:white;border-color:#1A1A1A}
.btn-primary:hover{background:#3A3A3A;transform:translateY(-2px);box-shadow:0 8px 32px rgba(26,26,26,.10)}
.btn-gold{background:#B8975A;color:white;border-color:#B8975A}
.btn-gold:hover{background:#CBA96E;transform:translateY(-2px);box-shadow:0 8px 24px rgba(184,151,90,.30)}
.btn-outline{background:transparent;color:#1A1A1A;border-color:rgba(26,26,26,.10);border-width:1.5px}
.btn-outline:hover{border-color:#1A1A1A;background:#F8F6F2}
.btn-outline-gold{background:transparent;color:#B8975A;border-color:rgba(184,151,90,.25);border-width:1.5px}
.btn-outline-gold:hover{background:#B8975A;color:white}
.btn-sm{padding:9px 20px;font-size:10px}
.btn-lg{padding:17px 46px;font-size:11px}
.btn-xl{padding:20px 56px;font-size:13px;letter-spacing:.18em}

/* ─── HERO ──────────────────────────────────────────────────── */
.hero{position:relative;height:100vh;min-height:640px;overflow:hidden}
.hero-media{position:absolute;inset:0}
.hero-video{width:100%;height:100%;object-fit:cover}
.hero-slide-img{width:100%;height:100%;object-fit:cover;display:block;position:absolute;inset:0;opacity:0;transition:opacity 1.2s ease}
.hero-slide-img.is-active{opacity:1}
.hero-ph-1{background:linear-gradient(165deg,#f0ede6,#e0d8cc,#c8bfb0)}
.hero-ph-2{background:linear-gradient(165deg,#d8e8f0,#c0d4e4,#a8c0d8)}

.hero-overlay{
  position:absolute;inset:0;
  background:linear-gradient(to bottom,rgba(255,255,255,0) 0%,rgba(255,255,255,0) 40%,rgba(255,255,255,.60) 75%,rgba(255,255,255,.95) 100%)
}
.hero-overlay-top{position:absolute;top:0;left:0;right:0;height:180px;background:linear-gradient(to bottom,rgba(255,255,255,.65),transparent)}

.hero-content{
  position:absolute;bottom:0;left:0;right:0;
  padding:0 clamp(20px,5vw,80px) clamp(48px,7vw,88px);
  display:flex;flex-direction:column
}
.hero-badge{
  display:inline-flex;align-items:center;gap:8px;
  background:white;border:1px solid rgba(26,26,26,.10);
  border-radius:100px;padding:6px 14px;
  font-size:11px;font-weight:700;letter-spacing:.25em;text-transform:uppercase;
  color:#B8975A;box-shadow:0 2px 8px rgba(26,26,26,.06);
  margin-bottom:20px;align-self:flex-start
}
.hero-badge-dot{width:6px;height:6px;border-radius:50%;background:#B8975A;animation:pulse 2s infinite}
.hero-title{
  font-family:'Cormorant Garamond',Georgia,serif;
  font-size:clamp(52px,9vw,120px);font-weight:300;line-height:.88;letter-spacing:-.035em;
  color:#1A1A1A;margin-bottom:20px
}
.hero-title em{font-style:italic;color:#8A6E3A}
.hero-subtitle{font-size:12px;font-weight:600;letter-spacing:.30em;text-transform:uppercase;color:#6B6B6B;margin-bottom:32px}
.hero-ctas{display:flex;gap:12px;flex-wrap:wrap}

.hero-dots{position:absolute;right:clamp(20px,5vw,80px);bottom:clamp(48px,7vw,88px);display:flex;flex-direction:column;gap:8px}
.hero-dot{width:8px;height:8px;border-radius:50%;border:1.5px solid #6B6B6B;cursor:pointer;transition:all .2s;background:none}
.hero-dot.is-active{background:#B8975A;border-color:#B8975A;transform:scale(1.3)}

.hero-panel-tags{position:absolute;bottom:clamp(48px,7vw,88px);right:calc(clamp(20px,5vw,80px) + 32px);display:flex;gap:8px}
.hero-panel-tag{background:white;border:1px solid rgba(26,26,26,.10);border-radius:3px;padding:6px 14px;font-size:11px;font-weight:700;letter-spacing:.15em;text-transform:uppercase;color:#3A3A3A;cursor:pointer;transition:all .2s}
.hero-panel-tag:hover,.hero-panel-tag.is-active{background:#B8975A;color:white;border-color:#B8975A}

.hero-scroll{position:absolute;bottom:32px;left:50%;transform:translateX(-50%);display:flex;flex-direction:column;align-items:center;gap:8px;cursor:pointer;text-decoration:none}
.hero-scroll-line{width:1px;height:48px;background:linear-gradient(to bottom,#B8975A,transparent);animation:scroll-pulse 2.5s ease-in-out infinite}
.hero-scroll-text{font-size:11px;font-weight:600;letter-spacing:.4em;text-transform:uppercase;color:#9A9A9A}

/* ─── TICKER ─────────────────────────────────────────────────── */
.ticker-bar{background:#2C2C2C;padding:14px 0;overflow:hidden}
.ticker-track{display:flex;gap:64px;animation:ticker 22s linear infinite;white-space:nowrap}
.ticker-item{display:flex;align-items:center;gap:20px;flex-shrink:0}
.ticker-text{font-size:11px;font-weight:600;letter-spacing:.35em;text-transform:uppercase;color:rgba(255,255,255,.55)}
.ticker-sep{width:5px;height:5px;border-radius:50%;background:#B8975A;flex-shrink:0}

/* ─── MEDIA SHOWCASE ─────────────────────────────────────────── */
.media-showcase{display:grid;grid-template-columns:1fr 1fr;grid-template-rows:auto;gap:4px}
.media-showcase-featured{grid-column:1;grid-row:1/3;position:relative;overflow:hidden;aspect-ratio:3/4;cursor:pointer;display:block}
.media-showcase-grid{grid-column:2;display:grid;grid-template-columns:1fr 1fr;grid-template-rows:1fr 1fr;gap:4px}
.media-showcase-item{position:relative;overflow:hidden;aspect-ratio:1;cursor:pointer;display:block}
.media-showcase-img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .7s cubic-bezier(.25,.46,.45,.94)}
.media-showcase-featured:hover .media-showcase-img,
.media-showcase-item:hover .media-showcase-img{transform:scale(1.05)}
.media-showcase-overlay{position:absolute;inset:0;background:linear-gradient(to top,rgba(26,26,26,.45) 0%,transparent 50%);opacity:0;transition:opacity .4s}
.media-showcase-featured:hover .media-showcase-overlay,
.media-showcase-item:hover .media-showcase-overlay{opacity:1}
.media-showcase-label{position:absolute;bottom:16px;left:16px;right:16px;font-size:11px;font-weight:700;letter-spacing:.20em;text-transform:uppercase;color:white;opacity:0;transform:translateY(6px);transition:all .4s;text-shadow:0 1px 4px rgba(0,0,0,.5)}
.media-showcase-featured:hover .media-showcase-label,
.media-showcase-item:hover .media-showcase-label{opacity:1;transform:translateY(0)}

/* ─── PROJECTS ──────────────────────────────────────────────── */
.projects-filter{display:flex;gap:6px;flex-wrap:wrap}
.filter-tab{background:transparent;border:1px solid rgba(26,26,26,.10);color:#6B6B6B;font-family:'DM Sans',sans-serif;font-size:11px;font-weight:700;letter-spacing:.20em;text-transform:uppercase;padding:8px 18px;cursor:pointer;transition:all .2s;border-radius:3px}
.filter-tab.is-active,.filter-tab:hover{border-color:#B8975A;color:#B8975A;background:rgba(184,151,90,.08)}

.projects-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:4px}
.project-card{position:relative;overflow:hidden;cursor:pointer;display:block;border-radius:1px;outline:none}
.project-card--featured{grid-column:span 2}
.project-thumb{width:100%;aspect-ratio:4/5;object-fit:cover;display:block;transition:transform .9s cubic-bezier(.25,.46,.45,.94),filter .5s;filter:brightness(.95)}
.project-card--featured .project-thumb{aspect-ratio:16/10}
.project-card:hover .project-thumb{transform:scale(1.04);filter:brightness(.82)}
.project-thumb--placeholder,.pph-1,.pph-2,.pph-3,.pph-4,.pph-5,.pph-6{display:block}
.pph-1{background:linear-gradient(160deg,#f5f0e8,#e8e0d0,#d5c9b5)}
.pph-2{background:linear-gradient(160deg,#e8eef5,#d0dcec,#b5c9de)}
.pph-3{background:linear-gradient(160deg,#f0ede0,#e0dcc8,#ccc8ae)}
.pph-4{background:linear-gradient(160deg,#e8f0e8,#d0e0d0,#b5cfb5)}
.pph-5{background:linear-gradient(160deg,#ede8f0,#ddd0e8,#c8b5d8)}
.pph-6{background:linear-gradient(160deg,#f0e8e8,#e8d0d0,#d8b5b5)}
.project-overlay{position:absolute;inset:0;background:linear-gradient(to top,rgba(26,26,26,.82) 0%,rgba(26,26,26,.08) 55%,transparent 100%)}
.project-info{position:absolute;bottom:0;left:0;right:0;padding:clamp(20px,2.5vw,34px);transform:translateY(6px);transition:transform .5s cubic-bezier(.16,1,.3,1)}
.project-card:hover .project-info{transform:translateY(0)}
.project-cat{font-size:11px;font-weight:700;letter-spacing:.30em;text-transform:uppercase;color:#B8975A;margin-bottom:6px}
.project-name{font-family:'Cormorant Garamond',Georgia,serif;font-size:clamp(20px,2.6vw,32px);font-weight:400;line-height:1.1;color:white}
.project-name--lg{font-size:clamp(28px,4vw,48px)}
.project-meta{font-size:11px;color:rgba(255,255,255,.60);margin-top:6px;letter-spacing:.10em;opacity:0;transform:translateY(6px);transition:all .4s .08s}
.project-card:hover .project-meta{opacity:1;transform:translateY(0)}
.project-arrow{position:absolute;top:20px;right:20px;width:36px;height:36px;background:white;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:14px;color:#1A1A1A;opacity:0;transform:translate(4px,-4px);transition:all .4s;box-shadow:0 2px 8px rgba(26,26,26,.06)}
.project-card:hover .project-arrow{opacity:1;transform:translate(0,0)}

/* ─── SERVICES ──────────────────────────────────────────────── */
.services-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:rgba(26,26,26,.10);border:1px solid rgba(26,26,26,.10)}
.service-item{background:#fff;padding:clamp(28px,3.5vw,48px) clamp(20px,2.5vw,36px);position:relative;overflow:hidden;cursor:pointer;transition:background .4s}
.service-item::after{content:'';position:absolute;bottom:0;left:0;right:0;height:2px;background:#B8975A;transform:scaleX(0);transform-origin:left;transition:transform .5s cubic-bezier(.16,1,.3,1)}
.service-item:hover{background:#F8F6F2}
.service-item:hover::after{transform:scaleX(1)}
.service-num{font-family:'Cormorant Garamond',Georgia,serif;font-size:52px;font-weight:300;color:#EAE6DE;line-height:1;margin-bottom:20px}
.service-icon{width:44px;height:44px;border:1.5px solid rgba(26,26,26,.10);display:flex;align-items:center;justify-content:center;margin-bottom:20px;border-radius:3px}
.service-icon svg{width:18px;height:18px;stroke:#B8975A;fill:none;stroke-width:1.5}
.service-name{font-family:'Cormorant Garamond',Georgia,serif;font-size:clamp(18px,2vw,22px);font-weight:400;line-height:1.25;margin-bottom:12px;color:#1A1A1A}
.service-desc{font-size:13px;color:#6B6B6B;line-height:1.75}
.service-link{display:inline-flex;align-items:center;gap:6px;font-size:11px;font-weight:700;letter-spacing:.20em;text-transform:uppercase;color:#B8975A;margin-top:18px;opacity:0;transform:translateY(4px);transition:all .35s .05s}
.service-item:hover .service-link{opacity:1;transform:translateY(0)}

/* ─── STATS ──────────────────────────────────────────────────── */
.stats-row{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:rgba(26,26,26,.10);border:1px solid rgba(26,26,26,.10)}
.stat-card{background:#fff;padding:clamp(24px,3vw,40px);text-align:center;transition:background .2s}
.stat-card:hover{background:#F8F6F2}
.stat-number{font-family:'Cormorant Garamond',Georgia,serif;font-size:clamp(44px,5.5vw,68px);font-weight:300;color:#B8975A;line-height:1}
.stat-suffix{font-size:clamp(22px,2.5vw,32px)}
.stat-label{font-size:11px;font-weight:700;letter-spacing:.25em;text-transform:uppercase;color:#6B6B6B;margin-top:10px}

/* ─── ABOUT GRID ─────────────────────────────────────────────── */
.about-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(36px,6vw,88px);align-items:center}
.about-stats{display:grid;grid-template-columns:1fr 1fr;gap:clamp(12px,2vw,24px)}

/* ─── TEAM ───────────────────────────────────────────────────── */
.team-grid{display:grid;grid-template-columns:1fr 1fr;gap:4px}
.team-card{position:relative;overflow:hidden;cursor:pointer;aspect-ratio:3/4;background:#F2EFE9;display:block;outline:none}
.team-photo{width:100%;height:100%;object-fit:cover;object-position:top;filter:grayscale(15%);transition:transform .8s cubic-bezier(.25,.46,.45,.94),filter .5s;display:block}
.team-card:hover .team-photo{transform:scale(1.04);filter:grayscale(0%)}
.team-photo--placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center}
.team-ph-1{background:linear-gradient(165deg,#f5f0e8,#e8e0d0,#d5c9b5)}
.team-ph-2{background:linear-gradient(165deg,#e8eef5,#d0dcec,#b5c9de)}
.team-initials{font-family:'Cormorant Garamond',Georgia,serif;font-size:clamp(72px,10vw,110px);font-weight:300;color:rgba(184,151,90,.18);letter-spacing:-.04em}
.team-overlay{position:absolute;inset:0;background:linear-gradient(to top,rgba(26,26,26,.88) 0%,rgba(26,26,26,.20) 45%,transparent 100%)}
.team-info{position:absolute;bottom:0;left:0;right:0;padding:clamp(24px,3vw,44px);transform:translateY(48px);transition:transform .6s cubic-bezier(.16,1,.3,1)}
.team-card:hover .team-info{transform:translateY(0)}
.team-role{font-size:11px;font-weight:700;letter-spacing:.35em;text-transform:uppercase;color:#B8975A;margin-bottom:10px}
.team-name{font-family:'Cormorant Garamond',Georgia,serif;font-size:clamp(24px,3vw,38px);font-weight:400;line-height:1.1;color:white;margin-bottom:10px}
.team-bio{font-size:13px;color:rgba(255,255,255,.70);line-height:1.7;opacity:0;transform:translateY(10px);transition:all .45s .12s;max-width:400px}
.team-card:hover .team-bio{opacity:1;transform:translateY(0)}
.team-social{display:flex;gap:8px;margin-top:16px;opacity:0;transition:opacity .4s .22s}
.team-card:hover .team-social{opacity:1}
.social-btn{width:34px;height:34px;border:1px solid rgba(255,255,255,.25);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:700;color:rgba(255,255,255,.65);transition:all .2s;cursor:pointer}
.social-btn:hover{border-color:#B8975A;color:#B8975A}

/* ─── MEDIA GRID ─────────────────────────────────────────────── */
.media-grid{display:grid;grid-template-columns:repeat(4,1fr);grid-auto-rows:200px;gap:4px}
.media-item{position:relative;overflow:hidden;cursor:pointer;background:#F2EFE9}
.media-item--wide{grid-column:span 2}
.media-item--tall{grid-row:span 2}
.media-thumb{width:100%;height:100%;object-fit:cover;display:block;transition:transform .7s cubic-bezier(.25,.46,.45,.94)}
.media-item:hover .media-thumb{transform:scale(1.06)}
.media-ph-hotels    {background:linear-gradient(135deg,#e0e8f0,#c8d8e8,#aec8dc);display:block;width:100%;height:100%}
.media-ph-villas    {background:linear-gradient(135deg,#f0ede0,#e4ddc8,#d4c8ae);display:block;width:100%;height:100%}
.media-ph-bureaux   {background:linear-gradient(135deg,#e8eef4,#d4e0ec,#bfd0e0);display:block;width:100%;height:100%}
.media-ph-residences{background:linear-gradient(135deg,#e8f0e8,#d0e4d0,#b8d4b8);display:block;width:100%;height:100%}
.media-ph-facades   {background:linear-gradient(135deg,#f0e8f0,#e4d0e4,#d4b8d4);display:block;width:100%;height:100%}
.media-ph-equipe    {background:linear-gradient(135deg,#f0ede8,#e4dcd4,#d4c8bc);display:block;width:100%;height:100%}
.media-item-overlay{position:absolute;inset:0;background:rgba(26,26,26,0);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px;transition:background .4s}
.media-item:hover .media-item-overlay{background:rgba(26,26,26,.42)}
.media-lightbox-btn{width:44px;height:44px;border-radius:50%;background:white;border:none;display:flex;align-items:center;justify-content:center;color:#1A1A1A;opacity:0;transform:scale(.8);transition:all .4s;box-shadow:0 8px 32px rgba(26,26,26,.10);cursor:pointer}
.media-lightbox-btn svg{width:16px;height:16px;fill:none;stroke:currentColor;stroke-width:1.5}
.media-item:hover .media-lightbox-btn{opacity:1;transform:scale(1)}
.media-item-label{font-size:11px;font-weight:700;letter-spacing:.20em;text-transform:uppercase;color:white;opacity:0;transform:translateY(4px);transition:all .35s .05s;text-shadow:0 1px 4px rgba(0,0,0,.4)}
.media-item:hover .media-item-label{opacity:1;transform:translateY(0)}
.media-filters{display:flex;gap:6px;flex-wrap:wrap;margin-bottom:28px}

/* ─── QUOTE ──────────────────────────────────────────────────── */
.quote-section{text-align:center;position:relative;overflow:hidden}
.quote-bg-word{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;font-family:'Cormorant Garamond',Georgia,serif;font-size:clamp(160px,22vw,320px);font-weight:300;color:rgba(184,151,90,.04);pointer-events:none;white-space:nowrap}
.quote-mark{font-family:'Cormorant Garamond',Georgia,serif;font-size:80px;line-height:.4;color:rgba(184,151,90,.2);margin-bottom:24px;display:block}
.quote-text{font-family:'Cormorant Garamond',Georgia,serif;font-size:clamp(20px,2.8vw,38px);font-weight:300;line-height:1.40;font-style:italic;max-width:780px;margin:0 auto}
.quote-author{margin-top:28px;font-size:11px;font-weight:700;letter-spacing:.40em;text-transform:uppercase;color:#B8975A;font-style:normal;font-family:'DM Sans',sans-serif}

/* ─── TESTIMONIALS ───────────────────────────────────────────── */
.testimonial-slide{padding:clamp(40px,5vw,72px) clamp(24px,7vw,96px);position:relative}
.testimonial-quote{position:absolute;top:20px;left:clamp(20px,5vw,76px);font-family:'Cormorant Garamond',Georgia,serif;font-size:120px;line-height:.5;color:rgba(184,151,90,.08);pointer-events:none}
.testimonial-text{font-family:'Cormorant Garamond',Georgia,serif;font-size:clamp(18px,2.5vw,28px);font-weight:300;line-height:1.55;font-style:italic;color:#1A1A1A;position:relative;z-index:1}
.testimonial-author{display:flex;align-items:center;gap:16px;margin-top:28px;flex-wrap:wrap}
.testimonial-avatar{width:48px;height:48px;border-radius:50%;background:#F2EFE9;border:2px solid rgba(26,26,26,.10);display:flex;align-items:center;justify-content:center;font-family:'Cormorant Garamond',Georgia,serif;font-size:20px;color:#B8975A;flex-shrink:0;overflow:hidden}
.testimonial-avatar img{width:100%;height:100%;object-fit:cover}
.testimonial-name{font-size:15px;font-weight:600;color:#1A1A1A}
.testimonial-role{font-size:13px;color:#6B6B6B;margin-top:2px}
.testimonial-stars{margin-left:auto;font-size:15px;color:#B8975A;letter-spacing:2px}
.swiper-pagination-bullet{background:rgba(26,26,26,.15);opacity:1;width:8px;height:8px;transition:all .3s}
.swiper-pagination-bullet-active{background:#B8975A;width:22px;border-radius:4px}

/* ─── BLOG ───────────────────────────────────────────────────── */
.blog-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(20px,2.5vw,36px)}
.blog-card{display:block;cursor:pointer}
.blog-thumb-wrap{overflow:hidden;aspect-ratio:16/9;margin-bottom:20px;background:#F2EFE9;border-radius:3px}
.blog-thumb{width:100%;height:100%;object-fit:cover;display:block;transition:transform .7s cubic-bezier(.25,.46,.45,.94)}
.blog-card:hover .blog-thumb{transform:scale(1.04)}
.blog-cat{font-size:11px;font-weight:700;letter-spacing:.30em;text-transform:uppercase;color:#B8975A;margin-bottom:8px}
.blog-title{font-family:'Cormorant Garamond',Georgia,serif;font-size:clamp(17px,2vw,22px);font-weight:400;line-height:1.25;color:#1A1A1A;transition:color .2s}
.blog-card:hover .blog-title{color:#8A6E3A}
.blog-excerpt{font-size:13px;color:#6B6B6B;line-height:1.70;margin-top:8px}
.blog-meta{display:flex;gap:16px;margin-top:12px;font-size:11px;color:#9A9A9A;font-weight:600}

/* ─── PARTNERS ───────────────────────────────────────────────── */
.partners-row{display:flex;align-items:center;justify-content:center;gap:clamp(28px,5vw,64px);flex-wrap:wrap;border-top:1px solid rgba(26,26,26,.10);border-bottom:1px solid rgba(26,26,26,.10);padding:36px 0}
.partner-item{opacity:.45;transition:opacity .2s}
.partner-item:hover{opacity:.85}
.partner-logo{max-height:40px;max-width:110px;object-fit:contain}
.partner-name-text{font-size:13px;font-weight:700;letter-spacing:.20em;text-transform:uppercase;color:#6B6B6B}

/* ─── NEWSLETTER ─────────────────────────────────────────────── */
.newsletter-section{text-align:center}
.newsletter-form{display:flex;max-width:440px;margin:32px auto 0;box-shadow:0 2px 8px rgba(26,26,26,.06);border-radius:3px;overflow:hidden;border:1px solid rgba(26,26,26,.10)}
.newsletter-input{flex:1;background:#fff;border:none;padding:14px 20px;color:#1A1A1A;font-size:15px;outline:none;min-width:0}
.newsletter-input::placeholder{color:#9A9A9A}
.newsletter-btn{background:#B8975A;color:white;padding:14px 24px;font-size:11px;font-weight:700;letter-spacing:.22em;text-transform:uppercase;border:none;cursor:pointer;transition:background .2s;white-space:nowrap}
.newsletter-btn:hover{background:#CBA96E}

/* ─── FAQ ────────────────────────────────────────────────────── */
.faq-item{border-bottom:1px solid rgba(26,26,26,.10)}
.faq-trigger{width:100%;display:flex;justify-content:space-between;align-items:center;padding:22px 0;font-size:clamp(14px,1.8vw,18px);font-weight:500;color:#1A1A1A;cursor:pointer;text-align:left;transition:color .2s}
.faq-trigger:hover{color:#8A6E3A}
.faq-icon{width:24px;height:24px;border:1.5px solid rgba(26,26,26,.10);border-radius:50%;flex-shrink:0;position:relative;transition:border-color .2s}
.faq-icon::before{content:'';position:absolute;width:10px;height:1.5px;top:50%;left:50%;transform:translate(-50%,-50%);background:#B8975A}
.faq-icon::after{content:'';position:absolute;width:1.5px;height:10px;top:50%;left:50%;transform:translate(-50%,-50%);background:#B8975A;transition:transform .35s}
.faq-item.is-open .faq-icon::after{transform:translate(-50%,-50%) rotate(90deg)}
.faq-item.is-open .faq-icon{border-color:#B8975A}
.faq-answer{overflow:hidden;max-height:0;transition:max-height .5s cubic-bezier(.16,1,.3,1)}
.faq-answer-inner{padding:0 0 20px;font-size:15px;color:#3A3A3A;line-height:1.80}
.faq-item.is-open .faq-answer{max-height:300px}

/* ─── LIGHTBOX ───────────────────────────────────────────────── */
.s2ac-lightbox{position:fixed;inset:0;z-index:9999;background:rgba(26,26,26,.96);display:flex;align-items:center;justify-content:center;opacity:0;pointer-events:none;transition:opacity .4s}
.s2ac-lightbox.is-open{opacity:1;pointer-events:all}
.lightbox-inner{position:relative;max-width:90vw;max-height:90vh;display:flex;flex-direction:column;align-items:center}
.lightbox-img{max-width:90vw;max-height:85vh;object-fit:contain;box-shadow:0 32px 80px rgba(0,0,0,.5)}
.lightbox-caption{font-size:11px;font-weight:700;letter-spacing:.25em;text-transform:uppercase;color:rgba(255,255,255,.55);margin-top:16px}
.lightbox-close{position:fixed;top:24px;right:28px;width:44px;height:44px;border:1px solid rgba(255,255,255,.25);border-radius:50%;background:none;color:white;font-size:20px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s}
.lightbox-close:hover{border-color:#B8975A;color:#B8975A}
.lightbox-nav{position:fixed;top:50%;transform:translateY(-50%);width:44px;height:44px;border:1px solid rgba(255,255,255,.2);border-radius:50%;background:none;color:white;font-size:20px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s}
.lightbox-prev{left:20px}.lightbox-next{right:20px}
.lightbox-nav:hover{border-color:#B8975A;color:#B8975A}

/* ─── FLOATANTS ──────────────────────────────────────────────── */
.float-whatsapp{position:fixed;bottom:28px;right:28px;width:52px;height:52px;border-radius:50%;background:#25D366;display:flex;align-items:center;justify-content:center;z-index:900;cursor:pointer;box-shadow:0 6px 24px rgba(37,211,102,.35);transition:transform .3s cubic-bezier(.34,1.56,.64,1)}
.float-whatsapp:hover{transform:scale(1.10)}
.float-whatsapp svg{width:24px;height:24px;fill:white}
.scroll-to-top{position:fixed;bottom:92px;right:28px;width:44px;height:44px;background:white;border:1px solid rgba(26,26,26,.10);border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;z-index:900;opacity:0;pointer-events:none;color:#3A3A3A;font-size:16px;transition:all .4s;box-shadow:0 2px 8px rgba(26,26,26,.06)}
.scroll-to-top.is-visible{opacity:1;pointer-events:all}
.scroll-to-top:hover{border-color:#B8975A;color:#B8975A;box-shadow:0 8px 32px rgba(26,26,26,.10)}
.chatbot-bubble{position:fixed;bottom:148px;right:28px;width:44px;height:44px;background:white;border:1px solid rgba(26,26,26,.10);border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;z-index:900;font-size:20px;box-shadow:0 2px 8px rgba(26,26,26,.06);transition:all .2s}
.chatbot-bubble:hover{border-color:rgba(184,151,90,.25);box-shadow:0 8px 32px rgba(26,26,26,.10)}
.chatbot-window{position:fixed;bottom:204px;right:28px;width:300px;background:white;border:1px solid rgba(26,26,26,.10);border-radius:8px;box-shadow:0 24px 64px rgba(26,26,26,.12);overflow:hidden;display:flex;flex-direction:column;opacity:0;pointer-events:none;transform:translateY(12px) scale(.96);transform-origin:bottom right;transition:all .5s cubic-bezier(.16,1,.3,1)}
.chatbot-window.is-open{opacity:1;pointer-events:all;transform:translateY(0) scale(1)}
.chatbot-header{padding:14px 16px;background:#2C2C2C;display:flex;align-items:center;gap:10px}
.chatbot-avatar{width:30px;height:30px;border-radius:50%;background:rgba(184,151,90,.2);display:flex;align-items:center;justify-content:center;font-size:16px;flex-shrink:0}
.chatbot-name{font-size:13px;font-weight:600;color:white}
.chatbot-status{font-size:11px;color:#6ee7b7}
.chatbot-close-btn{margin-left:auto;background:none;border:none;color:rgba(255,255,255,.6);font-size:20px;cursor:pointer;line-height:1}
.chatbot-messages{min-height:120px;max-height:200px;overflow-y:auto;padding:14px;display:flex;flex-direction:column;gap:10px}
.chat-msg{max-width:85%;padding:9px 12px;font-size:13px;line-height:1.55;border-radius:8px}
.chat-msg--in{background:#F8F6F2;color:#1A1A1A;align-self:flex-start;border-bottom-left-radius:4px}
.chat-msg--out{background:#B8975A;color:white;align-self:flex-end;border-bottom-right-radius:4px}
.chatbot-input-row{border-top:1px solid rgba(26,26,26,.10);display:flex}
.chatbot-input{flex:1;border:none;padding:12px 14px;font-size:13px;color:#1A1A1A;background:white;outline:none}
.chatbot-input::placeholder{color:#9A9A9A}
.chatbot-send{padding:12px 14px;color:#B8975A;font-size:16px;font-weight:700;transition:color .2s}
.chatbot-send:hover{color:#8A6E3A}

/* ─── FOOTER ─────────────────────────────────────────────────── */
.site-footer{background:#1A1A1A;color:rgba(255,255,255,.75)}
.footer-main{padding:clamp(56px,7vw,88px) clamp(20px,5vw,80px);display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:clamp(32px,5vw,64px)}
.footer-brand .logo-main{color:white}
.footer-brand .logo-tagline{color:#B8975A}
.footer-tagline{font-size:13px;color:rgba(255,255,255,.50);line-height:1.75;margin-top:16px;max-width:220px}
.footer-socials{display:flex;gap:8px;margin-top:22px}
.footer-social{width:34px;height:34px;border:1px solid rgba(255,255,255,.15);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:700;color:rgba(255,255,255,.5);transition:all .2s}
.footer-social:hover{border-color:#B8975A;color:#B8975A}
.footer-col-title{font-size:11px;font-weight:700;letter-spacing:.35em;text-transform:uppercase;color:#B8975A;margin-bottom:18px}
.footer-nav{display:flex;flex-direction:column;gap:10px}
.footer-nav a{font-size:13px;color:rgba(255,255,255,.50);transition:all .2s}
.footer-nav a:hover{color:white;padding-left:4px}
.footer-bottom{border-top:1px solid rgba(255,255,255,.08);padding:22px clamp(20px,5vw,80px);display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:12px}
.footer-copy{font-size:11px;color:rgba(255,255,255,.28);letter-spacing:.06em}
.footer-legal{display:flex;gap:20px}
.footer-legal a{font-size:11px;color:rgba(255,255,255,.28);transition:color .2s}
.footer-legal a:hover{color:#B8975A}

/* ─── SINGLE PROJECT ─────────────────────────────────────────── */
.project-hero-wrap{position:relative;height:72vh;min-height:480px;overflow:hidden}
.project-hero-img{width:100%;height:100%;object-fit:cover}
.project-hero-overlay{position:absolute;inset:0;background:linear-gradient(to bottom,rgba(255,255,255,0) 30%,rgba(26,26,26,.80) 100%)}
.project-hero-meta{position:absolute;bottom:52px;left:clamp(20px,5vw,80px)}
.project-details{display:grid;grid-template-columns:2fr 1fr;gap:64px;padding:clamp(52px,7vw,88px) clamp(20px,5vw,80px)}
.project-body p{font-size:15px;line-height:1.85;color:#3A3A3A;margin-bottom:20px}
.project-specs{display:flex;flex-direction:column}
.spec-item{border-bottom:1px solid rgba(26,26,26,.10);padding:16px 0}
.spec-label{font-size:11px;font-weight:700;letter-spacing:.30em;text-transform:uppercase;color:#B8975A;margin-bottom:4px}
.spec-value{font-size:15px;font-weight:500;color:#1A1A1A}
.project-gallery{display:grid;grid-template-columns:1fr 1fr;gap:3px}
.project-gallery img{width:100%;aspect-ratio:4/3;object-fit:cover;display:block}
.project-gallery .tall{aspect-ratio:auto;grid-row:span 2}

/* ─── BREADCRUMB ─────────────────────────────────────────────── */
.breadcrumb{display:flex;align-items:center;gap:8px;font-size:11px;color:#6B6B6B;padding:16px clamp(20px,5vw,80px);font-weight:600;letter-spacing:.05em}
.breadcrumb a{color:#6B6B6B;transition:color .2s}
.breadcrumb a:hover{color:#B8975A}
.breadcrumb-sep{color:rgba(26,26,26,.15)}

/* ─── RESPONSIVE ─────────────────────────────────────────────── */
@media(max-width:1200px){
  .services-grid{grid-template-columns:1fr 1fr}
  .footer-main{grid-template-columns:1fr 1fr}
  .media-grid{grid-template-columns:repeat(3,1fr)}
}
@media(max-width:991px){
  .about-grid,.project-details{grid-template-columns:1fr}
  .projects-grid{grid-template-columns:1fr 1fr}
  .project-card--featured{grid-column:span 2}
  .team-grid{grid-template-columns:1fr 1fr}
  .blog-grid{grid-template-columns:1fr 1fr}
  .media-grid{grid-template-columns:1fr 1fr;grid-auto-rows:180px}
  .media-showcase{grid-template-columns:1fr}
  .media-showcase-featured{aspect-ratio:16/9;grid-row:auto}
  .media-showcase-grid{grid-column:1;grid-template-columns:repeat(4,1fr);grid-template-rows:1fr}
  .stats-row{grid-template-columns:repeat(2,1fr)}
}
@media(max-width:767px){
  .primary-nav,.header-devis-btn{display:none}
  .nav-toggle{display:flex}
  .hero-title{font-size:clamp(44px,12vw,72px)}
  .hero-panel-tags{display:none}
  .services-grid{grid-template-columns:1fr}
  .projects-grid{grid-template-columns:1fr}
  .project-card--featured{grid-column:span 1}
  .team-grid{grid-template-columns:1fr}
  .blog-grid{grid-template-columns:1fr}
  .about-stats{grid-template-columns:1fr 1fr}
  .stats-row{grid-template-columns:1fr 1fr}
  .media-grid{grid-template-columns:1fr 1fr;grid-auto-rows:160px}
  .media-item--wide{grid-column:span 2}
  .media-item--tall{grid-row:auto}
  .footer-main{grid-template-columns:1fr}
  .newsletter-form{flex-direction:column;border-radius:3px}
  .newsletter-input{border-bottom:1px solid rgba(26,26,26,.10)}
  .hero-ctas,.cta-buttons,.section-cta-row{flex-direction:column;align-items:flex-start}
  .hero-content{padding-bottom:clamp(36px,6vw,64px)}
  .cta-section .cta-buttons{align-items:center}
}
@media(max-width:480px){
  .media-grid{grid-template-columns:1fr}
  .media-item--wide,.media-item--tall{grid-column:span 1;grid-row:auto}
  .projects-filter{gap:4px}
  .filter-tab{padding:6px 12px;font-size:9px}
}

/* ─── KEYFRAMES ──────────────────────────────────────────────── */
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.25}}
@keyframes ticker{from{transform:translateX(0)}to{transform:translateX(-50%)}}
@keyframes scroll-pulse{0%,100%{opacity:1;transform:scaleY(1)}50%{opacity:.2;transform:scaleY(.5)}}
