*{box-sizing:border-box;margin:0;padding:0}
:root{
  --bg:#0f1a12;--bg2:#142118;--bg3:#1a2d1f;
  --sage:#6b8f71;--sage2:#8bb58f;--sage3:#4d7052;
  --terra:#c17f59;--terra2:#d4976f;--terra3:#a8694a;
  --sand:#d4c5a9;--cream:#ede8dd;--warm:#c9b896;
  --text:#8a9b8c;--muted:#5b6d5e;--white:#f5f2ec;
  --heading:'Playfair Display',Georgia,serif;
  --elegant:'Lora',Georgia,serif;
  --body:'Nunito Sans',sans-serif;
}
html{scroll-behavior:smooth}
body{font-family:var(--body);background:var(--bg);color:var(--text);line-height:1.7;overflow-x:hidden}

body::after{content:'';position:fixed;inset:0;z-index:9999;pointer-events:none;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.035'/%3E%3C/svg%3E");opacity:.4}

.reveal{opacity:0;transform:translateY(25px);transition:opacity .9s ease,transform .9s ease}
.reveal.vis{opacity:1;transform:translateY(0)}

.demo{background:var(--terra);color:var(--white);text-align:center;padding:.4rem;font-size:.75rem;font-weight:600;letter-spacing:.04em;position:relative;z-index:10000}
.demo a{color:var(--white);text-decoration:underline}

/* Marquee */
.marquee{position:fixed;top:28px;left:0;right:0;z-index:999;background:var(--bg2);border-bottom:1px solid rgba(107,143,113,.08);overflow:hidden;height:32px;display:flex;align-items:center}
.marquee-track{display:flex;gap:2.5rem;white-space:nowrap;animation:scroll 42s linear infinite;font-family:var(--body);font-size:.7rem;letter-spacing:.25em;color:var(--sage2);text-transform:uppercase;font-weight:500}
.marquee-track .accent{color:var(--terra2);font-style:italic}
@keyframes scroll{from{transform:translateX(0)}to{transform:translateX(-50%)}}

nav{position:fixed;top:60px;left:0;right:0;z-index:1000;padding:0 3rem;height:60px;display:flex;align-items:center;justify-content:space-between;background:rgba(15,26,18,.9);backdrop-filter:blur(16px);border-bottom:1px solid rgba(107,143,113,.08)}
.nav-logo{font-family:var(--heading);font-size:1.35rem;color:var(--cream);letter-spacing:.04em;text-decoration:none;font-weight:400;font-style:italic}
.nav-logo span{color:var(--sage2);font-style:normal;font-weight:700}
.nav-mid{display:flex;gap:2.5rem;list-style:none}
.nav-mid a{color:var(--muted);text-decoration:none;font-size:.72rem;font-weight:500;letter-spacing:.12em;text-transform:uppercase;transition:color .3s;position:relative}
.nav-mid a::after{content:'';position:absolute;bottom:-4px;left:50%;width:0;height:1px;background:var(--terra2);transition:width .3s,left .3s}
.nav-mid a:hover{color:var(--sage2)}
.nav-mid a:hover::after{width:100%;left:0}
.nav-cta{background:transparent;border:1px solid var(--sage3);color:var(--sage2);padding:.45rem 1.5rem;font-family:var(--heading);font-size:.85rem;letter-spacing:.04em;text-decoration:none;transition:all .3s;font-style:italic}
.nav-cta:hover{background:var(--sage3);color:var(--white)}

/* HERO */
.hero{min-height:100vh;display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden;padding:9rem 2rem 6rem}
.hero-bg{position:absolute;inset:0;background:radial-gradient(ellipse at 25% 40%,rgba(107,143,113,.1),transparent 50%),radial-gradient(ellipse at 75% 60%,rgba(193,127,89,.06),transparent 40%),linear-gradient(180deg,var(--bg) 0%,var(--bg2) 100%)}
.hero-botanical{position:absolute;inset:0;pointer-events:none;overflow:hidden}
.hero-botanical svg{position:absolute;color:var(--sage3);opacity:.05}
.hero-botanical .leaf1{top:10%;left:5%;width:200px;transform:rotate(-15deg);animation:sway 8s ease-in-out infinite}
.hero-botanical .leaf2{bottom:15%;right:8%;width:180px;transform:rotate(25deg) scaleX(-1);animation:sway 9s ease-in-out infinite reverse}
.hero-botanical .leaf3{top:30%;right:15%;width:120px;transform:rotate(-40deg);animation:sway 7s ease-in-out infinite}
.hero-botanical .leaf4{top:60%;left:18%;width:140px;transform:rotate(50deg);animation:sway 10s ease-in-out infinite reverse}
@keyframes sway{0%,100%{transform:rotate(-15deg) translateY(0)}50%{transform:rotate(-12deg) translateY(-10px)}}
.hero-content{position:relative;z-index:3;text-align:center;max-width:850px}
.hero-flourish{width:80px;height:1px;background:linear-gradient(90deg,transparent,var(--sage3),transparent);margin:0 auto 2rem;opacity:.6}
.hero-tag{font-family:var(--body);font-size:.7rem;letter-spacing:.3em;text-transform:uppercase;color:var(--sage);margin-bottom:1.5rem}
.hero h1{font-family:var(--heading);font-size:clamp(3rem,7.5vw,5.5rem);color:var(--cream);line-height:1.05;font-weight:400;margin-bottom:.5rem}
.hero h1 em{color:var(--sage2);font-style:italic}
.hero h1 .script{font-family:var(--heading);font-style:italic;font-weight:400;font-size:clamp(1.3rem,3vw,2rem);display:block;color:var(--terra2);margin-top:.75rem;letter-spacing:.02em}
.hero-desc{font-family:var(--elegant);font-size:1.1rem;color:var(--text);max-width:560px;margin:1.5rem auto 2.5rem;line-height:2;font-weight:400;font-style:italic}
.hero-actions{display:flex;gap:1.5rem;justify-content:center;flex-wrap:wrap;align-items:center}
.hero-cta{display:inline-block;background:var(--sage3);color:var(--white);padding:1rem 3rem;font-family:var(--heading);font-size:1rem;letter-spacing:.06em;text-decoration:none;font-style:italic;border-radius:2px;transition:all .4s;position:relative;overflow:hidden}
.hero-cta::before{content:'';position:absolute;inset:0;background:var(--sage);transform:translateY(100%);transition:transform .35s}
.hero-cta:hover::before{transform:translateY(0)}
.hero-cta span{position:relative;z-index:1}
.hero-cta:hover{transform:translateY(-2px);box-shadow:0 12px 35px rgba(107,143,113,.25)}
.hero-tel{font-family:var(--heading);font-size:1.1rem;color:var(--terra2);font-style:italic;text-decoration:none;border-bottom:1px solid transparent;padding-bottom:.2rem;transition:border-color .3s}
.hero-tel:hover{border-color:var(--terra2)}

/* STATS */
.stats{padding:4rem 5vw;background:var(--bg2);border-top:1px solid rgba(107,143,113,.06);border-bottom:1px solid rgba(107,143,113,.06)}
.stats-inner{max-width:1100px;margin:0 auto;display:grid;grid-template-columns:repeat(4,1fr);gap:2rem;text-align:center}
.stat{position:relative}
.stat:not(:last-child)::after{content:'';position:absolute;right:-1rem;top:25%;height:50%;width:1px;background:rgba(107,143,113,.15)}
.stat-num{font-family:var(--heading);font-size:clamp(2rem,4vw,3.2rem);color:var(--sage2);font-style:italic;line-height:1;font-weight:400}
.stat-num .accent{color:var(--terra2)}
.stat-label{font-family:var(--body);font-size:.7rem;letter-spacing:.25em;text-transform:uppercase;color:var(--muted);margin-top:.6rem}

/* SECTION INTRO */
.sec-intro{text-align:center;margin-bottom:3.5rem}
.sec-intro .tag{font-size:.65rem;letter-spacing:.3em;text-transform:uppercase;color:var(--terra);margin-bottom:.75rem}
.sec-intro h2{font-family:var(--heading);font-size:clamp(2rem,4vw,3rem);color:var(--cream);font-weight:400}
.sec-intro h2 em{color:var(--sage2);font-style:italic}
.sec-intro .sub{font-family:var(--elegant);font-size:1rem;color:var(--text);font-style:italic;margin-top:.5rem}

/* SERVICES */
.services{padding:6rem 5vw;max-width:1100px;margin:0 auto}
.svc-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:2rem}
.svc-card{background:var(--bg2);padding:2.5rem;position:relative;overflow:hidden;transition:all .4s;border:1px solid rgba(107,143,113,.06);border-radius:3px}
.svc-card::before{content:'';position:absolute;top:0;left:0;width:3px;height:0;background:linear-gradient(180deg,var(--sage),var(--terra));transition:height .5s}
.svc-card:hover::before{height:100%}
.svc-card:hover{border-color:rgba(107,143,113,.2);background:var(--bg3);transform:translateY(-4px)}
.svc-icon{width:44px;height:44px;margin-bottom:1rem;transition:transform .4s}
.svc-card:hover .svc-icon{transform:rotate(-8deg) scale(1.1)}
.svc-icon svg{width:100%;height:100%;color:var(--sage)}
.svc-card:hover .svc-icon svg{color:var(--sage2)}
.svc-name{font-family:var(--heading);font-size:1.3rem;color:var(--cream);margin-bottom:.5rem;font-weight:400}
.svc-desc{font-size:.88rem;color:var(--muted);line-height:1.9;font-weight:300;margin-bottom:1rem}
.svc-link{font-family:var(--heading);font-size:.85rem;color:var(--terra2);font-style:italic;text-decoration:none;display:inline-flex;align-items:center;gap:.4rem;transition:gap .3s}
.svc-link:hover{gap:.7rem}

/* APPROACH */
.approach{padding:6rem 5vw;background:var(--bg2)}
.approach-inner{max-width:1100px;margin:0 auto;display:grid;grid-template-columns:1fr 1.2fr;gap:5rem;align-items:center}
.approach-visual{position:relative;aspect-ratio:3/4;background:var(--bg3);border-radius:4px;overflow:hidden;border:1px solid rgba(107,143,113,.06);transition:transform .5s}
.approach-visual:hover{transform:scale(1.02)}
.approach-visual::before{content:'';position:absolute;inset:0;background:radial-gradient(circle at 40% 60%,rgba(107,143,113,.1),transparent 60%),radial-gradient(circle at 60% 30%,rgba(193,127,89,.06),transparent 40%),linear-gradient(180deg,var(--bg3),var(--bg2))}
.approach-visual svg{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:55%;opacity:.08;color:var(--sage)}
.approach-visual .seasons{position:absolute;bottom:0;left:0;right:0;display:grid;grid-template-columns:repeat(4,1fr);gap:1px}
.approach-visual .season{padding:.8rem .5rem;text-align:center;background:rgba(15,26,18,.85);font-size:.6rem;letter-spacing:.15em;text-transform:uppercase;color:var(--muted);cursor:pointer;transition:all .3s}
.approach-visual .season:hover{color:var(--sage2);background:rgba(107,143,113,.1)}
.approach-visual .season.active{color:var(--sage2);background:rgba(107,143,113,.15)}
.approach-text .values{margin-top:2rem}
.approach-text .val{display:flex;gap:1rem;margin-bottom:1.5rem;align-items:flex-start;padding:1rem;border-left:1px solid transparent;transition:all .3s}
.approach-text .val:hover{border-left-color:var(--terra2);background:rgba(107,143,113,.04)}
.approach-text .val-num{font-family:var(--heading);font-size:2rem;color:var(--sage3);line-height:1;min-width:2.5rem;font-style:italic}
.approach-text .val h4{font-family:var(--heading);font-size:1rem;color:var(--cream);font-weight:400;margin-bottom:.25rem}
.approach-text .val p{font-size:.85rem;color:var(--muted);line-height:1.8;font-weight:300}

/* GALLERY */
.gallery{padding:6rem 5vw;max-width:1100px;margin:0 auto}
.gallery-grid{display:grid;grid-template-columns:1fr 1fr 1fr;grid-template-rows:280px 280px;gap:8px}
.gallery-item{position:relative;overflow:hidden;background:var(--bg2);border-radius:3px;transition:all .4s;cursor:pointer}
.gallery-item.tall{grid-row:span 2}
.gallery-item::before{content:'';position:absolute;inset:0;z-index:1;transition:transform .6s}
.gallery-item:hover::before{transform:scale(1.05)}
.g1::before{background:linear-gradient(160deg,rgba(107,143,113,.12),rgba(20,33,24,.85)),radial-gradient(circle at 30% 70%,rgba(107,143,113,.18),transparent 60%)}
.g2::before{background:linear-gradient(180deg,rgba(193,127,89,.1),rgba(20,33,24,.9)),radial-gradient(ellipse at 50% 40%,rgba(193,127,89,.12),transparent 50%)}
.g3::before{background:linear-gradient(135deg,rgba(20,33,24,.8),rgba(107,143,113,.1)),radial-gradient(circle at 60% 50%,rgba(107,143,113,.15),transparent 40%)}
.g4::before{background:linear-gradient(45deg,rgba(193,127,89,.08),rgba(20,33,24,.9)),radial-gradient(circle at 40% 60%,rgba(107,143,113,.1),transparent 50%)}
.g5::before{background:linear-gradient(180deg,rgba(107,143,113,.08),rgba(20,33,24,.95)),radial-gradient(circle at 50% 50%,rgba(193,127,89,.1),transparent 40%)}
.gallery-item svg{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:35%;opacity:.06;color:var(--sage);z-index:1;transition:opacity .4s}
.gallery-item:hover svg{opacity:.15}
.gallery-item .g-label{position:absolute;bottom:1rem;left:1.2rem;z-index:2;font-family:var(--heading);font-size:.85rem;color:var(--sage2);font-style:italic}
.gallery-item .g-meta{position:absolute;inset:0;z-index:3;background:linear-gradient(180deg,rgba(15,26,18,0) 50%,rgba(15,26,18,.95));opacity:0;transition:opacity .35s;display:flex;flex-direction:column;justify-content:flex-end;padding:1.5rem}
.gallery-item:hover .g-meta{opacity:1}
.g-meta h4{font-family:var(--heading);font-size:1.05rem;color:var(--cream);font-style:italic;margin-bottom:.25rem}
.g-meta p{font-family:var(--elegant);font-size:.82rem;color:var(--terra2);font-style:italic}

/* TIMELINE */
.timeline{padding:5rem 5vw;background:var(--bg2);border-top:1px solid rgba(107,143,113,.06)}
.timeline-inner{max-width:1100px;margin:0 auto}
.timeline-track{display:grid;grid-template-columns:repeat(5,1fr);gap:1rem;margin-top:3rem;position:relative}
.timeline-track::before{content:'';position:absolute;top:25px;left:8%;right:8%;height:1px;background:linear-gradient(90deg,transparent,var(--terra2),var(--sage2),transparent);z-index:0}
.tl-step{text-align:center;position:relative;z-index:1}
.tl-dot{width:50px;height:50px;background:var(--bg2);border:1px solid var(--sage3);border-radius:50%;margin:0 auto 1rem;display:flex;align-items:center;justify-content:center;font-family:var(--heading);font-size:1.1rem;color:var(--terra2);font-style:italic;transition:all .3s}
.tl-step:hover .tl-dot{background:var(--terra);color:var(--white);border-color:var(--terra);transform:scale(1.1)}
.tl-step h4{font-family:var(--heading);font-size:1rem;color:var(--cream);font-weight:400;font-style:italic;margin-bottom:.4rem}
.tl-step p{font-size:.78rem;color:var(--muted);font-weight:300;line-height:1.7}

/* TESTIMONIALS */
.testimonials{padding:6rem 5vw;max-width:1100px;margin:0 auto}
.testi-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem;margin-top:2rem}
.testi-card{background:var(--bg2);border:1px solid rgba(107,143,113,.06);padding:2rem;border-radius:3px;position:relative;transition:all .4s}
.testi-card::before{content:'"';position:absolute;top:-1.5rem;left:1.5rem;font-family:var(--heading);font-size:5rem;color:var(--terra);font-style:italic;line-height:1;opacity:.4}
.testi-card:hover{border-color:rgba(107,143,113,.2);transform:translateY(-3px)}
.testi-card .stars{color:var(--terra2);font-size:.95rem;letter-spacing:.15em;margin-bottom:1rem;margin-top:1rem}
.testi-card .quote{font-family:var(--elegant);font-size:.98rem;color:var(--cream);font-style:italic;line-height:1.8;margin-bottom:1rem;font-weight:400}
.testi-card .author{font-family:var(--body);font-size:.78rem;letter-spacing:.1em;color:var(--sage)}

/* CTA */
.cta{padding:8rem 5vw;text-align:center;position:relative;overflow:hidden}
.cta::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse at 50% 50%,rgba(107,143,113,.06),transparent 50%)}
.cta-inner{position:relative;z-index:1}
.cta h2{font-family:var(--heading);font-size:clamp(2.5rem,6vw,4.5rem);color:var(--cream);line-height:1.05;margin-bottom:.5rem;font-weight:400}
.cta h2 em{color:var(--sage2);font-style:italic}
.cta .sub{font-family:var(--elegant);font-size:1.1rem;color:var(--text);font-style:italic;margin-bottom:2.5rem}
.cta .phone{font-family:var(--heading);font-size:2.2rem;color:var(--terra);letter-spacing:.06em;text-decoration:none;display:inline-block;margin-top:2rem;transition:color .3s;font-weight:400}
.cta .phone:hover{color:var(--terra2)}
.cta .addr{font-size:.82rem;color:var(--muted);margin-top:.75rem;font-weight:300}

/* FOOTER */
footer{border-top:1px solid rgba(107,143,113,.06);padding:2.5rem 5vw;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:1rem}
.foot-left{font-size:.75rem;color:var(--muted);font-weight:300}
.foot-right{font-size:.72rem;color:var(--muted)}
.foot-right a{color:var(--sage);text-decoration:none;transition:color .2s}
.foot-right a:hover{color:var(--sage2)}

/* SUB-PAGE */
.subhero{padding:11rem 5vw 5rem;text-align:center;background:linear-gradient(180deg,var(--bg) 0%,var(--bg2) 100%);position:relative;overflow:hidden;border-bottom:1px solid rgba(107,143,113,.06)}
.subhero::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse at 50% 30%,rgba(107,143,113,.08),transparent 60%);pointer-events:none}
.subhero-flourish{width:80px;height:1px;background:linear-gradient(90deg,transparent,var(--sage3),transparent);margin:0 auto 2rem;opacity:.6}
.subhero-tag{font-family:var(--body);font-size:.7rem;letter-spacing:.3em;color:var(--terra2);margin-bottom:1rem;text-transform:uppercase;position:relative}
.subhero h1{font-family:var(--heading);font-size:clamp(3rem,7vw,5rem);color:var(--cream);margin-bottom:1rem;font-weight:400;position:relative}
.subhero h1 em{color:var(--sage2);font-style:italic}
.subhero p{font-family:var(--elegant);font-size:1.15rem;color:var(--text);font-style:italic;max-width:600px;margin:0 auto;position:relative;line-height:1.8}

.crumbs{padding:1.5rem 5vw;font-family:var(--body);font-size:.7rem;letter-spacing:.2em;color:var(--muted);text-transform:uppercase}
.crumbs a{color:var(--terra);text-decoration:none;transition:color .3s}
.crumbs a:hover{color:var(--terra2)}

/* PORTFOLIO PAGE */
.case-list{padding:5rem 5vw;max-width:1100px;margin:0 auto}
.case-item{display:grid;grid-template-columns:1fr 1fr;gap:3rem;align-items:center;margin-bottom:6rem;padding-bottom:3rem;border-bottom:1px solid rgba(107,143,113,.08)}
.case-item:last-child{border-bottom:none}
.case-item.flip{grid-template-columns:1fr 1fr}
.case-item.flip .case-vis{order:2}
.case-vis{aspect-ratio:4/3;border-radius:4px;overflow:hidden;border:1px solid rgba(107,143,113,.08);position:relative;background:var(--bg2);transition:transform .5s}
.case-vis:hover{transform:scale(1.02)}
.case-vis::before{content:'';position:absolute;inset:0;z-index:1}
.cv1::before{background:linear-gradient(160deg,rgba(107,143,113,.18),rgba(20,33,24,.8)),radial-gradient(circle at 30% 60%,rgba(107,143,113,.2),transparent 60%)}
.cv2::before{background:linear-gradient(45deg,rgba(193,127,89,.12),rgba(20,33,24,.85)),radial-gradient(circle at 70% 40%,rgba(193,127,89,.15),transparent 50%)}
.cv3::before{background:linear-gradient(180deg,rgba(107,143,113,.08),rgba(20,33,24,.92)),radial-gradient(circle at 50% 50%,rgba(193,127,89,.12),transparent 40%)}
.case-vis svg{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:40%;opacity:.08;color:var(--sage);z-index:1}
.case-vis .stamp{position:absolute;top:1.5rem;right:1.5rem;background:var(--terra);color:var(--white);font-family:var(--body);font-size:.65rem;letter-spacing:.2em;padding:.4rem .8rem;border-radius:2px;z-index:2;text-transform:uppercase}
.case-info .meta{font-family:var(--body);font-size:.7rem;letter-spacing:.25em;color:var(--terra);text-transform:uppercase;margin-bottom:.75rem}
.case-info h3{font-family:var(--heading);font-size:clamp(1.8rem,3vw,2.5rem);color:var(--cream);margin-bottom:1rem;font-weight:400;line-height:1.15}
.case-info h3 em{color:var(--sage2);font-style:italic}
.case-info p{font-family:var(--elegant);font-size:1rem;color:var(--text);font-style:italic;line-height:1.85;margin-bottom:1.25rem}
.case-stats{display:flex;gap:2rem;margin-top:1.5rem;flex-wrap:wrap}
.case-stat{padding-right:2rem;border-right:1px solid rgba(107,143,113,.1)}
.case-stat:last-child{border-right:none;padding-right:0}
.case-stat .v{font-family:var(--heading);font-size:1.4rem;color:var(--terra2);font-style:italic;display:block;line-height:1}
.case-stat .l{font-family:var(--body);font-size:.65rem;letter-spacing:.2em;color:var(--muted);text-transform:uppercase;margin-top:.3rem}

/* CONSULTATION FORM */
.consult{padding:5rem 5vw;max-width:1100px;margin:0 auto;display:grid;grid-template-columns:1fr 1fr;gap:4rem;align-items:start}
.consult-info h2{font-family:var(--heading);font-size:clamp(2rem,3.5vw,2.8rem);color:var(--cream);font-weight:400;margin-bottom:1rem}
.consult-info h2 em{color:var(--sage2);font-style:italic}
.consult-info .lead{font-family:var(--elegant);font-size:1.05rem;color:var(--text);font-style:italic;line-height:1.85;margin-bottom:2rem}
.consult-info .point{display:flex;gap:1rem;align-items:flex-start;margin-bottom:1.5rem}
.consult-info .point .num{width:40px;height:40px;border:1px solid var(--sage3);border-radius:50%;font-family:var(--heading);font-size:.95rem;font-style:italic;color:var(--terra2);display:flex;align-items:center;justify-content:center;flex-shrink:0;background:var(--bg2)}
.consult-info .point h4{font-family:var(--heading);font-size:1rem;color:var(--cream);font-weight:400;margin-bottom:.25rem}
.consult-info .point p{font-size:.88rem;color:var(--muted);line-height:1.8;font-weight:300}

.consult-card{background:var(--bg2);border:1px solid rgba(107,143,113,.1);padding:2.5rem;border-radius:3px}
.consult-card h3{font-family:var(--heading);font-size:1.4rem;color:var(--cream);font-weight:400;margin-bottom:1.5rem}
.consult-card h3 em{color:var(--sage2);font-style:italic}
.cfield{margin-bottom:1.25rem}
.cfield label{display:block;font-family:var(--body);font-size:.65rem;letter-spacing:.25em;color:var(--terra);text-transform:uppercase;margin-bottom:.5rem;font-weight:600}
.cfield input,.cfield textarea,.cfield select{width:100%;background:var(--bg);border:1px solid rgba(107,143,113,.15);color:var(--cream);padding:.85rem 1rem;font-family:var(--elegant);font-size:.95rem;transition:border-color .3s;border-radius:2px}
.cfield input:focus,.cfield textarea:focus,.cfield select:focus{outline:none;border-color:var(--sage2)}
.coptions{display:grid;grid-template-columns:repeat(2,1fr);gap:.5rem}
.copt{background:var(--bg);border:1px solid rgba(107,143,113,.15);padding:.85rem;text-align:center;cursor:pointer;font-family:var(--heading);font-size:.85rem;font-style:italic;color:var(--cream);transition:all .3s;border-radius:2px}
.copt:hover{border-color:var(--sage2)}
.copt.selected{background:var(--sage3);color:var(--white);border-color:var(--sage3)}
.csubmit{display:block;width:100%;background:var(--sage3);color:var(--white);border:none;padding:1.1rem;font-family:var(--heading);font-size:1rem;letter-spacing:.06em;font-style:italic;cursor:pointer;margin-top:1rem;transition:all .3s;border-radius:2px}
.csubmit:hover{background:var(--sage)}
.cmsg{margin-top:1rem;font-size:.85rem;color:var(--sage2);text-align:center;opacity:0;transition:opacity .3s;font-style:italic}
.cmsg.vis{opacity:1}

@media(max-width:900px){
  .marquee{display:none}
  nav{top:28px;padding:0 1.5rem}
  .nav-mid{display:none}
  .stats-inner{grid-template-columns:repeat(2,1fr);gap:2rem}
  .stat:nth-child(2)::after{display:none}
  .svc-grid{grid-template-columns:1fr}
  .approach-inner{grid-template-columns:1fr;gap:3rem}
  .approach-visual{max-height:350px}
  .gallery-grid{grid-template-columns:1fr 1fr;grid-template-rows:200px 200px 200px}
  .gallery-item.tall{grid-row:span 1}
  .timeline-track{grid-template-columns:repeat(2,1fr);gap:2rem}
  .timeline-track::before{display:none}
  .testi-grid{grid-template-columns:1fr}
  .case-item,.case-item.flip{grid-template-columns:1fr;gap:2rem}
  .case-item.flip .case-vis{order:0}
  .consult{grid-template-columns:1fr;gap:2rem}
}
@media(max-width:600px){
  .hero h1{font-size:3rem}
  .gallery-grid{grid-template-columns:1fr;grid-template-rows:repeat(5,180px)}
}
