
  :root{
    --cream:#f4efe5;
    --cream-2:#ece5d7;
    --ink:#1a1814;
    --ink-soft:#2a2722;
    --slate:#23211c;
    --rust:#c05a32;
    --rust-deep:#9c4523;
    --rust-glow:rgba(192,90,50,.16);
    --line:rgba(26,24,20,.12);
    --muted:#6b655b;
    --gold:#c89b54;
    --shadow:0 24px 60px -20px rgba(26,24,20,.35);
    --r:18px;
  }
  *{margin:0;padding:0;box-sizing:border-box}
  html{scroll-behavior:smooth}
  body{
    font-family:"Hanken Grotesk",sans-serif;
    background:var(--cream);
    color:var(--ink);
    line-height:1.6;
    overflow-x:hidden;
    -webkit-font-smoothing:antialiased;
  }
  /* grain overlay */
  body::after{
    content:"";position:fixed;inset:0;pointer-events:none;z-index:9999;opacity:.04;
    background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='200' height='200'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.8' numOctaves='3'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
  }
  h1,h2,h3,h4{font-family:"Bricolage Grotesque",sans-serif;font-weight:700;line-height:1.04;letter-spacing:-.02em}
  a{color:inherit;text-decoration:none}
  img{display:block;max-width:100%}
  .wrap{max-width:1240px;margin:0 auto;padding:0 28px}
  .eyebrow{
    display:inline-flex;align-items:center;gap:10px;font-size:.78rem;font-weight:600;
    text-transform:uppercase;letter-spacing:.18em;color:var(--rust-deep);
  }
  .eyebrow::before{content:"";width:26px;height:2px;background:var(--rust)}
  .btn{
    display:inline-flex;align-items:center;gap:10px;font-weight:600;font-size:.95rem;
    padding:15px 28px;border-radius:50px;transition:.3s cubic-bezier(.2,.7,.2,1);
    cursor:pointer;border:none;font-family:inherit;
  }
  .btn-primary{background:var(--rust);color:#fff;box-shadow:0 14px 30px -10px var(--rust)}
  .btn-primary:hover{background:var(--rust-deep);transform:translateY(-3px)}
  .btn-ghost{background:transparent;color:var(--cream);border:1.5px solid rgba(244,239,229,.35)}
  .btn-ghost:hover{background:rgba(244,239,229,.1);border-color:var(--cream)}
  .btn-dark{background:var(--ink);color:var(--cream)}
  .btn-dark:hover{background:var(--ink-soft);transform:translateY(-3px)}

  /* ---------- TOP BAR ---------- */
  .topbar{background:var(--ink);color:var(--cream-2);font-size:.84rem}
  .topbar .wrap{display:flex;justify-content:space-between;align-items:center;height:40px}
  .topbar .left{display:flex;gap:24px;flex-wrap:wrap}
  .topbar a{display:inline-flex;align-items:center;gap:7px;opacity:.85;transition:.2s}
  .topbar a:hover{opacity:1;color:var(--rust)}
  .topbar .right{opacity:.7;letter-spacing:.04em}

  /* ---------- HEADER ---------- */
  header{position:sticky;top:0;z-index:100;background:rgba(244,239,229,.82);backdrop-filter:blur(14px);border-bottom:1px solid transparent;transition:.3s}
  header.scrolled{border-bottom:1px solid var(--line);box-shadow:0 8px 30px -18px rgba(26,24,20,.3)}
  header .wrap{display:flex;align-items:center;justify-content:space-between;height:78px}
  .logo{font-family:"Bricolage Grotesque";font-weight:800;font-size:1.5rem;letter-spacing:-.04em;display:flex;align-items:center;gap:10px}
  .logo .mark{
    width:34px;height:34px;background:var(--rust);border-radius:8px;position:relative;flex:none;
    box-shadow:0 8px 18px -6px var(--rust)
  }
  .logo .mark::before{content:"";position:absolute;inset:8px 8px auto 8px;height:7px;background:var(--cream);clip-path:polygon(0 100%,50% 0,100% 100%)}
  .logo .mark::after{content:"";position:absolute;inset:auto 8px 9px 8px;height:8px;background:rgba(244,239,229,.45)}
  .logo b{color:var(--rust)}
  nav.main{display:flex;gap:6px}
  nav.main a{padding:10px 16px;border-radius:40px;font-weight:500;font-size:.95rem;color:var(--ink-soft);transition:.2s;position:relative}
  nav.main a:hover{color:var(--rust-deep);background:rgba(192,90,50,.08)}
  .header-cta{display:flex;align-items:center;gap:18px}
  .header-cta .phone{font-family:"Bricolage Grotesque";font-weight:700;color:var(--ink)}
  .header-cta .phone span{display:block;font-family:"Hanken Grotesk";font-size:.7rem;font-weight:500;color:var(--muted);letter-spacing:.06em}
  .burger{display:none;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer;padding:8px}
  .burger span{width:26px;height:2px;background:var(--ink);transition:.3s}

  /* ---------- MOBILE MENU ---------- */
  .mobile-menu{position:fixed;inset:0;background:var(--ink);z-index:200;transform:translateX(100%);transition:.45s cubic-bezier(.7,0,.2,1);display:flex;flex-direction:column;padding:30px 28px;color:var(--cream)}
  .mobile-menu.open{transform:translateX(0)}
  .mobile-menu .mtop{display:flex;justify-content:space-between;align-items:center;margin-bottom:50px}
  .mobile-menu .close{background:none;border:none;color:var(--cream);font-size:2rem;cursor:pointer;line-height:1}
  .mobile-menu a.mlink{font-family:"Bricolage Grotesque";font-size:2rem;font-weight:700;padding:14px 0;border-bottom:1px solid rgba(244,239,229,.12)}
  .mobile-menu a.mlink:hover{color:var(--rust)}
  .mobile-menu .mfoot{margin-top:auto;display:flex;flex-direction:column;gap:14px;font-size:1rem;opacity:.8}

  /* ---------- HERO ---------- */
  .hero{position:relative;color:var(--cream);overflow:hidden;background:var(--ink)}
  .hero-bg{position:absolute;inset:0;z-index:0}
  .hero-bg img{width:100%;height:100%;object-fit:cover;opacity:.92;transform:scale(1.04)}
  .hero-bg::after{content:"";position:absolute;inset:0;background:linear-gradient(100deg,rgba(20,17,14,.96) 10%,rgba(20,17,14,.74) 42%,rgba(20,17,14,.34) 74%,rgba(20,17,14,.6) 100%),linear-gradient(to bottom,transparent 60%,rgba(20,17,14,.5) 100%)}
  .hero .wrap{position:relative;z-index:2;padding:90px 28px 110px;display:grid;grid-template-columns:1.15fr .85fr;gap:50px;align-items:center}
  .hero-copy{max-width:640px}
  .hero h1{font-size:clamp(2.6rem,5.6vw,4.6rem);margin:22px 0 22px;font-weight:800}
  .hero h1 em{font-style:normal;color:var(--rust);position:relative}
  .hero p.lead{font-size:1.18rem;color:rgba(244,239,229,.82);max-width:540px;margin-bottom:34px}
  .hero-actions{display:flex;gap:16px;flex-wrap:wrap;align-items:center}
  .hero .eyebrow{color:var(--gold)}
  .hero .eyebrow::before{background:var(--gold)}
  /* hero side card */
  .hero-card{background:rgba(244,239,229,.07);backdrop-filter:blur(10px);border:1px solid rgba(244,239,229,.15);border-radius:24px;padding:32px;justify-self:end;width:100%;max-width:340px}
  .hero-card h3{font-size:1.35rem;margin-bottom:8px}
  .hero-card p{font-size:.92rem;color:rgba(244,239,229,.7);margin-bottom:22px}
  .hero-card .row{display:flex;align-items:center;gap:14px;padding:14px 0;border-top:1px solid rgba(244,239,229,.12)}
  .hero-card .ico{width:40px;height:40px;border-radius:10px;background:var(--rust-glow);display:grid;place-items:center;flex:none;color:var(--rust)}
  .hero-card .row b{display:block;font-family:"Bricolage Grotesque";font-size:1.05rem}
  .hero-card .row small{color:rgba(244,239,229,.6);font-size:.8rem}
  .hero-card .btn{width:100%;justify-content:center;margin-top:18px}

  /* tile divider */
  .tiles-divider{height:26px;background:var(--rust);position:relative;z-index:3}
  .tiles-divider::before{content:"";position:absolute;inset:0;background-image:repeating-linear-gradient(90deg,transparent 0,transparent 26px,rgba(0,0,0,.12) 26px,rgba(0,0,0,.12) 28px);background-size:28px 100%}
  /* ---------- PARTNERS ---------- */
  .partners{background:#141210;padding:34px 0 40px}
  .partners .ptitle{display:block;text-align:center;font-size:.76rem;letter-spacing:.2em;text-transform:uppercase;color:rgba(244,239,229,.5);font-weight:600;margin-bottom:26px}
  .plogos{display:flex;align-items:center;justify-content:center;gap:clamp(28px,7vw,80px);flex-wrap:wrap}
  .plogos img{height:36px;width:auto;mix-blend-mode:screen;opacity:.9;transition:.3s cubic-bezier(.2,.7,.2,1)}
  .plogos img.wb{height:30px}
  .plogos img:hover{opacity:1;transform:scale(1.07)}
  @media(max-width:640px){.plogos img{height:27px}.plogos img.wb{height:23px}.plogos{gap:30px 26px}}

  /* ---------- STATS ---------- */
  .stats{background:var(--ink-soft);color:var(--cream)}
  .stats .wrap{display:grid;grid-template-columns:repeat(4,1fr);gap:30px;padding:54px 28px}
  .stat{text-align:center;position:relative}
  .stat:not(:last-child)::after{content:"";position:absolute;right:-15px;top:10%;height:80%;width:1px;background:rgba(244,239,229,.14)}
  .stat .num{font-family:"Bricolage Grotesque";font-size:clamp(2.4rem,4vw,3.2rem);font-weight:800;color:var(--rust);line-height:1}
  .stat .lab{font-size:.92rem;color:rgba(244,239,229,.72);margin-top:8px;letter-spacing:.02em}

  /* ---------- SECTION BASICS ---------- */
  section.pad{padding:100px 0}
  .sec-head{max-width:680px;margin-bottom:54px}
  .sec-head h2{font-size:clamp(2rem,4vw,3rem);margin:16px 0}
  .sec-head p{color:var(--muted);font-size:1.08rem}

  /* ---------- ABOUT ---------- */
  .about{display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:center}
  .about-media{position:relative}
  .about-media .main{border-radius:var(--r);overflow:hidden;box-shadow:var(--shadow);aspect-ratio:4/5}
  .about-media .main img{width:100%;height:100%;object-fit:cover}
  .about-media .float{position:absolute;bottom:-26px;left:-26px;background:var(--ink);color:var(--cream);padding:24px 28px;border-radius:16px;box-shadow:var(--shadow);max-width:230px}
  .about-media .float .big{font-family:"Bricolage Grotesque";font-size:2.4rem;font-weight:800;color:var(--rust);line-height:1}
  .about-media .float small{font-size:.85rem;color:rgba(244,239,229,.75)}
  .about-text h2{font-size:clamp(1.9rem,3.6vw,2.7rem);margin:16px 0 20px}
  .about-text p{color:var(--muted);margin-bottom:18px}
  .about-text .chips{display:flex;gap:12px;flex-wrap:wrap;margin:26px 0 30px}
  .chip{display:inline-flex;align-items:center;gap:8px;background:var(--cream-2);border:1px solid var(--line);padding:9px 16px;border-radius:40px;font-size:.88rem;font-weight:600}
  .chip svg{color:var(--rust)}

  /* ---------- SERVICES ---------- */
  .services{background:var(--slate);color:var(--cream)}
  .services .sec-head p{color:rgba(244,239,229,.65)}
  .serv-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px}
  .serv{background:rgba(244,239,229,.04);border:1px solid rgba(244,239,229,.1);border-radius:var(--r);padding:30px 26px;transition:.35s cubic-bezier(.2,.7,.2,1);position:relative;overflow:hidden}
  .serv::before{content:"";position:absolute;left:0;top:0;height:3px;width:0;background:var(--rust);transition:.4s}
  .serv:hover{background:rgba(244,239,229,.07);transform:translateY(-6px)}
  .serv:hover::before{width:100%}
  .serv .ico{width:52px;height:52px;border-radius:13px;background:var(--rust-glow);color:var(--rust);display:grid;place-items:center;margin-bottom:20px}
  .serv h3{font-size:1.18rem;margin-bottom:10px}
  .serv p{font-size:.92rem;color:rgba(244,239,229,.62)}

  /* ---------- MATERIALS ---------- */
  .mats .sec-head{display:flex;justify-content:space-between;align-items:flex-end;max-width:100%;gap:30px;flex-wrap:wrap}
  .mats .sec-head .t{max-width:620px}
  .mat-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:22px}
  .mat{border-radius:var(--r);overflow:hidden;position:relative;aspect-ratio:3/4;box-shadow:var(--shadow);cursor:pointer}
  .mat img{width:100%;height:100%;object-fit:cover;transition:.6s}
  .mat:hover img{transform:scale(1.08)}
  .mat::after{content:"";position:absolute;inset:0;background:linear-gradient(to top,rgba(26,24,20,.88) 0,rgba(26,24,20,.1) 55%,transparent 100%)}
  .mat .cap{position:absolute;left:22px;right:22px;bottom:20px;z-index:2;color:var(--cream)}
  .mat .cap span{font-size:.72rem;letter-spacing:.16em;text-transform:uppercase;color:var(--gold);font-weight:600}
  .mat .cap h3{font-size:1.3rem;margin-top:4px}

  /* ---------- PROCESS ---------- */
  .process{background:var(--cream-2)}
  .timeline{position:relative;max-width:1000px;margin:0 auto;padding:6px 0}
  .timeline::before{content:"";position:absolute;left:50%;top:10px;bottom:10px;width:2px;transform:translateX(-50%);background:linear-gradient(180deg,rgba(192,90,50,.18),var(--rust) 9%,var(--rust) 88%,rgba(192,90,50,.12))}
  .tl-row{position:relative;margin-bottom:18px}
  .tl-card{width:calc(50% - 58px);background:var(--cream);border:1px solid var(--line);border-radius:16px;padding:24px 28px;transition:.35s cubic-bezier(.2,.7,.2,1)}
  .tl-row:nth-child(odd) .tl-card{margin-right:auto}
  .tl-row:nth-child(even) .tl-card{margin-left:auto}
  .tl-card:hover{transform:translateY(-5px);box-shadow:var(--shadow);border-color:rgba(192,90,50,.4)}
  .tl-node{position:absolute;left:50%;top:6px;transform:translateX(-50%);width:54px;height:54px;border-radius:50%;background:var(--rust);color:#fff;display:grid;place-items:center;font-family:"Bricolage Grotesque";font-weight:800;font-size:1.3rem;box-shadow:0 12px 26px -9px var(--rust);border:4px solid var(--cream-2);z-index:2}
  .tl-ico{width:44px;height:44px;border-radius:11px;background:var(--rust-glow);color:var(--rust-deep);display:grid;place-items:center;margin-bottom:14px}
  .tl-step{font-size:.72rem;letter-spacing:.18em;text-transform:uppercase;color:var(--rust-deep);font-weight:700}
  .tl-card h3{font-size:1.2rem;margin:5px 0 8px}
  .tl-card p{font-size:.92rem;color:var(--muted)}
  @media(max-width:780px){
    .timeline{padding-left:4px}
    .timeline::before{left:25px}
    .tl-card,.tl-row:nth-child(odd) .tl-card,.tl-row:nth-child(even) .tl-card{width:auto;margin:0 0 0 64px}
    .tl-node{left:25px;width:48px;height:48px;font-size:1.15rem}
  }

  /* ---------- PORTFOLIO ---------- */
  .folio-grid{display:grid;grid-template-columns:repeat(4,1fr);grid-auto-rows:200px;gap:14px}
  .folio-grid figure{border-radius:14px;overflow:hidden;position:relative}
  .folio-grid figure img{width:100%;height:100%;object-fit:cover;transition:.6s}
  .folio-grid figure:hover img{transform:scale(1.1)}
  .folio-grid figure::after{content:"";position:absolute;inset:0;background:var(--rust-glow);opacity:0;transition:.3s;mix-blend-mode:multiply}
  .folio-grid figure:hover::after{opacity:1}
  .folio-grid .tall{grid-row:span 2}
  .folio-grid .wide{grid-column:span 2}

  /* ---------- BENEFITS ---------- */
  .benefits{background:var(--ink);color:var(--cream);position:relative;overflow:hidden}
  .benefits::before{content:"";position:absolute;top:-120px;right:-120px;width:420px;height:420px;background:radial-gradient(circle,var(--rust-glow),transparent 70%)}
  .ben-wrap{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center;position:relative;z-index:2}
  .benefits h2{font-size:clamp(1.9rem,3.6vw,2.8rem);margin:16px 0 18px}
  .benefits .eyebrow{color:var(--gold)}.benefits .eyebrow::before{background:var(--gold)}
  .benefits .intro{color:rgba(244,239,229,.7);margin-bottom:30px;max-width:480px}
  .ben-list{list-style:none;display:grid;gap:14px}
  .ben-list li{display:flex;align-items:flex-start;gap:14px;background:rgba(244,239,229,.05);border:1px solid rgba(244,239,229,.1);padding:18px 22px;border-radius:14px}
  .ben-list .tick{width:30px;height:30px;flex:none;border-radius:8px;background:var(--rust);display:grid;place-items:center;color:#fff}
  .ben-list b{font-family:"Bricolage Grotesque";font-size:1.05rem;display:block}
  .ben-list small{color:rgba(244,239,229,.6);font-size:.86rem}

  /* ---------- CTA BAND ---------- */
  .cta-band{background:var(--rust);color:#fff;position:relative;overflow:hidden}
  .cta-band::before{content:"";position:absolute;inset:0;background-image:repeating-linear-gradient(135deg,rgba(255,255,255,.06) 0,rgba(255,255,255,.06) 2px,transparent 2px,transparent 22px)}
  .cta-band .wrap{position:relative;z-index:2;padding:72px 28px;display:flex;justify-content:space-between;align-items:center;gap:30px;flex-wrap:wrap}
  .cta-band h2{font-size:clamp(1.8rem,3.6vw,2.6rem);max-width:640px}
  .cta-band p{opacity:.9;margin-top:8px}
  .cta-band .acts{display:flex;gap:14px;flex-wrap:wrap}
  .cta-band .btn-light{background:#fff;color:var(--rust-deep)}
  .cta-band .btn-light:hover{transform:translateY(-3px);background:var(--cream)}
  .cta-band .btn-outline{background:transparent;color:#fff;border:1.5px solid rgba(255,255,255,.6)}
  .cta-band .btn-outline:hover{background:rgba(255,255,255,.12)}

  /* ---------- FOOTER ---------- */
  footer{background:var(--ink);color:var(--cream-2);padding:72px 0 0}
  .foot-grid{display:grid;grid-template-columns:1.6fr 1fr 1fr 1.2fr;gap:44px;padding-bottom:50px}
  footer .logo{color:var(--cream);margin-bottom:18px}
  footer .about-f{color:rgba(244,239,229,.6);font-size:.95rem;max-width:320px}
  footer h4{font-family:"Bricolage Grotesque";font-size:1.05rem;color:var(--cream);margin-bottom:20px}
  footer ul{list-style:none;display:grid;gap:12px}
  footer ul a,footer .ci{color:rgba(244,239,229,.62);font-size:.94rem;transition:.2s;display:flex;align-items:center;gap:10px}
  footer ul a:hover{color:var(--rust)}
  footer .ci svg{color:var(--rust);flex:none}
  .foot-bottom{border-top:1px solid rgba(244,239,229,.12);padding:24px 0;text-align:center;font-size:.85rem;color:rgba(244,239,229,.45)}
  .socials{display:flex;gap:10px;margin-top:18px}
  .socials a{width:38px;height:38px;border-radius:10px;background:rgba(244,239,229,.08);display:grid;place-items:center;transition:.25s}
  .socials a:hover{background:var(--rust);transform:translateY(-3px)}

  /* ---------- REVEAL ANIM ---------- */
  .reveal{opacity:0;transform:translateY(26px);transition:.8s cubic-bezier(.2,.7,.2,1)}
  .reveal.in{opacity:1;transform:none}
  .hero-copy>*{opacity:0;animation:rise .8s cubic-bezier(.2,.7,.2,1) forwards}
  .hero-copy>*:nth-child(1){animation-delay:.1s}
  .hero-copy>*:nth-child(2){animation-delay:.22s}
  .hero-copy>*:nth-child(3){animation-delay:.34s}
  .hero-copy>*:nth-child(4){animation-delay:.46s}
  .hero-card{opacity:0;animation:rise .8s cubic-bezier(.2,.7,.2,1) .55s forwards}
  @keyframes rise{to{opacity:1;transform:none}}

  /* ---------- RESPONSIVE ---------- */
  @media(max-width:1080px){
    nav.main,.header-cta .phone{display:none}
    .burger{display:flex}
    .header-cta .btn{display:none}
    .hero .wrap{grid-template-columns:1fr}
    .hero-card{justify-self:start;max-width:420px}
    .serv-grid,.mat-grid,.folio-grid{grid-template-columns:repeat(2,1fr)}
    .proc-grid{grid-template-columns:repeat(2,1fr)}
    .about,.ben-wrap{grid-template-columns:1fr;gap:40px}
    .foot-grid{grid-template-columns:1fr 1fr}
  }
  @media(max-width:640px){
    .wrap{padding:0 20px}
    section.pad{padding:70px 0}
    .stats .wrap{grid-template-columns:1fr 1fr;gap:30px 20px}
    .stat:nth-child(2)::after{display:none}
    .serv-grid,.mat-grid,.proc-grid,.folio-grid{grid-template-columns:1fr}
    .folio-grid{grid-auto-rows:220px}
    .folio-grid .wide{grid-column:span 1}
    .topbar .right{display:none}
    .about-media .float{position:static;margin-top:18px;max-width:100%}
    .foot-grid{grid-template-columns:1fr}
  }

  /* ===== MULTIPAGE ADDITIONS ===== */
  section[id]{scroll-margin-top:92px}
  nav.main a.nav-active{color:var(--rust-deep);background:rgba(192,90,50,.1)}
  /* sub-page hero */
  .subhero{background:var(--ink);color:var(--cream);position:relative;overflow:hidden;padding:66px 0 60px;text-align:center}
  .subhero::before{content:"";position:absolute;inset:0;background:linear-gradient(120deg,var(--ink) 30%,rgba(192,90,50,.16))}
  .subhero::after{content:"";position:absolute;top:-120px;right:-100px;width:380px;height:380px;background:radial-gradient(circle,var(--rust-glow),transparent 70%)}
  .subhero .wrap{position:relative;z-index:2}
  .subhero .crumb{font-size:.82rem;letter-spacing:.05em;color:var(--gold)}
  .subhero .crumb a{color:rgba(244,239,229,.6)}
  .subhero h1{font-size:clamp(2.2rem,5vw,3.4rem);margin:14px 0 12px}
  .subhero p{color:rgba(244,239,229,.72);max-width:620px;margin:0 auto;font-size:1.05rem}
  /* feature blocks */
  .feature{display:grid;grid-template-columns:1fr 1fr;gap:54px;align-items:center}
  .feature+.feature{margin-top:84px}
  .feature .fimg{border-radius:var(--r);overflow:hidden;box-shadow:var(--shadow)}
  .feature .fimg img{width:100%;aspect-ratio:4/3;object-fit:cover;display:block;transition:.6s cubic-bezier(.2,.7,.2,1)}
  .feature .fimg:hover img{transform:scale(1.05)}
  .feature h2{font-size:clamp(1.7rem,3.2vw,2.4rem);margin:14px 0 14px}
  .feature p{color:var(--muted);margin-bottom:12px}
  .flist{list-style:none;display:grid;gap:11px;margin:18px 0 28px}
  .flist li{display:flex;gap:11px;align-items:flex-start;font-size:.97rem}
  .flist svg{color:var(--rust);flex:none;margin-top:3px}
  .feature.rev .fimg{order:2}
  @media(max-width:860px){.feature{grid-template-columns:1fr;gap:28px}.feature.rev .fimg{order:0}}
  /* contact */
  .contact-grid{display:grid;grid-template-columns:.9fr 1.1fr;gap:48px;align-items:start}
  .cinfo{display:grid;gap:15px}
  .cinfo .card{display:flex;gap:16px;align-items:flex-start;background:var(--cream-2);border:1px solid var(--line);border-radius:14px;padding:20px 22px;transition:.3s}
  .cinfo .card:hover{transform:translateY(-3px);box-shadow:var(--shadow)}
  .cinfo .card .ic{width:46px;height:46px;border-radius:11px;background:var(--rust-glow);color:var(--rust-deep);display:grid;place-items:center;flex:none}
  .cinfo .card b{display:block;font-family:"Bricolage Grotesque";font-size:1.06rem;margin-bottom:2px}
  .cinfo .card a,.cinfo .card span{color:var(--muted);font-size:.95rem;word-break:break-word}
  .cinfo .card a:hover{color:var(--rust-deep)}
  .cform{background:var(--cream-2);border:1px solid var(--line);border-radius:var(--r);padding:30px}
  .cform .frow{display:grid;grid-template-columns:1fr 1fr;gap:16px}
  .cform label{display:block;font-size:.82rem;font-weight:600;margin:14px 0 6px;color:var(--ink-soft)}
  .cform input,.cform select,.cform textarea{width:100%;padding:13px 15px;border:1px solid var(--line);border-radius:10px;background:var(--cream);font-family:inherit;font-size:.95rem;color:var(--ink)}
  .cform textarea{min-height:130px;resize:vertical}
  .cform input:focus,.cform select:focus,.cform textarea:focus{outline:none;border-color:var(--rust);box-shadow:0 0 0 3px var(--rust-glow)}
  .cform .actions{display:flex;gap:12px;flex-wrap:wrap;margin-top:24px}
  .cform .hint{font-size:.82rem;color:var(--muted);margin-top:14px}
  .btn-wa{background:#25D366;color:#fff}.btn-wa:hover{background:#1da851;transform:translateY(-3px)}
  @media(max-width:860px){.contact-grid{grid-template-columns:1fr;gap:30px}.cform .frow{grid-template-columns:1fr}}
  /* floating buttons */
  .floats{position:fixed;right:18px;bottom:18px;z-index:400;display:flex;flex-direction:column;gap:12px}
  .float-btn{position:relative;width:58px;height:58px;border-radius:50%;display:grid;place-items:center;color:#fff;box-shadow:0 14px 30px -8px rgba(0,0,0,.45);transition:.3s cubic-bezier(.2,.7,.2,1)}
  .float-btn svg{width:28px;height:28px}
  .float-btn.wa{background:#25D366}
  .float-btn.tel{background:var(--rust)}
  .float-btn:hover{transform:scale(1.09) translateY(-2px)}
  .float-btn.wa::before{content:"";position:absolute;inset:0;border-radius:50%;background:#25D366;opacity:.45;z-index:-1;animation:fpulse 2.6s ease-out infinite}
  @keyframes fpulse{0%{transform:scale(1);opacity:.45}70%{transform:scale(1.75);opacity:0}100%{opacity:0}}
  @media(max-width:640px){.floats{right:14px;bottom:14px;gap:10px}.float-btn{width:52px;height:52px}.float-btn svg{width:25px;height:25px}}
