:root{
  --max:1180px;
  --max-wide:1280px;
  --radius-xl:34px;
  --radius-lg:26px;
  --radius-md:18px;
  --font: Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
}
.theme-dark{
  --bg:#090d14;
  --bg-2:#0d1420;
  --paper:#111a27;
  --paper-2:#151f2e;
  --paper-3:#0f1723;
  --text:#f5f7fb;
  --soft:#c6ceda;
  --muted:#8995a6;
  --line:rgba(255,255,255,.11);
  --line-strong:rgba(255,255,255,.18);
  --accent:#91dcff;
  --accent-2:#d6bc83;
  --accent-text:#07111b;
  --shadow:0 32px 90px rgba(0,0,0,.34);
  --shadow-soft:0 20px 48px rgba(0,0,0,.22);
}
.theme-light{
  --bg:#f7f2e9;
  --bg-2:#efe7da;
  --paper:#fffaf0;
  --paper-2:#f2eadf;
  --paper-3:#fffdf8;
  --text:#18191c;
  --soft:#424a55;
  --muted:#6b7380;
  --line:rgba(27,30,36,.14);
  --line-strong:rgba(27,30,36,.22);
  --accent:#255f6f;
  --accent-2:#a66f2d;
  --accent-text:#fffaf0;
  --shadow:0 32px 82px rgba(79,58,27,.14);
  --shadow-soft:0 18px 44px rgba(79,58,27,.12);
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  min-height:100vh;
  color:var(--text);
  font-family:var(--font);
  line-height:1.55;
  background:
    radial-gradient(circle at 10% -12%, color-mix(in srgb,var(--accent) 16%,transparent), transparent 34rem),
    radial-gradient(circle at 88% 10%, color-mix(in srgb,var(--accent-2) 16%,transparent), transparent 30rem),
    linear-gradient(180deg,var(--bg),var(--bg-2));
  letter-spacing:-.012em;
}
a{color:inherit;text-decoration:none}
button,input,textarea{font:inherit;color:inherit}
button{cursor:pointer}
img{max-width:100%;display:block}
.skip-link{position:absolute;left:-999px;top:12px;background:var(--paper);padding:10px 14px;border-radius:14px;z-index:9999;border:1px solid var(--line)}
.skip-link:focus{left:12px}
.app-shell{min-height:100vh}.app-wrap{min-height:100vh;display:flex;flex-direction:column}
.site-header{position:sticky;top:0;z-index:70;padding:18px 20px 8px;background:linear-gradient(180deg,color-mix(in srgb,var(--bg) 96%,transparent),color-mix(in srgb,var(--bg) 68%,transparent));backdrop-filter:blur(20px)}
.header-inner{max-width:var(--max-wide);margin:0 auto;display:grid;grid-template-columns:minmax(220px,1fr) auto minmax(220px,1fr);align-items:center;gap:18px;padding:11px 12px 11px 16px;border:1px solid var(--line);background:color-mix(in srgb,var(--paper) 88%,transparent);border-radius:999px;box-shadow:var(--shadow-soft)}
.brand{display:flex;gap:12px;align-items:center;min-width:0}.brand-mark{width:44px;height:44px;border-radius:17px;display:grid;place-items:center;background:linear-gradient(135deg,var(--accent),color-mix(in srgb,var(--accent) 58%,var(--accent-2)));color:var(--accent-text);font-size:15px;font-weight:950;letter-spacing:-.08em;box-shadow:0 14px 30px color-mix(in srgb,var(--accent) 24%,transparent)}
.brand-copy{min-width:0}.brand-copy strong{display:block;max-width:320px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;font-size:15px;line-height:1.12}.brand-copy span{display:block;max-width:320px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;color:var(--muted);font-size:12px;margin-top:2px}
.main-nav{justify-self:center;display:flex;gap:3px;align-items:center;padding:5px;border:1px solid var(--line);border-radius:999px;background:color-mix(in srgb,var(--paper-3) 88%,transparent)}
.nav-link{padding:10px 15px;border-radius:999px;color:var(--muted);font-size:13px;font-weight:800;transition:.18s ease}.nav-link:hover,.nav-link.is-active{color:var(--text);background:var(--paper);box-shadow:0 10px 24px rgba(0,0,0,.10)}
.header-actions{justify-self:end;display:flex;gap:9px;align-items:center}.theme-toggle{width:46px;height:46px;border-radius:50%;border:1px solid var(--line);background:var(--paper-3);display:grid;place-items:center;font-size:19px;box-shadow:0 10px 22px rgba(0,0,0,.08);transition:.18s ease}.theme-toggle:hover{transform:translateY(-1px);border-color:var(--line-strong)}
.header-cta,.btn,.mobile-cta{display:inline-flex;align-items:center;justify-content:center;border:0;border-radius:999px;padding:13px 19px;font-size:14px;font-weight:900;line-height:1.1;transition:.18s ease}.header-cta,.btn.primary,.mobile-cta{background:linear-gradient(135deg,var(--accent),color-mix(in srgb,var(--accent) 70%,var(--accent-2)));color:var(--accent-text);box-shadow:0 14px 34px color-mix(in srgb,var(--accent) 23%,transparent)}.btn.secondary{border:1px solid var(--line);background:transparent;color:var(--text)}.btn.ghost{border:1px solid var(--line);background:var(--paper-3);color:var(--text)}.header-cta:hover,.btn:hover,.mobile-cta:hover{transform:translateY(-1px)}
.mode-rail{position:fixed;right:18px;top:50%;transform:translateY(-50%);z-index:80;display:flex;flex-direction:column;align-items:flex-end;gap:8px;writing-mode:horizontal-tb}.mode-rail button{border:1px solid var(--line-strong);background:color-mix(in srgb,var(--paper) 92%,transparent);color:var(--text);border-radius:999px;padding:13px 18px;font-weight:950;letter-spacing:.02em;box-shadow:var(--shadow-soft);backdrop-filter:blur(14px);transition:.18s ease;white-space:nowrap}.mode-rail button:hover{transform:translateX(-2px);border-color:color-mix(in srgb,var(--accent) 60%,var(--line))}.mode-pill{font-size:11px;color:var(--muted);text-transform:uppercase;letter-spacing:.16em;background:color-mix(in srgb,var(--paper) 80%,transparent);border:1px solid var(--line);padding:8px 12px;border-radius:999px}
.site-main{width:100%;max-width:var(--max-wide);margin:0 auto;padding:52px 20px 76px}.page-shell{display:grid;gap:30px}.hero{display:grid;grid-template-columns:minmax(0,1.02fr) minmax(360px,.78fr);gap:34px;align-items:stretch}.hero-panel{border:1px solid var(--line);border-radius:var(--radius-xl);background:linear-gradient(145deg,color-mix(in srgb,var(--paper) 96%,transparent),color-mix(in srgb,var(--paper-3) 96%,transparent));box-shadow:var(--shadow);padding:56px;position:relative;overflow:hidden}.hero-panel:before{content:"";position:absolute;inset:auto -8rem -10rem auto;width:22rem;height:22rem;border-radius:50%;background:color-mix(in srgb,var(--accent) 10%,transparent);filter:blur(8px)}.hero-content{position:relative}.eyebrow{margin:0 0 14px;color:var(--accent);font-size:12px;font-weight:950;letter-spacing:.16em;text-transform:uppercase}.mode-badge{display:inline-flex;align-items:center;gap:8px;border:1px solid var(--line);background:var(--paper-3);border-radius:999px;padding:8px 12px;color:var(--soft);font-size:12px;font-weight:900;margin-bottom:18px}.mode-badge:before{content:"";width:8px;height:8px;border-radius:50%;background:var(--accent);box-shadow:0 0 0 4px color-mix(in srgb,var(--accent) 16%,transparent)}
h1,h2,h3,p{margin-top:0}h1{font-size:clamp(46px,6.9vw,96px);line-height:.88;letter-spacing:-.086em;margin-bottom:22px;max-width:960px}h2{font-size:clamp(31px,4.6vw,58px);line-height:.96;letter-spacing:-.066em;margin-bottom:16px}h3{font-size:20px;line-height:1.14;letter-spacing:-.035em;margin-bottom:10px}.lead{font-size:clamp(20px,2.2vw,27px);line-height:1.34;color:var(--soft);max-width:800px;margin-bottom:18px}.intro{font-size:17px;color:var(--muted);max-width:820px;margin-bottom:31px}.hero-actions{display:flex;gap:12px;flex-wrap:wrap;margin-bottom:26px}.trust-line{display:flex;gap:10px;flex-wrap:wrap;margin:0;padding-top:20px;border-top:1px solid var(--line);color:var(--muted);font-size:14px}.trust-line span{display:inline-flex;align-items:center;gap:8px}.trust-line span:before{content:"";width:6px;height:6px;border-radius:50%;background:var(--accent-2)}
.visual-card{border:1px solid var(--line);border-radius:var(--radius-xl);background:color-mix(in srgb,var(--paper) 94%,transparent);box-shadow:var(--shadow);padding:16px;overflow:hidden}.visual-card figure{margin:0;height:100%;display:grid;grid-template-rows:minmax(320px,1fr) auto}.visual-card img{width:100%;height:100%;min-height:320px;object-fit:cover;border-radius:24px;border:1px solid var(--line)}.visual-card figcaption{padding:18px 4px 3px;color:var(--muted);font-size:14px}.visual-card strong{display:block;color:var(--text);font-size:18px;margin-bottom:2px}
.quick-facts{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}.quick-facts article,.service-card,.value-card,.gallery-card,.contact-card,.process-card,.story-card,.legal-card{border:1px solid var(--line);background:color-mix(in srgb,var(--paper) 92%,transparent);border-radius:var(--radius-lg);box-shadow:0 18px 45px rgba(0,0,0,.10)}.quick-facts article{padding:25px}.quick-facts p,.service-card p,.value-card p,.gallery-card p,.process-card p,.story-card p,.section-head p,.contact-card p,.legal-card p{color:var(--muted)}
.section-head{display:flex;align-items:end;justify-content:space-between;gap:26px;margin-top:20px}.section-head > div{max-width:760px}.section-head p{font-size:17px;margin-bottom:0}.services-preview,.services-grid,.value-grid,.process-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}.service-card{padding:28px;min-height:245px;display:flex;flex-direction:column;position:relative;overflow:hidden}.service-card:before{content:attr(data-count);position:absolute;right:24px;top:20px;color:color-mix(in srgb,var(--accent) 40%,transparent);font-weight:950;font-size:42px;letter-spacing:-.08em}.service-card h3,.service-card p,.service-card small,.service-card a{position:relative}.service-card p{margin-bottom:20px}.service-card small{display:block;margin-top:auto;color:var(--accent);font-weight:950}.service-card a{align-self:flex-start;margin-top:17px;border:1px solid var(--line);background:var(--paper-3);border-radius:999px;padding:9px 14px;font-size:13px;font-weight:900}.service-card a:hover{border-color:color-mix(in srgb,var(--accent) 60%,var(--line))}
.story-card{display:grid;grid-template-columns:minmax(0,.92fr) minmax(360px,.62fr);gap:32px;padding:42px;align-items:center}.story-card img{width:100%;height:330px;object-fit:cover;border-radius:24px;border:1px solid var(--line)}.value-grid{margin-top:16px}.value-card{padding:24px}.process-grid .process-card{padding:25px}.process-card span{display:inline-flex;width:40px;height:40px;border-radius:15px;align-items:center;justify-content:center;background:var(--accent);color:var(--accent-text);font-weight:950;margin-bottom:16px}.gallery-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}.gallery-card{overflow:hidden}.gallery-card img{width:100%;height:245px;object-fit:cover;border-bottom:1px solid var(--line)}.gallery-card h3{padding:20px 20px 0;margin-bottom:8px}.gallery-card p{padding:0 20px 22px;margin:0}.wide-note{border:1px solid var(--line);border-radius:var(--radius-lg);padding:25px;background:linear-gradient(135deg,color-mix(in srgb,var(--accent) 10%,var(--paper)),color-mix(in srgb,var(--paper) 94%,transparent));display:flex;align-items:center;justify-content:space-between;gap:22px}.wide-note p{margin:0;color:var(--muted)}
.page-title{border:1px solid var(--line);border-radius:var(--radius-xl);background:color-mix(in srgb,var(--paper) 94%,transparent);box-shadow:var(--shadow);padding:52px}.page-title p:last-child{max-width:820px;color:var(--muted);font-size:18px;margin-bottom:0}.contact-layout{display:grid;grid-template-columns:.78fr 1fr;gap:24px}.contact-card{padding:38px}.contact-list{display:grid;gap:12px;margin-top:27px}.contact-list a,.contact-list div{display:block;border:1px solid var(--line);border-radius:20px;background:var(--paper-3);padding:16px}.contact-list span{display:block;color:var(--muted);font-size:12px;font-weight:950;letter-spacing:.14em;text-transform:uppercase}.contact-list strong{display:block;margin-top:5px}.contact-form{display:grid;gap:14px}.contact-form label{display:grid;gap:7px;color:var(--muted);font-weight:850;font-size:13px}.contact-form input,.contact-form textarea{width:100%;border:1px solid var(--line);border-radius:18px;background:var(--paper-3);padding:14px 15px;outline:0}.contact-form input:focus,.contact-form textarea:focus{border-color:color-mix(in srgb,var(--accent) 70%,var(--line));box-shadow:0 0 0 4px color-mix(in srgb,var(--accent) 12%,transparent)}.form-note{font-size:13px;color:var(--muted);margin:0}.legal-card{padding:42px;max-width:900px;margin:0 auto}.legal-card dl{display:grid;grid-template-columns:190px 1fr;gap:10px 18px}.legal-card dt{color:var(--muted);font-weight:900}.legal-card dd{margin:0}.site-footer{margin-top:auto;padding:28px 20px 42px}.footer-inner{max-width:var(--max-wide);margin:0 auto;border-top:1px solid var(--line);padding-top:22px;display:flex;align-items:center;justify-content:space-between;gap:18px;color:var(--muted);font-size:13px}.footer-links{display:flex;gap:14px;align-items:center}.footer-links a:hover{color:var(--text)}.mobile-cta{display:none;position:fixed;left:18px;right:18px;bottom:16px;z-index:90}.toast{position:fixed;left:50%;bottom:24px;transform:translateX(-50%);z-index:100;background:var(--paper);border:1px solid var(--line);border-radius:999px;padding:12px 16px;box-shadow:var(--shadow-soft);font-size:13px;font-weight:850}
@media (max-width:1120px){.header-inner{grid-template-columns:1fr auto}.main-nav{grid-column:1/-1;justify-self:stretch;overflow:auto;justify-content:flex-start}.hero,.story-card,.contact-layout{grid-template-columns:1fr}.visual-card figure{grid-template-rows:auto auto}.gallery-grid{grid-template-columns:repeat(2,1fr)}}
@media (max-width:760px){.site-header{padding:12px 12px 5px}.header-inner{border-radius:26px;padding:10px;gap:10px}.brand-copy span{display:none}.header-cta{display:none}.theme-toggle{width:42px;height:42px}.site-main{padding:28px 12px 92px}.hero-panel,.page-title,.story-card,.contact-card,.legal-card{padding:28px;border-radius:26px}.hero{gap:14px}.quick-facts,.services-preview,.services-grid,.value-grid,.process-grid,.gallery-grid{grid-template-columns:1fr}.section-head{display:block}.visual-card img{min-height:240px}.mode-rail{right:8px;top:auto;bottom:82px;transform:none}.mode-rail button{padding:12px 14px;font-size:12px}.mode-pill{display:none}.mobile-cta{display:inline-flex}.footer-inner{display:grid}.legal-card dl{grid-template-columns:1fr}.nav-link{padding:9px 12px}.main-nav{scrollbar-width:none}.main-nav::-webkit-scrollbar{display:none}h1{font-size:clamp(42px,16vw,62px)}}
@media (prefers-reduced-motion:reduce){*{scroll-behavior:auto!important;transition:none!important}}


/* V16 polish on top of V15 */
h1{font-size:clamp(42px,6vw,82px);letter-spacing:-.072em;line-height:.92}
.mode-rail{right:14px;opacity:.9}
.mode-rail:hover{opacity:1}
.mode-rail button{padding:10px 14px;font-size:12px;font-weight:900;box-shadow:0 12px 30px rgba(0,0,0,.18)}
.mode-pill{font-size:10px;padding:6px 10px;letter-spacing:.14em}
.visual-card figcaption{display:block;line-height:1.4}
.visual-card figcaption strong{font-size:16px}
.mode-example .visual-card figcaption{color:var(--soft)}
.mode-example .wide-note{background:linear-gradient(135deg,color-mix(in srgb,var(--accent-2) 12%,var(--paper)),color-mix(in srgb,var(--paper) 94%,transparent))}
@media (max-width:760px){.mode-rail{right:10px;bottom:78px}.mode-rail button{max-width:210px}.mode-example .mode-rail button,.mode-template .mode-rail button{font-size:11px}h1{font-size:clamp(38px,13vw,56px)}}


/* V17: routing + visual cleanup */
html{scroll-padding-top:124px}
.site-main{padding-top:64px}
.page-title{overflow:visible}
.page-title h1{font-size:clamp(36px,4.7vw,68px);line-height:1;letter-spacing:-.058em;max-width:900px}
.hero h1{font-size:clamp(42px,6vw,82px);line-height:.92;letter-spacing:-.072em}
.mode-template .visual-card img[src*="placeholders"],
.mode-template .story-card img[src*="placeholders"],
.mode-template .gallery-card img[src*="placeholders"]{
  object-fit:contain;
  padding:26px;
  background:linear-gradient(135deg,color-mix(in srgb,var(--paper-2) 82%,transparent),color-mix(in srgb,var(--accent-2) 16%,var(--paper)));
}
.mode-template .visual-card img[src*="placeholders"]{min-height:320px}
.mode-template .gallery-card img[src*="placeholders"]{height:245px}
.mode-template .visual-card figcaption strong{font-size:16px}
.mode-rail{right:12px;transform:translateY(-50%) scale(.94);transform-origin:right center}
.mode-rail button{padding:9px 13px;font-size:11px}
.mode-pill{font-size:9px;padding:5px 9px}
@media (max-width:1120px){.page-title h1{font-size:clamp(34px,7vw,58px)}}
@media (max-width:760px){
  html{scroll-padding-top:104px}
  .site-main{padding-top:34px}
  .page-title h1{font-size:clamp(34px,11vw,52px);line-height:1.02}
  .hero h1{font-size:clamp(38px,13vw,56px)}
  .mode-template .visual-card img[src*="placeholders"],
  .mode-template .story-card img[src*="placeholders"],
  .mode-template .gallery-card img[src*="placeholders"]{padding:18px}
}


/* V18: image + audit polish */
:root{--image-radius:28px}
.mode-example .visual-card{padding:12px}
.mode-example .visual-card figure{position:relative;display:block;min-height:100%}
.mode-example .visual-card img{min-height:430px;object-position:center;border-radius:var(--image-radius)}
.mode-example .visual-card figcaption{position:absolute;left:18px;right:18px;bottom:18px;padding:16px 18px;border:1px solid rgba(255,255,255,.18);border-radius:22px;background:linear-gradient(180deg,rgba(9,13,20,.28),rgba(9,13,20,.72));backdrop-filter:blur(16px);color:rgba(255,255,255,.78);box-shadow:0 18px 40px rgba(0,0,0,.22)}
.mode-example .visual-card figcaption strong{color:#fff;font-size:18px}
.mode-example.theme-light .visual-card figcaption{background:linear-gradient(180deg,rgba(255,250,240,.68),rgba(255,250,240,.92));color:#3d4650;border-color:rgba(27,30,36,.16)}
.mode-example.theme-light .visual-card figcaption strong{color:#16181c}
.mode-example .gallery-grid{grid-template-columns:repeat(12,1fr);align-items:stretch}
.mode-example .gallery-card{grid-column:span 6;display:flex;flex-direction:column}
.mode-example .gallery-card:nth-child(1){grid-column:span 7}
.mode-example .gallery-card:nth-child(2){grid-column:span 5}
.mode-example .gallery-card:nth-child(3),.mode-example .gallery-card:nth-child(4){grid-column:span 6}
.mode-example .gallery-card img{height:310px;object-position:center}
.mode-example .gallery-card:nth-child(1) img{height:380px}
.mode-example .gallery-card:nth-child(2) img{height:380px}
.mode-example .service-card{min-height:230px}
.mode-rail{right:10px;opacity:.82}
.mode-rail:hover,.mode-rail:focus-within{opacity:1}
.mode-rail button{border-radius:18px;padding:10px 12px;max-width:172px;white-space:normal;line-height:1.15;text-align:center}
.mode-pill{display:none}
@media (max-width:1120px){.mode-example .gallery-grid{grid-template-columns:repeat(2,1fr)}.mode-example .gallery-card,.mode-example .gallery-card:nth-child(1),.mode-example .gallery-card:nth-child(2),.mode-example .gallery-card:nth-child(3),.mode-example .gallery-card:nth-child(4){grid-column:auto}.mode-example .gallery-card img,.mode-example .gallery-card:nth-child(1) img,.mode-example .gallery-card:nth-child(2) img{height:300px}}
@media (max-width:760px){.mode-example .visual-card img{min-height:280px}.mode-example .visual-card figcaption{position:static;margin-top:12px;background:color-mix(in srgb,var(--paper) 92%,transparent);color:var(--muted)}.mode-example .visual-card figcaption strong{color:var(--text)}.mode-example .gallery-grid{grid-template-columns:1fr}.mode-example .gallery-card img,.mode-example .gallery-card:nth-child(1) img,.mode-example .gallery-card:nth-child(2) img{height:250px}.mode-rail{right:8px;bottom:78px;max-width:160px}.mode-rail button{font-size:11px;padding:9px 11px}.footer-inner{padding-bottom:72px}}


/* V19: audit-based visual refinement */
.site-main{padding-top:46px;padding-bottom:58px}
.page-shell{gap:24px}
.hero{gap:28px}
.hero-panel{padding:48px}
.visual-card{padding:14px}
.quick-facts article{padding:22px}
.start-note{margin-top:0}
.mode-rail{
  top:auto!important;
  right:18px!important;
  bottom:24px!important;
  transform:none!important;
  z-index:90;
  opacity:.78;
  gap:6px;
}
.mode-rail:hover{opacity:1}
.mode-rail .mode-pill{display:none}
.mode-rail button{
  padding:9px 13px!important;
  font-size:11px!important;
  line-height:1.1;
  max-width:185px;
  box-shadow:0 14px 36px rgba(0,0,0,.22)!important;
}
.mode-example .mode-rail button{
  background:color-mix(in srgb,var(--accent) 18%,var(--paper) 88%);
}
.mode-template .visual-card img[src*="placeholders"]{
  object-fit:contain;
  padding:30px;
}
.mode-template .visual-card figcaption{
  padding-top:14px;
}
.mode-example .hero-panel{
  background:linear-gradient(145deg,color-mix(in srgb,var(--paper) 96%,transparent),color-mix(in srgb,var(--accent-2) 8%,var(--paper-3)));
}
.mode-example .lead{max-width:700px}
@media (min-width:1121px){
  .hero-panel{min-height:500px;display:flex;align-items:center}
  .visual-card figure{grid-template-rows:minmax(390px,1fr) auto}
}
@media (max-width:1120px){
  .site-main{padding-top:36px}
  .hero-panel{padding:38px}
  .mode-rail{bottom:20px!important;right:14px!important}
}
@media (max-width:760px){
  .site-main{padding-top:24px}
  .page-shell{gap:18px}
  .hero-panel,.page-title,.story-card,.contact-card,.legal-card{padding:24px}
  .mode-rail{bottom:74px!important;right:10px!important}
  .mode-rail button{max-width:148px!important;padding:8px 10px!important;font-size:10px!important}
  .quick-facts article{padding:20px}
  .start-note{display:block}
}
