:root{
    --paper:#F3EEE1; --paper-2:#ECE5D3; --ink:#1C2415; --ink-soft:#3c4630;
    --forest:#243018; --forest-2:#2E3D22; --olive:#7C8049; --moss:#9DAE7E;
    --tan:#B9763E; --tan-soft:#cf9362; --lake:#7E96A1; --lake-deep:#5d7480;
    --line:rgba(36,48,24,.16); --shadow:0 22px 60px -28px rgba(28,36,21,.55);
    --maxw:1180px;
  }
  *{box-sizing:border-box;margin:0;padding:0}
  html{scroll-behavior:smooth}
  body{
    background:var(--paper); color:var(--ink);
    font-family:"Hanken Grotesk",system-ui,sans-serif; font-weight:400;
    line-height:1.6; -webkit-font-smoothing:antialiased; overflow-x:hidden;
  }
  /* grain + paper texture overlay */
  body::before{
    content:""; position:fixed; inset:0; z-index:1; pointer-events:none; opacity:.05;
    background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
  }
  .wrap{max-width:var(--maxw); margin:0 auto; padding:0 28px; position:relative; z-index:2}
  h1,h2,h3,.display{font-family:"Fraunces",Georgia,serif; font-optical-sizing:auto; line-height:1.02; letter-spacing:-.01em}
  a{color:inherit}
  .overline{font-size:.74rem; letter-spacing:.28em; text-transform:uppercase; font-weight:600; color:var(--olive)}
  .serif-it{font-family:"Fraunces",serif; font-style:italic; font-weight:400}

  /* ---------- top bar ---------- */
  header{position:absolute; top:0; left:0; right:0; z-index:5}
  .nav{display:flex; align-items:center; justify-content:space-between; padding:26px 28px; max-width:var(--maxw); margin:0 auto}
  .brandmark{display:flex; align-items:center; gap:11px; font-family:"Fraunces",serif; font-weight:600; font-size:1.06rem; letter-spacing:-.01em}
  .leaf{width:26px;height:26px;flex:0 0 auto}
  .nav .loc{font-size:.78rem; letter-spacing:.16em; text-transform:uppercase; color:var(--ink-soft); opacity:.8}
  @media(max-width:640px){.nav .loc{display:none}}
  .navright{display:flex; align-items:center; gap:18px}
  .lang{font-size:.78rem; letter-spacing:.12em; font-weight:600; white-space:nowrap}
  .lang a{text-decoration:none; color:var(--ink-soft); opacity:.6}
  .lang a.on{color:var(--forest); opacity:1}
  .lang a:hover{opacity:1}

  /* ---------- hero ---------- */
  .hero{position:relative; min-height:100svh; display:flex; align-items:flex-end; padding-bottom:7vh; overflow:hidden}
  .hero .topo{position:absolute; inset:0; z-index:0; opacity:.5}
  .hero .glow{position:absolute; z-index:0; width:60vw; height:60vw; right:-18vw; top:-12vw; border-radius:50%;
    background:radial-gradient(circle at center,rgba(157,174,126,.45),transparent 62%); filter:blur(10px)}
  .hero-inner{position:relative; z-index:2; width:100%}
  .eyebrow{display:flex; align-items:center; gap:14px; margin-bottom:26px}
  .eyebrow .rule{height:1px;width:46px;background:var(--olive)}
  .hero h1{font-size:clamp(3.1rem,10.5vw,8.8rem); font-weight:340; color:var(--forest)}
  .hero h1 b{font-weight:600}
  .hero h1 .gardens{display:block; font-style:italic; font-weight:340; color:var(--tan); margin-left:.06em}
  .hero .lede{max-width:33ch; margin-top:30px; font-size:clamp(1.05rem,1.7vw,1.32rem); color:var(--ink-soft)}
  .hero-meta{display:flex; flex-wrap:wrap; gap:34px; margin-top:40px; align-items:flex-end}
  .cta{display:inline-flex; align-items:center; gap:10px; background:var(--forest); color:var(--paper);
    padding:15px 26px; border-radius:999px; font-weight:600; font-size:.95rem; text-decoration:none;
    transition:background .25s ease, transform .25s ease}
  .cta:hover{background:var(--forest-2); transform:translateY(-2px)}
  .cta svg{transition:transform .25s ease}
  .cta:hover svg{transform:translateX(3px)}
  .stat-quick{font-size:.82rem; color:var(--ink-soft)}
  .stat-quick b{font-family:"Fraunces",serif; font-size:1.5rem; color:var(--forest); display:block; font-weight:500}

  /* ---------- sections ---------- */
  section{position:relative; padding:clamp(72px,11vh,140px) 0}
  .secnum{font-family:"Fraunces",serif; font-style:italic; color:var(--tan); font-size:1.05rem; margin-bottom:14px; display:block}
  .sectitle{font-size:clamp(2rem,4.4vw,3.5rem); font-weight:360; color:var(--forest); max-width:18ch}
  .sectitle b{font-weight:600}
  .lead-p{font-size:clamp(1.05rem,1.5vw,1.2rem); max-width:60ch; color:var(--ink-soft); margin-top:22px}
  .divider{height:1px;background:var(--line);max-width:var(--maxw);margin:0 auto}

  .band{background:var(--forest); color:var(--paper)}
  .band .secnum{color:var(--moss)}
  .band .sectitle{color:var(--paper)}
  .band .lead-p{color:rgba(243,238,225,.78)}

  /* vision split */
  .split{display:grid; grid-template-columns:1fr 1fr; gap:60px; align-items:center}
  @media(max-width:860px){.split{grid-template-columns:1fr; gap:36px}}
  .vlist{margin-top:30px; display:flex; flex-direction:column; gap:2px}
  .vlist div{display:flex; gap:16px; padding:16px 0; border-top:1px solid var(--line)}
  .vlist .k{font-family:"Fraunces",serif; font-style:italic; color:var(--tan); flex:0 0 28px}
  .vlist .v b{display:block; font-weight:600; color:var(--forest)}

  /* zones */
  .map-card{position:relative; border-radius:18px; overflow:hidden; box-shadow:var(--shadow); background:var(--paper-2); border:1px solid var(--line)}
  .map-card img{display:block; width:100%; height:auto}
  .map-cap{font-size:.8rem; color:var(--ink-soft); margin-top:14px; letter-spacing:.04em}
  .zones{display:flex; flex-direction:column; gap:0; margin-top:6px}
  .zone{display:grid; grid-template-columns:auto 1fr auto; gap:22px; align-items:baseline; padding:22px 0; border-top:1px solid var(--line)}
  .zone:last-child{border-bottom:1px solid var(--line)}
  .zone .z{font-family:"Fraunces",serif; font-weight:600; font-size:1.5rem; color:var(--olive)}
  .zone .zt{font-weight:600; color:var(--forest)} .zone .zd{font-size:.93rem; color:var(--ink-soft); margin-top:3px}
  .zone .za{font-size:.84rem; color:var(--tan); font-weight:600; white-space:nowrap}

  /* feature row hempcrete */
  .feat{display:grid; grid-template-columns:repeat(3,1fr); gap:26px; margin-top:48px}
  @media(max-width:760px){.feat{grid-template-columns:1fr}}
  .feat .card{padding:30px; border:1px solid rgba(243,238,225,.16); border-radius:16px; background:rgba(243,238,225,.04)}
  .feat .card h3{font-size:1.3rem; color:var(--paper); font-weight:500; margin-bottom:10px}
  .feat .card p{font-size:.95rem; color:rgba(243,238,225,.75)}
  .feat .ic{width:34px;height:34px;margin-bottom:18px;color:var(--moss)}

  /* tracks */
  .tracks{display:grid; grid-template-columns:repeat(3,1fr); gap:24px; margin-top:52px}
  @media(max-width:880px){.tracks{grid-template-columns:1fr}}
  .track{position:relative; background:var(--paper-2); border:1px solid var(--line); border-radius:18px; padding:34px 30px;
    display:flex; flex-direction:column; transition:transform .3s ease, box-shadow .3s ease}
  .track:hover{transform:translateY(-5px); box-shadow:var(--shadow)}
  .track.lead{background:var(--forest); color:var(--paper)}
  .track .tg{font-size:.74rem; letter-spacing:.2em; text-transform:uppercase; font-weight:600; color:var(--tan)}
  .track.lead .tg{color:var(--moss)}
  .track h3{font-size:1.65rem; font-weight:500; margin:14px 0 6px; color:var(--forest)}
  .track.lead h3{color:var(--paper)}
  .track .who{font-size:.86rem; color:var(--ink-soft); font-style:italic; font-family:"Fraunces",serif}
  .track.lead .who{color:var(--moss)}
  .track p{font-size:.95rem; margin-top:18px; color:var(--ink-soft)}
  .track.lead p{color:rgba(243,238,225,.82)}
  .track .big{font-family:"Fraunces",serif; font-size:2.6rem; font-weight:500; color:var(--forest); margin-top:auto; padding-top:24px}
  .track.lead .big{color:var(--paper)}
  .track .big small{display:block; font-family:"Hanken Grotesk"; font-size:.8rem; font-weight:500; letter-spacing:.12em; text-transform:uppercase; color:var(--olive)}
  .track.lead .big small{color:var(--moss)}

  /* numbers strip */
  .nums{display:grid; grid-template-columns:repeat(4,1fr); gap:30px}
  @media(max-width:760px){.nums{grid-template-columns:repeat(2,1fr); gap:30px 20px}}
  .num b{font-family:"Fraunces",serif; font-size:clamp(2.2rem,4vw,3.2rem); font-weight:500; color:var(--paper); display:block; line-height:1}
  .num span{font-size:.84rem; color:rgba(243,238,225,.7); display:block; margin-top:10px; letter-spacing:.04em}

  /* experiences */
  .gallery{display:grid; grid-template-columns:repeat(2,1fr); gap:24px; margin-top:46px}
  @media(max-width:760px){.gallery{grid-template-columns:1fr}}
  .gcard{background:var(--paper-2); border:1px solid var(--line); border-radius:18px; overflow:hidden; transition:transform .3s ease, box-shadow .3s ease}
  .gcard:hover{transform:translateY(-5px); box-shadow:var(--shadow)}
  .gcard .ph{position:relative; aspect-ratio:4/3; overflow:hidden}
  .gcard .ph img{width:100%; height:100%; object-fit:cover; display:block}
  .gcard .tag{position:absolute; left:16px; top:16px; background:rgba(36,48,24,.82); color:var(--paper); font-size:.66rem; letter-spacing:.18em; text-transform:uppercase; font-weight:600; padding:6px 12px; border-radius:999px}
  .gcard .body{padding:22px 24px 26px}
  .gcard h3{font-size:1.35rem; color:var(--forest); font-weight:500; margin-bottom:6px}
  .gcard p{font-size:.92rem; color:var(--ink-soft)}
  .imgnote{font-size:.78rem; color:var(--ink-soft); opacity:.85; margin-top:20px; font-style:italic}

  /* ask / contact */
  .ask{background:var(--forest); color:var(--paper); border-radius:24px; padding:clamp(40px,6vw,72px); text-align:center; position:relative; overflow:hidden}
  .ask .glow{position:absolute; width:50vw;height:50vw; left:-15vw; bottom:-25vw; border-radius:50%;
    background:radial-gradient(circle,rgba(185,118,62,.4),transparent 60%)}
  .ask .founders{position:relative; z-index:2; display:flex; flex-direction:column; align-items:center; gap:11px; margin-bottom:28px}
  .ask .founders img{width:86px; height:86px; border-radius:50%; object-fit:cover; border:2px solid rgba(243,238,225,.5)}
  .ask .founders span{font-family:"Fraunces",serif; font-style:italic; font-size:.9rem; color:rgba(243,238,225,.85)}
  .ask h2{font-size:clamp(2rem,5vw,3.6rem); font-weight:360; position:relative; z-index:2}
  .ask h2 b{font-weight:600; font-style:italic; color:var(--tan-soft)}
  .ask p{position:relative; z-index:2; max-width:48ch; margin:22px auto 0; color:rgba(243,238,225,.82)}
  .contacts{position:relative; z-index:2; display:flex; flex-wrap:wrap; gap:14px; justify-content:center; margin-top:38px}
  .contacts a{display:inline-flex; align-items:center; gap:9px; padding:13px 22px; border-radius:999px; text-decoration:none;
    border:1px solid rgba(243,238,225,.28); font-weight:500; font-size:.94rem; transition:background .25s,border-color .25s}
  .contacts a:hover{background:rgba(243,238,225,.1); border-color:rgba(243,238,225,.6)}
  .contacts a.solid{background:var(--paper); color:var(--forest); border-color:var(--paper)}
  .contacts a.solid:hover{background:var(--tan-soft); border-color:var(--tan-soft)}

  footer{padding:50px 0 70px; text-align:center}
  footer .disc{font-size:.78rem; color:var(--ink-soft); max-width:74ch; margin:0 auto; opacity:.85}
  footer .sig{font-family:"Fraunces",serif; font-style:italic; color:var(--olive); margin-top:18px}

  /* real-image bands, figures & credits */
  .band-img{position:relative; overflow:hidden; padding:0; margin:0}
  .band-img > img{display:block; width:100%; height:clamp(320px,58vh,640px); object-fit:cover}
  .band-img .cap{position:absolute; left:0; right:0; bottom:0; background:linear-gradient(to top,rgba(20,26,15,.82),rgba(20,26,15,0))}
  .band-img .capinner{max-width:var(--maxw); margin:0 auto; padding:54px 28px 28px; color:var(--paper); display:flex; justify-content:space-between; align-items:flex-end; gap:24px; flex-wrap:wrap}
  .band-img .capmain b{font-family:"Fraunces",serif; font-style:italic; font-weight:500; font-size:clamp(1.3rem,2.8vw,2.1rem); display:block; margin-bottom:6px; color:var(--paper)}
  .band-img .capmain span{font-size:.92rem; letter-spacing:.04em; opacity:.92}
  .band-img .capmeta{text-align:right; font-family:"Fraunces",serif; font-style:italic; color:rgba(243,238,225,.9); white-space:nowrap}
  .band-img .capmeta span{display:block; font-size:1rem; line-height:1.5}
  @media(max-width:600px){.band-img .capmeta{display:none}}
  .figure{border-radius:16px; overflow:hidden; box-shadow:var(--shadow); border:1px solid var(--line); background:var(--paper-2)}
  .figure img{display:block; width:100%; height:100%; object-fit:cover}
  .zfigs{display:grid; grid-template-columns:1.7fr 1fr; gap:20px; align-items:stretch}
  .zfigs .figure{height:clamp(300px,32vw,430px)}
  .zfigs .figure img{width:100%; height:100%; object-fit:cover}
  .zfigs .figure.plan{background:#fbfaf6}
  .zfigs .figure.plan img{object-fit:contain; padding:8px}
  @media(max-width:760px){.zfigs{grid-template-columns:1fr} .zfigs .figure{height:clamp(240px,64vw,340px)}}
  .gcard .ph .credit{position:absolute; right:12px; bottom:12px; background:rgba(20,26,15,.72); color:var(--paper); font-size:.6rem; letter-spacing:.05em; padding:4px 9px; border-radius:999px}
  .credits{font-size:.74rem; color:var(--ink-soft); opacity:.82; max-width:82ch; margin:16px auto 0; line-height:1.55}

  /* reveal animation */
  .rv{opacity:0; transform:translateY(26px); transition:opacity .8s cubic-bezier(.2,.7,.2,1), transform .8s cubic-bezier(.2,.7,.2,1)}
  .rv.in{opacity:1; transform:none}
  .hero .eyebrow,.hero h1,.hero .lede,.hero-meta{opacity:0; transform:translateY(24px); animation:rise .95s cubic-bezier(.2,.7,.2,1) forwards}
  .hero h1{animation-delay:.12s}.hero .lede{animation-delay:.3s}.hero-meta{animation-delay:.46s}
  @keyframes rise{to{opacity:1;transform:none}}
  @media(prefers-reduced-motion:reduce){.rv,.hero .eyebrow,.hero h1,.hero .lede,.hero-meta{opacity:1;transform:none;animation:none;transition:none}}
