/* =========================================================
   ATELIER VERDANT — Sustainable Architecture
   Dark luxury / cinematic / editorial
   ========================================================= */

:root{
  --bg: #0d0c0a;
  --bg-2: #131210;
  --bg-3: #1a1814;
  --ink: #e9e2d4;          /* ivory */
  --ink-soft: #c9c2b3;
  --muted: #8a8275;
  --muted-2: #5b5448;
  --line: rgba(218,191,140,0.12);
  --line-strong: rgba(218,191,140,0.22);
  --bronze: #c69c5d;        /* warm bronze */
  --bronze-2: #b88845;
  --bronze-soft: #d4b27e;
  --gold: #e3c089;
  --beige: #d8cdb6;
  --shadow-1: 0 30px 80px rgba(0,0,0,0.5);
  --radius: 18px;
  --radius-lg: 26px;
  --transition: 0.55s cubic-bezier(.2,.7,.2,1);
}

*{box-sizing:border-box;margin:0;padding:0;}
html{scroll-behavior:smooth;}
body{
  background:var(--bg);
  color:var(--ink);
  font-family:'Inter',sans-serif;
  font-weight:300;
  line-height:1.6;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
img{display:block;max-width:100%;}
a{color:inherit;text-decoration:none;}
em{font-style:italic;}

/* ============== GRAIN ============== */
.grain{
  pointer-events:none;
  position:fixed;inset:0;z-index:9999;
  opacity:.06;mix-blend-mode:overlay;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='240' height='240'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2' stitchTiles='stitch'/><feColorMatrix values='0 0 0 0 0  0 0 0 0 0  0 0 0 0 0  0 0 0 0.6 0'/></filter><rect width='100%' height='100%' filter='url(%23n)'/></svg>");
}

/* ============== LOADER ============== */
.loader{
  position:fixed;inset:0;z-index:10000;
  background:radial-gradient(ellipse at center, #15130f 0%, #07060500 70%), #07060f0a, #0a0907;
  display:flex;align-items:center;justify-content:center;
  transition:opacity .8s ease, visibility .8s ease;
}
.loader.hide{opacity:0;visibility:hidden;}
.loader-grain{
  position:absolute;inset:0;opacity:.08;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='200' height='200'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='2'/></filter><rect width='100%' height='100%' filter='url(%23n)' opacity='0.6'/></svg>");
}
.loader-content{position:relative;text-align:center;width:min(420px,86vw);}
.loader-logo{display:flex;flex-direction:column;align-items:center;gap:14px;margin-bottom:46px;}
.loader-mark{
  font-family:'Cormorant Garamond',serif;font-size:44px;font-weight:400;letter-spacing:.06em;
  color:var(--ink);
}
.loader-mark .dot{color:var(--bronze);}
.loader-name{
  font-family:'Cormorant Garamond',serif;font-size:22px;font-style:italic;color:var(--ink-soft);
}
.loader-bar-wrap{margin-top:8px;}
.loader-bar{
  height:1px;background:rgba(255,255,255,.08);position:relative;overflow:hidden;
}
.loader-bar span{
  position:absolute;left:0;top:0;height:100%;width:0;
  background:linear-gradient(90deg, transparent, var(--bronze), var(--gold));
  transition:width .15s linear;
}
.loader-meta{
  display:flex;justify-content:space-between;margin-top:14px;
  font-size:11px;letter-spacing:.3em;text-transform:uppercase;color:var(--muted);
}
.loader-tagline{
  margin-top:34px;font-size:11px;letter-spacing:.4em;text-transform:uppercase;color:var(--muted-2);
}

/* ============== TYPOGRAPHY ============== */
.serif-h2{
  font-family:'Cormorant Garamond',serif;
  font-weight:400;
  font-size:clamp(34px,4.4vw,62px);
  line-height:1.05;
  letter-spacing:-.01em;
  color:var(--ink);
}
.serif-h2 em{color:var(--bronze);font-style:italic;}
.serif-display{
  font-family:'Cormorant Garamond',serif;
  font-weight:400;
  font-size:clamp(42px,6vw,90px);
  line-height:1.02;
  letter-spacing:-.01em;
}
.serif-display em{color:var(--bronze);font-style:italic;}
.eyebrow{
  display:inline-block;font-size:11px;letter-spacing:.32em;text-transform:uppercase;
  color:var(--bronze);font-weight:500;margin-bottom:18px;
}
.eyebrow.ivory{color:var(--ink-soft);}
.lead{color:var(--ink-soft);font-size:17px;max-width:46ch;}

/* ============== BUTTONS ============== */
.btn{
  display:inline-flex;align-items:center;gap:10px;
  padding:14px 26px;border-radius:999px;
  font-family:'Inter',sans-serif;font-size:13px;font-weight:500;
  letter-spacing:.18em;text-transform:uppercase;
  transition:var(--transition);cursor:pointer;border:1px solid transparent;
  white-space:nowrap;
}
.btn-primary{
  background:linear-gradient(135deg,#b88845,#d4b27e);
  color:#1a1208;
  box-shadow:0 10px 30px rgba(198,156,93,0.18);
}
.btn-primary:hover{
  transform:translateY(-2px);
  box-shadow:0 18px 50px rgba(198,156,93,0.45), 0 0 0 1px rgba(212,178,126,0.4);
  background:linear-gradient(135deg,#cf9e5b,#e7c690);
}
.btn-primary.lg{padding:18px 34px;font-size:13px;}
.btn-ghost{
  border:1px solid var(--line-strong);color:var(--ink);background:transparent;
}
.btn-ghost:hover{border-color:var(--bronze);color:var(--bronze);background:rgba(198,156,93,.06);}
.btn-ghost-lg{
  border:1px solid var(--line-strong);color:var(--ink);background:transparent;
  display:inline-flex;align-items:center;gap:12px;padding:18px 36px;border-radius:999px;
  font-size:12px;letter-spacing:.24em;text-transform:uppercase;transition:var(--transition);
}
.btn-ghost-lg:hover{border-color:var(--bronze);color:var(--bronze);}
.btn-ghost-sm{
  border:1px solid var(--line-strong);color:var(--ink);
  display:inline-flex;align-items:center;gap:10px;padding:12px 22px;border-radius:999px;
  font-size:11px;letter-spacing:.24em;text-transform:uppercase;transition:var(--transition);
}
.btn-ghost-sm:hover{border-color:var(--bronze);color:var(--bronze);}
.btn-pill{
  display:inline-flex;align-items:center;gap:10px;
  padding:11px 22px;border:1px solid var(--line-strong);border-radius:999px;
  font-size:11px;letter-spacing:.24em;text-transform:uppercase;color:var(--ink);
  transition:var(--transition);
}
.btn-pill:hover{border-color:var(--bronze);color:var(--bronze);background:rgba(198,156,93,.06);}
.btn-text{
  font-size:13px;color:var(--ink-soft);letter-spacing:.04em;border-bottom:1px solid var(--line-strong);
  padding-bottom:4px;transition:var(--transition);
}
.btn-text:hover{color:var(--bronze);border-color:var(--bronze);}

/* ============== HEADER ============== */
.site-header{
  position:fixed;top:0;left:0;right:0;z-index:200;
  padding:22px 0;transition:var(--transition);
  border-bottom:1px solid transparent;
}
.site-header.scrolled{
  background:rgba(13,12,10,0.78);
  backdrop-filter:blur(18px) saturate(140%);
  -webkit-backdrop-filter:blur(18px) saturate(140%);
  border-bottom:1px solid var(--line);
  padding:14px 0;
}
.header-inner{
  max-width:1320px;margin:0 auto;padding:0 36px;
  display:flex;align-items:center;justify-content:space-between;gap:30px;
}
.brand{display:flex;align-items:center;gap:12px;}
.brand-mark{
  font-family:'Cormorant Garamond',serif;font-size:24px;letter-spacing:.04em;color:var(--ink);
}
.brand-mark .dot{color:var(--bronze);}
.brand-name{
  font-family:'Cormorant Garamond',serif;font-size:18px;font-style:italic;color:var(--ink-soft);
}
.nav-main{display:flex;gap:38px;}
.nav-main a{
  font-size:11px;letter-spacing:.28em;text-transform:uppercase;color:var(--ink-soft);
  transition:var(--transition);position:relative;padding:6px 0;
}
.nav-main a::after{
  content:'';position:absolute;left:0;bottom:0;width:0;height:1px;
  background:var(--bronze);transition:var(--transition);
}
.nav-main a:hover{color:var(--bronze);}
.nav-main a:hover::after{width:100%;}
.header-right{display:flex;align-items:center;gap:18px;}
.theme-icon{
  width:36px;height:36px;border-radius:50%;border:1px solid var(--line);
  display:flex;align-items:center;justify-content:center;color:var(--bronze-soft);font-size:13px;
}
.menu-toggle{display:none;background:none;border:none;cursor:pointer;flex-direction:column;gap:5px;}
.menu-toggle span{display:block;width:22px;height:1px;background:var(--ink);}

/* ============== HERO ============== */
.hero{
  position:relative;min-height:100vh;
  display:flex;align-items:flex-end;
  padding:0 0 12vh;overflow:hidden;
}
.hero-fallback{
  position:absolute;inset:0;z-index:0;
  background-image:url('https://images.unsplash.com/photo-1600585154340-be6161a56a0c?auto=format&fit=crop&w=2400&q=80');
  background-size:cover;background-position:center;
  filter:saturate(.9) contrast(1.05) brightness(.85);
}
.hero-video{
  position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:0;
  filter:saturate(.95) contrast(1.05);
  background:#0a0907;
}
.hero-overlay{
  position:absolute;inset:0;z-index:1;
  background:
    linear-gradient(90deg, rgba(8,7,5,0.88) 0%, rgba(8,7,5,0.55) 35%, rgba(8,7,5,0.2) 70%, rgba(8,7,5,0.45) 100%),
    linear-gradient(to top, rgba(8,7,5,0.95) 0%, rgba(8,7,5,0.4) 40%, rgba(8,7,5,0.2) 80%);
}
.hero-vignette{
  position:absolute;inset:0;z-index:1;pointer-events:none;
  box-shadow:inset 0 0 240px 60px rgba(0,0,0,0.6);
}
.hero-content{
  position:relative;z-index:2;
  max-width:1320px;width:100%;margin:0 auto;padding:0 36px;
}
.badge{
  display:inline-flex;align-items:center;gap:10px;
  padding:8px 18px;border:1px solid var(--line-strong);border-radius:999px;
  font-size:10.5px;letter-spacing:.28em;text-transform:uppercase;color:var(--bronze-soft);
  background:rgba(198,156,93,.06);backdrop-filter:blur(8px);
  margin-bottom:32px;
}
.badge-dot{
  width:6px;height:6px;border-radius:50%;background:var(--bronze);
  box-shadow:0 0 14px var(--bronze);
}
.hero-title{
  font-family:'Cormorant Garamond',serif;
  font-weight:400;
  font-size:clamp(48px,6.6vw,108px);
  line-height:1.02;
  letter-spacing:-.015em;
  max-width:14ch;
  color:var(--ink);
  margin-bottom:28px;
}
.hero-title em{
  color:var(--bronze);font-style:italic;
  background:linear-gradient(180deg,var(--gold),var(--bronze));
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;
}
.hero-sub{
  max-width:48ch;color:var(--ink-soft);font-size:18px;line-height:1.65;
  margin-bottom:42px;
}
.hero-actions{display:flex;gap:16px;flex-wrap:wrap;}

/* Floating stats card */
.hero-stats{
  position:absolute;left:36px;bottom:38px;z-index:3;
  display:flex;align-items:stretch;gap:0;
  background:rgba(20,18,14,0.55);
  backdrop-filter:blur(22px) saturate(140%);
  -webkit-backdrop-filter:blur(22px) saturate(140%);
  border:1px solid var(--line);border-radius:18px;
  padding:22px 6px;
  max-width:560px;
  box-shadow:0 24px 60px rgba(0,0,0,0.4);
}
.hero-stats .stat{
  flex:1;padding:0 26px;display:flex;flex-direction:column;gap:4px;min-width:140px;
}
.stat-num{
  font-family:'Cormorant Garamond',serif;font-size:38px;font-weight:400;color:var(--ink);
  line-height:1;
}
.stat-num sup{color:var(--bronze);font-size:18px;margin-left:2px;top:-12px;position:relative;}
.stat-num small{color:var(--bronze);font-size:18px;}
.stat-label{font-size:10.5px;letter-spacing:.24em;text-transform:uppercase;color:var(--muted);}
.stat-sep{width:1px;background:var(--line);}

.scroll-cue{
  position:absolute;right:36px;bottom:48px;z-index:3;
  display:flex;align-items:center;gap:14px;
  font-size:10px;letter-spacing:.4em;text-transform:uppercase;color:var(--muted);
}
.scroll-cue span{
  width:1px;height:46px;background:linear-gradient(to bottom, transparent, var(--bronze));
  display:block;animation:scrollPulse 2.4s ease-in-out infinite;
}
@keyframes scrollPulse{
  0%,100%{opacity:.3;transform:scaleY(.6);transform-origin:top;}
  50%{opacity:1;transform:scaleY(1);transform-origin:top;}
}

/* ============== CONTAINER & SECTIONS ============== */
.container{max-width:1320px;margin:0 auto;padding:0 36px;}
section{position:relative;}
.section-head{
  display:grid;grid-template-columns:1.2fr 1fr;gap:60px;align-items:end;
  margin-bottom:70px;
}
.section-head.center{
  display:block;text-align:center;max-width:760px;margin-left:auto;margin-right:auto;
}
.section-intro{color:var(--ink-soft);font-size:16px;max-width:48ch;}
.link-arrow{
  font-size:11px;letter-spacing:.28em;text-transform:uppercase;color:var(--ink-soft);
  display:inline-flex;align-items:center;gap:10px;transition:var(--transition);
}
.link-arrow:hover{color:var(--bronze);gap:14px;}

/* ============== PHILOSOPHY ============== */
.philosophy{padding:140px 0;background:var(--bg);}
.philo-grid{
  display:grid;grid-template-columns:1fr 1.05fr;gap:90px;align-items:center;
}
.philo-text .lead{margin:18px 0 38px;}
.feature-list{list-style:none;display:flex;flex-direction:column;gap:24px;border-top:1px solid var(--line);padding-top:30px;}
.feature-list li{display:flex;gap:18px;align-items:flex-start;}
.feature-list .ico{
  flex:0 0 auto;width:42px;height:42px;border-radius:50%;
  border:1px solid var(--line-strong);background:rgba(198,156,93,.06);
  display:flex;align-items:center;justify-content:center;color:var(--bronze);font-size:15px;
}
.feature-list h4{
  font-family:'Cormorant Garamond',serif;font-weight:500;font-size:20px;color:var(--ink);
  margin-bottom:4px;
}
.feature-list p{color:var(--muted);font-size:14px;}

.philo-visual{position:relative;}
.philo-image{
  border-radius:var(--radius-lg);overflow:hidden;
  aspect-ratio:4/5;
  box-shadow:var(--shadow-1);
  position:relative;
}
.philo-image img{
  width:100%;height:100%;object-fit:cover;
  transition:transform 1.6s ease;
}
.philo-image:hover img{transform:scale(1.04);}
.caption-card{
  position:absolute;bottom:28px;left:-30px;max-width:280px;
  background:rgba(20,18,14,0.78);backdrop-filter:blur(18px);
  border:1px solid var(--line-strong);border-radius:14px;
  padding:20px 22px;
  box-shadow:0 20px 50px rgba(0,0,0,.5);
}
.caption-card .caption-label{
  display:flex;align-items:center;gap:8px;font-size:10px;letter-spacing:.3em;
  text-transform:uppercase;color:var(--bronze);margin-bottom:10px;
}
.caption-card p{
  font-family:'Cormorant Garamond',serif;font-size:18px;font-style:italic;color:var(--ink);line-height:1.4;
}
.philo-tag{
  position:absolute;top:24px;right:24px;
  background:rgba(13,12,10,0.7);backdrop-filter:blur(14px);
  border:1px solid var(--line);border-radius:10px;
  padding:10px 16px;text-align:right;
}
.philo-tag span{display:block;font-family:'Cormorant Garamond',serif;font-size:16px;color:var(--ink);}
.philo-tag small{font-size:10px;letter-spacing:.24em;text-transform:uppercase;color:var(--muted);}

/* ============== SERVICES ============== */
.services{
  padding:140px 0;
  background:linear-gradient(180deg, var(--bg) 0%, #0b0a08 100%);
}
.services-grid{
  display:grid;
  grid-template-columns:repeat(3, 1fr);
  grid-auto-rows:1fr;
  gap:18px;
}
.service-card{
  position:relative;
  background:linear-gradient(160deg, rgba(28,25,20,0.6), rgba(18,16,12,0.4));
  border:1px solid var(--line);border-radius:var(--radius);
  padding:34px 30px;
  transition:var(--transition);
  overflow:hidden;
  display:flex;flex-direction:column;gap:14px;
  min-height:240px;
  backdrop-filter:blur(8px);
}
.service-card::before{
  content:'';position:absolute;inset:0;border-radius:var(--radius);
  background:radial-gradient(400px circle at var(--x,50%) var(--y,0%), rgba(198,156,93,0.18), transparent 60%);
  opacity:0;transition:opacity .6s ease;pointer-events:none;
}
.service-card:hover{
  transform:translateY(-6px);
  border-color:var(--line-strong);
  box-shadow:0 30px 60px rgba(0,0,0,.4);
}
.service-card:hover::before{opacity:1;}
.service-card.large{
  grid-column:span 1;grid-row:span 2;
  min-height:480px;
  background:linear-gradient(160deg, rgba(38,30,20,0.7), rgba(20,16,12,0.5));
  padding:42px 36px;
}
.card-num{
  position:absolute;top:24px;right:28px;
  font-family:'Cormorant Garamond',serif;font-size:14px;color:var(--bronze);letter-spacing:.2em;
}
.ico-lg{
  width:48px;height:48px;border-radius:12px;
  border:1px solid var(--line-strong);background:rgba(198,156,93,.06);
  display:flex;align-items:center;justify-content:center;color:var(--bronze);font-size:18px;
  margin-bottom:12px;
}
.service-card h3{
  font-family:'Cormorant Garamond',serif;font-weight:500;font-size:24px;color:var(--ink);
}
.service-card.large h3{font-size:32px;}
.service-card p{color:var(--ink-soft);font-size:14px;line-height:1.6;}
.service-card.large p{font-size:16px;max-width:38ch;}
.mini-list{list-style:none;display:flex;flex-direction:column;gap:10px;margin-top:8px;}
.mini-list li{font-size:13px;color:var(--ink-soft);display:flex;align-items:center;gap:10px;}
.mini-list i{color:var(--bronze);font-size:11px;}
.card-link{
  margin-top:auto;font-size:11px;letter-spacing:.28em;text-transform:uppercase;
  color:var(--bronze);display:inline-flex;align-items:center;gap:10px;transition:var(--transition);
}
.card-link:hover{gap:14px;color:var(--gold);}

/* ============== MARQUEE ============== */
.marquee{
  border-top:1px solid var(--line);border-bottom:1px solid var(--line);
  padding:22px 0;background:#0a0907;overflow:hidden;
}
.marquee-track{
  display:flex;align-items:center;gap:34px;
  white-space:nowrap;
  animation:marquee 60s linear infinite;
  font-size:11px;letter-spacing:.4em;text-transform:uppercase;
  color:var(--ink-soft);
}
.marquee-track span{color:var(--ink-soft);font-weight:400;}
.marquee-track .dot-sep{
  width:5px;height:5px;border-radius:50%;background:var(--bronze);flex:0 0 auto;
}
@keyframes marquee{
  from{transform:translateX(0);}
  to{transform:translateX(-50%);}
}

/* ============== PROJECTS ============== */
.projects{padding:140px 0;background:var(--bg);}
.projects-grid{
  display:grid;grid-template-columns:repeat(3,1fr);gap:22px;
}
.project-feature{grid-column:1 / -1;}
.project-card{
  position:relative;
  border-radius:var(--radius-lg);overflow:hidden;
  background:#0a0907;
  display:block;
  border:1px solid var(--line);
  transition:var(--transition);
}
.project-card:hover{transform:translateY(-4px);border-color:var(--line-strong);}
.project-img{
  aspect-ratio:4/3;overflow:hidden;position:relative;
}
.project-feature .project-img{aspect-ratio:21/9;}
.project-img img{
  width:100%;height:100%;object-fit:cover;
  transition:transform 1.4s ease;
}
.project-card:hover .project-img img{transform:scale(1.06);}
.project-img::after{
  content:'';position:absolute;inset:0;
  background:linear-gradient(to top, rgba(8,7,5,0.95) 0%, rgba(8,7,5,0.4) 35%, transparent 65%);
}
.project-meta{
  position:absolute;left:0;right:0;bottom:0;
  padding:28px 30px;z-index:2;color:var(--ink);
}
.project-feature .project-meta{padding:42px 50px;max-width:600px;}
.project-cat{
  font-size:10.5px;letter-spacing:.3em;text-transform:uppercase;color:var(--bronze);
  display:block;margin-bottom:10px;
}
.project-title{
  font-family:'Cormorant Garamond',serif;font-weight:400;font-size:30px;line-height:1.1;
  color:var(--ink);margin-bottom:6px;
}
.project-feature .project-title{font-size:48px;margin-bottom:14px;}
.project-meta p{color:var(--ink-soft);font-size:14px;max-width:42ch;}
.project-feature .project-meta p{font-size:16px;}
.project-cta{
  display:inline-flex;align-items:center;gap:10px;
  margin-top:16px;
  font-size:11px;letter-spacing:.28em;text-transform:uppercase;color:var(--bronze);
  transition:var(--transition);
}
.project-card:hover .project-cta{gap:14px;color:var(--gold);}
.featured-tag{
  position:absolute;top:22px;left:22px;z-index:3;
  background:rgba(198,156,93,0.16);backdrop-filter:blur(10px);
  border:1px solid var(--line-strong);border-radius:999px;
  padding:6px 14px;font-size:10px;letter-spacing:.3em;text-transform:uppercase;color:var(--bronze-soft);
}
.center-cta{text-align:center;margin-top:60px;}

/* ============== PROCESS ============== */
.process{
  padding:160px 0;
  background:radial-gradient(ellipse at top, #15130f 0%, var(--bg) 60%);
}
.timeline{
  position:relative;max-width:980px;margin:0 auto;padding:30px 0;
}
.timeline-line{
  position:absolute;left:50%;top:0;bottom:0;width:1px;
  background:linear-gradient(to bottom, transparent, var(--line-strong) 10%, var(--line-strong) 90%, transparent);
}
.timeline-step{
  position:relative;display:grid;grid-template-columns:1fr auto 1fr;gap:30px;align-items:center;
  margin-bottom:80px;
}
.timeline-step:last-child{margin-bottom:0;}
.timeline-step[data-side="left"] .step-card{grid-column:1;text-align:right;}
.timeline-step[data-side="left"] .step-dot{grid-column:2;}
.timeline-step[data-side="right"] .step-card{grid-column:3;text-align:left;}
.timeline-step[data-side="right"] .step-dot{grid-column:2;}
.step-card{
  background:linear-gradient(160deg, rgba(28,25,20,0.7), rgba(18,16,12,0.5));
  border:1px solid var(--line);border-radius:var(--radius);
  padding:30px 34px;
  backdrop-filter:blur(10px);
  transition:var(--transition);
}
.step-card:hover{border-color:var(--line-strong);transform:translateY(-3px);}
.step-num{
  font-family:'Cormorant Garamond',serif;font-size:14px;color:var(--bronze);letter-spacing:.3em;
  display:block;margin-bottom:8px;
}
.step-card h3{
  font-family:'Cormorant Garamond',serif;font-weight:500;font-size:26px;color:var(--ink);
  margin-bottom:8px;
}
.step-card p{color:var(--ink-soft);font-size:14.5px;line-height:1.6;}
.step-dot{
  width:14px;height:14px;border-radius:50%;
  background:var(--bronze);box-shadow:0 0 0 6px rgba(198,156,93,0.12), 0 0 20px var(--bronze);
  position:relative;z-index:2;
}

/* ============== TESTIMONIALS ============== */
.testimonials{padding:140px 0;background:var(--bg);}
.testi-grid{
  display:grid;grid-template-columns:repeat(3,1fr);gap:22px;margin-bottom:90px;
}
.testi-card{
  background:linear-gradient(160deg, rgba(28,25,20,0.6), rgba(18,16,12,0.4));
  border:1px solid var(--line);border-radius:var(--radius);
  padding:34px 30px;
  display:flex;flex-direction:column;gap:22px;
  transition:var(--transition);
  backdrop-filter:blur(8px);
}
.testi-card:hover{border-color:var(--line-strong);transform:translateY(-4px);}
.stars{display:flex;gap:4px;color:var(--bronze);font-size:11px;}
.testi-card blockquote{
  font-family:'Cormorant Garamond',serif;font-size:21px;font-weight:400;line-height:1.45;
  color:var(--ink);font-style:italic;
}
.testi-author{display:flex;align-items:center;gap:14px;border-top:1px solid var(--line);padding-top:18px;margin-top:auto;}
.avatar{
  width:46px;height:46px;border-radius:50%;
  background-size:cover;background-position:center;
  display:flex;align-items:center;justify-content:center;
  font-family:'Cormorant Garamond',serif;font-size:16px;color:var(--ink);
  border:1px solid var(--line-strong);
}
.testi-author strong{display:block;font-size:14px;color:var(--ink);font-weight:500;}
.testi-author small{font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--muted);}

/* TRUST ROW */
.trust-row{
  display:grid;grid-template-columns:repeat(4,1fr);gap:30px;
  border-top:1px solid var(--line);border-bottom:1px solid var(--line);
  padding:36px 0;
}
.trust-item{
  display:flex;align-items:center;gap:16px;justify-content:center;
}
.trust-item i{color:var(--bronze);font-size:20px;}
.trust-item strong{
  font-family:'Cormorant Garamond',serif;font-size:30px;font-weight:400;color:var(--ink);display:block;line-height:1;
}
.trust-item span{font-size:11px;letter-spacing:.24em;text-transform:uppercase;color:var(--muted);}

/* ============== JOURNAL ============== */
.journal{padding:140px 0;background:linear-gradient(180deg, var(--bg) 0%, #0b0a08 100%);}
.journal-grid{
  display:grid;grid-template-columns:repeat(3,1fr);gap:22px;
}
.article-card{
  background:rgba(18,16,12,0.5);
  border:1px solid var(--line);border-radius:var(--radius);
  overflow:hidden;
  transition:var(--transition);
  display:flex;flex-direction:column;
}
.article-card:hover{transform:translateY(-4px);border-color:var(--line-strong);}
.article-img{aspect-ratio:4/3;overflow:hidden;}
.article-img img{width:100%;height:100%;object-fit:cover;transition:transform 1.4s ease;}
.article-card:hover .article-img img{transform:scale(1.06);}
.article-meta{padding:28px 28px 30px;display:flex;flex-direction:column;gap:10px;flex:1;}
.cat-tag{
  align-self:flex-start;font-size:10px;letter-spacing:.28em;text-transform:uppercase;
  color:var(--bronze);border:1px solid var(--line-strong);border-radius:999px;padding:5px 12px;
  margin-bottom:6px;
}
.article-meta h3{
  font-family:'Cormorant Garamond',serif;font-weight:500;font-size:22px;line-height:1.2;color:var(--ink);
}
.article-meta p{color:var(--ink-soft);font-size:14px;line-height:1.6;}
.read-link{
  margin-top:auto;font-size:11px;letter-spacing:.28em;text-transform:uppercase;color:var(--bronze);
  display:inline-flex;align-items:center;gap:10px;transition:var(--transition);
  padding-top:14px;
}
.article-card:hover .read-link{gap:14px;color:var(--gold);}

/* ============== FINAL CTA ============== */
.final-cta{
  position:relative;padding:160px 0;overflow:hidden;
  isolation:isolate;
}
.cta-bg{
  position:absolute;inset:0;background-size:cover;background-position:center;
  z-index:-2;filter:saturate(.9);
  transform:scale(1.05);
}
.cta-overlay{
  position:absolute;inset:0;z-index:-1;
  background:
    radial-gradient(ellipse at center, rgba(8,7,5,0.6), rgba(8,7,5,0.95)),
    linear-gradient(to top, rgba(8,7,5,1), rgba(8,7,5,0.4));
}
.cta-content{text-align:center;max-width:880px;}
.cta-content .serif-display{margin:18px 0 24px;}
.cta-sub{color:var(--ink-soft);font-size:18px;max-width:58ch;margin:0 auto 42px;}
.cta-actions{display:flex;align-items:center;justify-content:center;gap:32px;flex-wrap:wrap;}

/* ============== FOOTER ============== */
.site-footer{padding:90px 0 40px;background:#08070500;border-top:1px solid var(--line);}
.footer-grid{
  display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:60px;
  padding-bottom:60px;border-bottom:1px solid var(--line);
}
.footer-brand p{
  margin-top:18px;color:var(--muted);font-size:14px;max-width:36ch;
}
.footer-col h5{
  font-size:11px;letter-spacing:.3em;text-transform:uppercase;color:var(--bronze);
  margin-bottom:18px;font-weight:500;
}
.footer-col a{
  display:block;font-size:14px;color:var(--ink-soft);padding:6px 0;transition:var(--transition);
}
.footer-col a:hover{color:var(--bronze);}
.footer-base{
  display:flex;justify-content:space-between;align-items:center;padding-top:30px;
}
.footer-base small{font-size:12px;color:var(--muted);letter-spacing:.06em;}

/* ============== REVEAL ANIM ============== */
.reveal{opacity:0;transform:translateY(34px);transition:opacity 1s ease, transform 1s cubic-bezier(.2,.7,.2,1);}
.reveal.in{opacity:1;transform:translateY(0);}

/* ============== RESPONSIVE ============== */
@media (max-width: 1100px){
  .nav-main{display:none;}
  .menu-toggle{display:flex;}
  .philo-grid{grid-template-columns:1fr;gap:60px;}
  .section-head{grid-template-columns:1fr;gap:24px;}
  .services-grid{grid-template-columns:repeat(2,1fr);}
  .service-card.large{grid-column:span 2;grid-row:span 1;min-height:auto;}
  .projects-grid{grid-template-columns:repeat(2,1fr);}
  .project-feature{grid-column:1 / -1;}
  .project-feature .project-title{font-size:36px;}
  .testi-grid,.journal-grid{grid-template-columns:1fr;}
  .trust-row{grid-template-columns:repeat(2,1fr);gap:24px;}
  .footer-grid{grid-template-columns:1fr 1fr;gap:40px;}
  .timeline-line{left:20px;}
  .timeline-step{grid-template-columns:40px 1fr;gap:18px;}
  .timeline-step[data-side="left"] .step-card,
  .timeline-step[data-side="right"] .step-card{grid-column:2;text-align:left;}
  .timeline-step[data-side="left"] .step-dot,
  .timeline-step[data-side="right"] .step-dot{grid-column:1;justify-self:center;}
  .hero-stats{position:relative;left:auto;bottom:auto;margin-top:50px;max-width:100%;}
  .hero{padding-bottom:60px;}
}
@media (max-width: 700px){
  .header-inner{padding:0 22px;}
  .btn-pill{display:none;}
  .container{padding:0 22px;}
  .hero-content{padding:0 22px;}
  .hero-stats{flex-direction:column;gap:14px;padding:22px 24px;}
  .hero-stats .stat{padding:12px 0;}
  .stat-sep{width:100%;height:1px;}
  .scroll-cue{display:none;}
  .services-grid{grid-template-columns:1fr;}
  .service-card.large{grid-column:span 1;}
  .projects-grid{grid-template-columns:1fr;}
  .project-feature .project-meta{padding:24px;}
  .trust-row{grid-template-columns:1fr 1fr;}
  .footer-grid{grid-template-columns:1fr;gap:30px;}
  .footer-base{flex-direction:column;gap:10px;text-align:center;}
  .philosophy,.services,.projects,.process,.testimonials,.journal,.final-cta{padding:90px 0;}
  .caption-card{left:0;right:0;bottom:-20px;margin:0 12px;max-width:none;}
  .philo-tag{top:12px;right:12px;}
}
