/* ============================================
   EMANOEL PERES — Global Stylesheet
   Fonts: Bricolage Grotesque (hero) + Coolvetica (brand) + Geist Mono (body)
   ============================================ */

/* ── TOKENS ── */
:root {
    --bg:        #f5efe4;
    --bg2:       #ede4d6;
    --bg3:       #e3d7c5;
    --paper:     #fbf6eb;

    --text:      #2e1d0b;
    --ink:       #2e1d0b;
    --muted:     rgba(41,25,9,.70);
    --dim:       rgba(87,57,30,.44);

    --accent:    #d95f00;
    --orange:    #d95f00;
    --accent2:   #f07020;
    --accent-bg: rgba(217,95,0,.10);

    --line:      rgba(42,24,10,.10);
    --line2:     rgba(42,24,10,.18);
    --ls:        rgba(42,24,10,.08);
    --lm:        rgba(42,24,10,.13);

    --mono:    'Geist Mono','JetBrains Mono',monospace;
    --display: 'Bricolage Grotesque',sans-serif;
    --brand:   'Coolvetica','Bricolage Grotesque','Arial Rounded MT Bold',Arial,sans-serif;
}

/* ── RESET ── */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; font-size: 16px; background: #f8f0e4; }
body {
    background: transparent;
    color: var(--text);
    font-family: var(--mono);
    line-height: 1.6;
    overflow-x: hidden;
    text-transform: lowercase;
}
img, svg { display: block; max-width: 100%; }
a { color: inherit; }
button { font-family: inherit; }

/* ── SCROLLBAR ── */
::-webkit-scrollbar { width: 2px; }
::-webkit-scrollbar-track { background: var(--bg); }
::-webkit-scrollbar-thumb { background: var(--accent); }

/* ── BACKGROUND ── */
.bg-layer {
    position: fixed; inset: 0; z-index: 0;
    pointer-events: none;
    background: #faf7f2;
}

/* ── NAV ── */
.xnav {
    position: fixed; top: 20px; left: 0; right: 0;
    z-index: 9000; pointer-events: none;
    display: flex; flex-direction: column; align-items: center;
}
.xnav-pill {
    pointer-events: all;
    display: flex; align-items: center; gap: 6px;
    padding: 6px 6px 6px 6px;
    background: rgba(250,247,242,.94);
    border: 1px solid rgba(42,24,10,.08);
    border-radius: 100px;
    box-shadow: 0 2px 16px rgba(42,24,10,.06);
    transition: box-shadow .3s;
}
.xnav-pill:hover {
    box-shadow: 0 4px 24px rgba(42,24,10,.10);
}
.xnav.scrolled .xnav-pill {
    box-shadow: 0 4px 28px rgba(42,24,10,.12);
}
/* logomark */
.xnav-mark {
    display: flex; text-decoration: none; flex-shrink: 0;
}
.xnav-mark-inner {
    display: flex; flex-direction: column;
    width: 36px; height: 36px;
    background: #1e0e04; border-radius: 10px;
    overflow: hidden; flex-shrink: 0;
    transition: transform .3s cubic-bezier(.2,.8,.2,1), box-shadow .3s;
}
.xnav-mark:hover .xnav-mark-inner {
    transform: scale(1.08) rotate(-3deg);
    box-shadow: 0 0 18px rgba(217,95,0,.45);
}
.xnav-mark-bar {
    background: #2d1205; padding: 3px 4px 2px;
    display: flex; gap: 2.5px; align-items: center; flex-shrink: 0;
}
.xnav-mark-bar i {
    display: block; width: 4px; height: 4px; border-radius: 50%; flex-shrink: 0;
}
.xnav-mark-bar i:nth-child(1) { background: #ff5f57; }
.xnav-mark-bar i:nth-child(2) { background: #28c840; }
.xnav-mark-bar i:nth-child(3) { background: #ffbd2e; }
.xnav-mark-ep {
    flex: 1; display: flex; align-items: center; justify-content: center;
    font-family: var(--display); font-weight: 800;
    font-size: 13px; letter-spacing: -.03em; color: #f5efe4; line-height: 1;
}
/* links */
.xnav-links {
    display: flex; align-items: center; gap: 2px;
    padding: 0 8px;
}
.xnav-link {
    font-family: var(--mono); font-size: .6rem; letter-spacing: .08em;
    text-transform: lowercase; color: var(--muted); text-decoration: none;
    padding: 8px 12px; border-radius: 100px;
    transition: background .18s, color .18s;
    white-space: nowrap;
}
.xnav-link:hover { background: rgba(42,24,10,.07); color: var(--text); }
/* right side */
.xnav-right {
    display: flex; align-items: center; gap: 6px; padding-left: 4px;
}
.xnav-lang {
    display: flex; align-items: center; gap: 5px;
    font-family: var(--mono); font-size: .56rem; letter-spacing: .1em;
    color: var(--dim); padding: 0 8px;
}
.xnav-lang a { color: var(--dim); text-decoration: none; transition: color .2s; }
.xnav-lang a:hover, .xnav-lang .xnav-lang-on { color: var(--text); font-weight: 600; }
.xnav-lang span { opacity: .35; }
.xnav-cta {
    display: inline-flex; align-items: center; gap: 6px;
    font-family: var(--mono); font-size: .6rem; letter-spacing: .08em;
    text-transform: lowercase; text-decoration: none;
    background: var(--accent); color: #fff;
    padding: 9px 18px; border-radius: 100px;
    transition: background .2s, transform .2s, box-shadow .2s;
    white-space: nowrap;
}
.xnav-cta:hover {
    background: var(--accent2); transform: translateY(-1px);
    box-shadow: 0 6px 20px rgba(217,95,0,.35);
}
/* burger */
.xnav-burger {
    display: none; flex-direction: column; justify-content: center; gap: 5px;
    width: 36px; height: 36px; background: none; border: none;
    cursor: pointer; padding: 8px; border-radius: 50%;
    transition: background .2s;
}
.xnav-burger:hover { background: rgba(42,24,10,.07); }
.xnav-burger span {
    display: block; height: 1.5px; background: var(--text);
    border-radius: 2px; transition: transform .3s, opacity .3s;
    transform-origin: center;
}
.xnav-burger.open span:nth-child(1) { transform: translateY(3.25px) rotate(45deg); }
.xnav-burger.open span:nth-child(2) { transform: translateY(-3.25px) rotate(-45deg); }
/* drawer */
.xnav-drawer {
    pointer-events: all;
    display: flex; flex-direction: column;
    background: rgba(245,239,228,.96);
    backdrop-filter: blur(28px); -webkit-backdrop-filter: blur(28px);
    border: 1px solid rgba(42,24,10,.10);
    border-radius: 20px;
    margin-top: 8px;
    padding: 8px;
    gap: 2px;
    min-width: 220px;
    box-shadow: 0 16px 48px rgba(42,24,10,.14);
    transform: translateY(-8px) scale(.97); opacity: 0;
    pointer-events: none;
    transition: transform .28s cubic-bezier(.2,.8,.2,1), opacity .22s;
}
.xnav-drawer.open {
    transform: none; opacity: 1; pointer-events: all;
}
.xnav-drawer-link {
    font-family: var(--mono); font-size: .7rem; letter-spacing: .06em;
    text-transform: lowercase; color: var(--muted); text-decoration: none;
    padding: 11px 16px; border-radius: 12px;
    transition: background .15s, color .15s;
}
.xnav-drawer-link:hover { background: rgba(42,24,10,.06); color: var(--text); }
.xnav-drawer-cta {
    display: block; text-align: center;
    font-family: var(--mono); font-size: .7rem; letter-spacing: .06em;
    text-transform: lowercase; text-decoration: none;
    background: var(--accent); color: #fff;
    padding: 12px 16px; border-radius: 12px; margin-top: 4px;
    transition: background .2s;
}
.xnav-drawer-cta:hover { background: var(--accent2); }
@media (max-width: 860px) {
    .xnav-links, .xnav-lang, .xnav-cta { display: none; }
    .xnav-burger { display: flex; }
}

/* ── FOOTER ── */
.footer { border-top: 1px solid var(--line); padding: 28px 48px; }
.footer-inner { max-width: 1280px; margin: 0 auto; display: flex; align-items: center; justify-content: space-between; }
.footer-name, .footer-year { font-family: var(--mono); font-size: .62rem; letter-spacing: .16em; text-transform: lowercase; color: var(--dim); }
@media (max-width: 600px) { .footer { padding: 24px; } }

/* ── WPP FLOAT ── */
.wpp-float {
    position: fixed; bottom: 28px; right: 28px; z-index: 300;
    width: 52px; height: 52px;
    background: #25d366; color: #fff;
    border-radius: 50%;
    display: flex; align-items: center; justify-content: center;
    box-shadow: 0 6px 24px rgba(37,211,102,.35);
    transition: transform .3s, box-shadow .3s;
    text-decoration: none;
}
.wpp-float:hover { transform: scale(1.1); box-shadow: 0 10px 32px rgba(37,211,102,.45); }
.wpp-float-tip {
    position: absolute; right: 62px;
    background: var(--text); color: var(--bg);
    font-family: var(--mono); font-size: .6rem; letter-spacing: .08em;
    padding: 6px 12px; white-space: nowrap;
    opacity: 0; pointer-events: none;
    transform: translateX(8px);
    transition: opacity .2s, transform .2s;
}
.wpp-float:hover .wpp-float-tip { opacity: 1; transform: translateX(0); }
.scroll-progress{position:fixed;top:0;left:0;z-index:9500;height:2px;width:0;background:linear-gradient(90deg,var(--orange),var(--og2));pointer-events:none;transition:width .08s linear}
.back-to-top{position:fixed;right:28px;bottom:92px;z-index:280;width:42px;height:42px;border:1px solid var(--line2);border-radius:50%;background:rgba(251,246,235,.86);color:var(--text);display:grid;place-items:center;cursor:pointer;opacity:0;pointer-events:none;transform:translateY(8px);transition:opacity .22s,transform .22s,background .22s,border-color .22s;box-shadow:0 8px 28px rgba(42,24,10,.10)}
.back-to-top--visible{opacity:1;pointer-events:auto;transform:none}
.back-to-top:hover{background:var(--ink);border-color:var(--ink);color:var(--paper)}

/* ── BUTTONS (global, used in nav/detail) ── */
.btn {
    display: inline-flex; align-items: center; gap: 10px;
    text-decoration: none; font-family: var(--mono); font-size: .65rem;
    letter-spacing: .1em; text-transform: lowercase;
    transition: all .22s; cursor: pointer; border: none; background: none;
}
.btn-primary {
    background: var(--accent); color: #fff;
    padding: 14px 28px; font-weight: 700;
    position: relative; overflow: hidden;
}
.btn-primary:hover { background: var(--accent2); transform: translateY(-2px); box-shadow: 0 8px 28px rgba(217,95,0,.4); }
.btn-outline { border: 1px solid var(--line2); color: var(--muted); padding: 13px 28px; }
.btn-outline:hover { border-color: var(--accent); color: var(--accent); background: var(--accent-bg); }

/* ── TAG (shared chip) ── */
.tag {
    font-family: var(--mono); font-size: .55rem; letter-spacing: .1em;
    text-transform: lowercase; color: var(--dim);
    border: 1px solid var(--line); padding: 3px 8px;
}

/* ── ANIMATIONS ── */
@keyframes fadeUp { from { opacity: 0; transform: translateY(28px); } to { opacity: 1; transform: none; } }

/* ── PROJECT DETAIL PAGE ── */
.detail-hero { height: 55vh; position: relative; overflow: hidden; }
.detail-hero img { width: 100%; height: 100%; object-fit: cover; filter: grayscale(20%) brightness(.9); }
.detail-hero-overlay { position: absolute; inset: 0; background: linear-gradient(to bottom, transparent 30%, var(--bg) 100%); }
.detail-content { max-width: 860px; margin: 0 auto; padding: 0 48px 120px; position: relative; z-index: 2; margin-top: -80px; }
.detail-back { display: inline-block; padding-top: 24px; margin-bottom: 48px; font-family: var(--mono); font-size: .62rem; letter-spacing: .14em; text-transform: lowercase; color: var(--dim); text-decoration: none; transition: color .2s; }
.detail-back:hover { color: var(--text); }
.detail-title { font-family: var(--mono); font-weight: 800; font-size: clamp(3.5rem,9vw,7.5rem); line-height: .88; letter-spacing: -.04em; margin-bottom: 48px; text-transform: lowercase; }
.detail-divider { height: 1px; background: var(--line); margin: 48px 0; }
.detail-field-label { font-family: var(--mono); font-size: .58rem; letter-spacing: .22em; text-transform: lowercase; color: var(--dim); margin-bottom: 16px; }
.detail-description { font-size: .9rem; line-height: 1.85; color: var(--muted); font-weight: 300; }
.detail-tags { display: flex; flex-wrap: wrap; gap: 8px; margin-top: 16px; }
.detail-cta { margin-top: 56px; display: flex; gap: 16px; flex-wrap: wrap; }
.detail-other { margin-top: 100px; padding-top: 48px; border-top: 1px solid var(--line); }
.other-grid { display: grid; grid-template-columns: repeat(auto-fill,minmax(200px,1fr)); gap: 1px; background: var(--line); margin-top: 24px; }
.other-card { background: var(--bg); padding: 28px 24px; text-decoration: none; color: inherit; transition: background .2s; display: block; }
.other-card:hover { background: var(--bg3); }
.other-card-dot { width: 8px; height: 8px; border-radius: 50%; margin-bottom: 16px; }
.other-card-name { font-family: var(--mono); font-weight: 700; font-size: 1.4rem; line-height: 1; letter-spacing: -.02em; color: var(--text); margin-bottom: 8px; text-transform: lowercase; }
.other-card-desc { font-size: .75rem; color: var(--dim); line-height: 1.5; }
.detail-hero-glow { position: absolute; bottom: 0; left: 50%; transform: translateX(-50%); width: 500px; height: 220px; opacity: .07; filter: blur(90px); border-radius: 50%; pointer-events: none; }
.detail-header-block { display: flex; align-items: center; justify-content: space-between; margin-bottom: 16px; }
.detail-header-meta { display: flex; align-items: center; gap: 16px; }
.detail-accent-line { width: 40px; height: 2px; flex-shrink: 0; }
.detail-info-grid { display: grid; grid-template-columns: 1fr 280px; gap: 60px; align-items: start; margin: 40px 0 0; }
.detail-info-sidebar { display: flex; flex-direction: column; gap: 36px; padding-top: 4px; }
.detail-sidebar-section { border-left: 1px solid var(--line); padding-left: 24px; }
.detail-status-badge { display: inline-flex; align-items: center; gap: 8px; border: 1px solid rgba(0,0,0,.1); padding: 6px 14px; }
.detail-status-dot { width: 6px; height: 6px; border-radius: 50%; background: var(--status-color,var(--accent)); animation: pulseStatus 2.2s ease-in-out infinite; flex-shrink: 0; }
.detail-status-text { font-family: var(--mono); font-size: .6rem; letter-spacing: .16em; text-transform: lowercase; color: var(--status-color,var(--accent)); }
@keyframes pulseStatus { 0%,100%{opacity:1} 50%{opacity:.6} }
.detail-status-full { display: flex; align-items: center; gap: 10px; margin-top: 12px; }
@media (max-width: 760px) {
    .detail-info-grid { grid-template-columns: 1fr; gap: 36px; }
    .detail-sidebar-section { border-left: none; padding-left: 0; border-top: 1px solid var(--line); padding-top: 24px; }
    .detail-header-block { flex-direction: column; align-items: flex-start; gap: 14px; }
}
@media (max-width: 900px) { .detail-content { padding: 0 24px 80px; } }

/* ── INDEX PAGE ── */
:root{
    --paper:#fbf6eb;
    --ink:#120d08;
    --orange:#d95f00;
    --og2:#f28a2e;
    --green:#219b63;
    --ls:rgba(42,24,10,.10);
    --lm:rgba(42,24,10,.18);
    --lh:rgba(42,24,10,.30);
}
html{scroll-padding-top:100px}
body{position:relative;z-index:1}
.m-intro{position:fixed;inset:0;z-index:1000;pointer-events:none;overflow:hidden}
.m-intro-fill{position:absolute;inset:0;background:var(--ink);transform-origin:bottom;animation:mFillUp .72s cubic-bezier(.76,0,.24,1) 0s forwards}
.m-intro-wordmark{position:absolute;bottom:clamp(24px,5vw,72px);left:clamp(16px,4vw,56px);font-family:var(--display);font-weight:800;line-height:.82;letter-spacing:-.05em;font-size:clamp(52px,9vw,140px);color:var(--paper);overflow:hidden}
.m-intro-wordmark span,.m-intro-wordmark b{display:block;overflow:hidden}
.m-intro-wordmark span span,.m-intro-wordmark b span{display:block;transform:translateY(110%);animation:mWordUp .54s cubic-bezier(.2,.75,.16,1) forwards}
.m-intro-wordmark b span{color:var(--orange);animation-delay:.12s}
.m-intro-line{position:absolute;bottom:clamp(24px,5vw,72px);right:clamp(16px,4vw,56px);width:1px;height:0;background:rgba(251,246,235,.22);animation:mLineGrow .6s ease .08s forwards}
@keyframes mFillUp{0%{transform:scaleY(1)}60%{transform:scaleY(1)}100%{transform:scaleY(0)}}
@keyframes mWordUp{to{transform:translateY(0)}}
@keyframes mLineGrow{to{height:clamp(60px,10vh,120px)}}
.m-intro.gone{display:none}
.m-main{position:relative;z-index:2;padding-top:96px}
.m-w{width:100%;max-width:100vw;min-width:0;padding-inline:clamp(16px,4vw,56px);overflow:hidden}
.m-section{padding:clamp(72px,11vh,128px) 0}
.m-section+.m-section{border-top:1px solid var(--ls)}
.m-hero-logo-wrap{position:relative;display:flex;align-items:center;justify-content:center;min-width:0;max-width:100%;flex-shrink:0;opacity:0;transform:translateX(48px)}
.m-hero-logo-wrap::before,.m-hero-logo-wrap::after{content:'';position:absolute;border-radius:50%;pointer-events:none;z-index:0}
.m-hero-logo-wrap::before{inset:-48px;background:radial-gradient(circle,rgba(217,95,0,.18) 0%,rgba(217,95,0,.06) 45%,transparent 70%);animation:mGlowPulse 3.5s ease-in-out infinite}
.m-hero-logo-wrap::after{inset:-88px;background:radial-gradient(circle,rgba(255,140,40,.10) 0%,rgba(217,95,0,.04) 50%,transparent 68%);animation:mGlowPulse 3.5s ease-in-out infinite .8s}
@keyframes mGlowPulse{0%,100%{opacity:.6;transform:scale(.95)}50%{opacity:1;transform:scale(1.04)}}
.m-logomark-big{position:relative;z-index:1;width:clamp(280px,32vw,420px);height:clamp(280px,32vw,420px);background:linear-gradient(145deg,#2a1105 0%,#1a0a02 55%,#0e0601 100%);border-radius:22%;display:flex;flex-direction:column;overflow:hidden;box-shadow:0 0 0 1.5px rgba(255,140,40,.18),0 2px 0 rgba(255,200,120,.10) inset,0 28px 70px rgba(10,4,0,.50);transition:transform .5s cubic-bezier(.2,.8,.2,1)}
.m-logomark-big:hover{transform:scale(1.03) rotate(-1.5deg)}
.m-logomark-big-bar{background:rgba(0,0,0,.30);padding:clamp(10px,1.5vw,18px) clamp(14px,1.8vw,22px) clamp(9px,1.2vw,14px);display:flex;gap:clamp(7px,.9vw,11px);align-items:center;flex-shrink:0;border-bottom:1px solid rgba(255,140,40,.12)}
.m-logomark-big-bar i{display:block;width:clamp(11px,1.2vw,15px);height:clamp(11px,1.2vw,15px);border-radius:50%;flex-shrink:0}
.m-logomark-big-bar i:nth-child(1){background:#ff5f57;box-shadow:0 0 8px rgba(255,95,87,.8)}
.m-logomark-big-bar i:nth-child(2){background:#28c840;box-shadow:0 0 8px rgba(40,200,64,.8)}
.m-logomark-big-bar i:nth-child(3){background:#ffbd2e;box-shadow:0 0 8px rgba(255,189,46,.8)}
.m-logomark-big-text{flex:1;display:flex;align-items:center;justify-content:center;font-family:var(--display);font-weight:800;font-size:clamp(90px,12vw,170px);letter-spacing:-.06em;line-height:1;color:#f7f0e6;text-shadow:0 0 50px rgba(217,95,0,.35),0 0 100px rgba(217,95,0,.14)}
.m-hero{width:100%;min-width:0;max-width:100%;min-height:calc(100svh - 96px);display:grid;grid-template-columns:minmax(0,1fr) minmax(0,auto);align-items:center;gap:clamp(32px,5vw,80px);padding:clamp(40px,6vh,80px) 0;position:relative}
.m-hero-left{display:flex;flex-direction:column;align-items:flex-start;min-width:0;max-width:100%}
.m-hero-eyebrow{display:flex;align-items:center;gap:14px;font-size:.6rem;letter-spacing:.22em;color:var(--orange);margin-bottom:20px;opacity:0;transform:translateY(10px)}
.m-hero-eyebrow::before{content:'';width:32px;height:1px;background:var(--orange);opacity:.7;flex-shrink:0}
.m-hero-eyebrow-text{min-width:0;max-width:100%;line-height:1.45;overflow-wrap:break-word}
@media(max-width:900px){.m-hero{grid-template-columns:1fr;min-height:auto;align-items:start}.m-hero-logo-wrap{width:100%;justify-content:flex-start}}
.m-hero-h1{font-family:var(--display);font-weight:800;font-size:clamp(3rem,7.5vw,8.5rem);line-height:.88;letter-spacing:-.048em;margin-bottom:clamp(28px,4vh,48px)}
.m-hero-h1 .m-line{display:block;overflow:hidden;padding:.04em 0}
.m-hero-h1 .m-word{display:block;transform:translateY(115%)}
.m-hero-h1 em{font-style:normal;color:var(--orange)}
.m-hero-foot{display:grid;grid-template-columns:minmax(0,1fr) auto;align-items:end;gap:clamp(24px,4vw,64px);border-top:1px solid var(--lm);padding-top:clamp(20px,3vh,32px);width:100%;min-width:0;max-width:100%}
.m-hero-bio{width:100%;font-size:.9rem;color:var(--muted);line-height:1.88;max-width:44ch;opacity:0;text-align:left;overflow-wrap:break-word}
.m-hero-stats{display:flex;gap:0;flex-shrink:0}
.m-hero-stat{display:flex;flex-direction:column;gap:4px;padding:0 clamp(16px,2.5vw,36px);border-left:1px solid var(--ls)}
.m-hero-stat:first-child{padding-left:0;border-left:0}
.m-stat-n{font-family:var(--display);font-size:clamp(1.6rem,3.5vw,2.8rem);font-weight:800;line-height:1;letter-spacing:-.04em;color:var(--orange)}
.m-stat-l{font-size:.58rem;letter-spacing:.14em;color:var(--muted)}
.m-hero-actions{display:flex;gap:10px;flex-wrap:wrap;margin-top:20px;opacity:0;transform:translateY(12px);justify-content:flex-start}
.m-btn{display:inline-flex;align-items:center;justify-content:center;gap:9px;min-height:44px;padding:12px 22px;font-size:.76rem;letter-spacing:.08em;font-weight:600;border:1.5px solid transparent;cursor:pointer;transition:background .22s,color .22s,border-color .22s,transform .2s,box-shadow .22s;text-decoration:none;line-height:1;font-family:var(--mono)}
.m-btn--ink{background:var(--ink);color:var(--paper);border-color:var(--ink)}
.m-btn--ink:hover{background:var(--orange);border-color:var(--orange);transform:translateY(-2px);box-shadow:0 12px 32px rgba(217,95,0,.28)}
.m-btn--ghost{background:transparent;color:var(--text);border-color:var(--lh)}
.m-btn--ghost:hover{border-color:var(--ink);background:rgba(18,13,8,.05);transform:translateY(-2px)}
.m-avail{display:inline-flex;align-items:center;gap:8px;font-size:.58rem;letter-spacing:.16em;color:var(--muted);margin-top:14px;opacity:0}
.m-avail-dot{width:6px;height:6px;border-radius:50%;background:var(--green);flex-shrink:0;animation:mPulse 2.2s ease infinite}
.m-avail-text{min-width:0}
@keyframes mPulse{0%,100%{box-shadow:0 0 0 0 rgba(33,155,99,.4)}50%{box-shadow:0 0 0 7px rgba(33,155,99,0)}}
.m-sh{display:grid;grid-template-columns:1fr minmax(0,.55fr);gap:clamp(20px,4vw,72px);align-items:start;margin-bottom:clamp(44px,6vw,80px)}
.m-sh-left .m-eyebrow{font-size:.58rem;letter-spacing:.2em;color:var(--orange);margin-bottom:10px;overflow:hidden}
.m-sh-left .m-eyebrow span{display:block;transform:translateX(-100%)}
.m-sh-title{font-family:var(--display);font-size:clamp(2.4rem,5vw,5.5rem);line-height:.9;letter-spacing:-.042em;font-weight:800}
.m-sh-title .m-line{display:block;overflow:hidden;padding:.03em 0}
.m-sh-title .m-word{display:block;transform:translateY(110%)}
.m-sh-body{font-size:.92rem;color:var(--muted);line-height:1.84;max-width:48ch;opacity:0;transform:translateY(14px)}
.m-svc-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:1px;background:var(--lm)}
.m-svc-card{background:var(--paper);padding:clamp(22px,3vw,38px);display:flex;flex-direction:column;gap:12px;position:relative;overflow:hidden;transform:translateY(28px);opacity:0;transition:background .26s,box-shadow .26s}
.m-svc-card::before{content:'';position:absolute;left:0;top:0;bottom:0;width:2px;background:var(--orange);transform:scaleY(0);transform-origin:bottom;transition:transform .4s cubic-bezier(.2,.8,.2,1)}
.m-svc-card:hover{background:rgba(251,246,235,.9);box-shadow:0 16px 52px rgba(42,24,10,.07)}
.m-svc-card:hover::before{transform:scaleY(1)}
.m-svc-num{font-size:.58rem;letter-spacing:.2em;color:var(--orange)}
.m-svc-name{font-family:var(--display);font-size:clamp(1.2rem,2vw,1.6rem);font-weight:700;line-height:1.1;letter-spacing:-.02em}
.m-svc-desc{font-size:.86rem;color:var(--muted);line-height:1.8;flex:1}
.m-svc-for{font-size:.58rem;letter-spacing:.12em;color:var(--muted);border-top:1px solid var(--ls);padding-top:12px;margin-top:auto}
.m-portal{display:grid;grid-template-columns:1fr 1fr;border:1px solid var(--lm)}
.m-portal-l{padding:clamp(28px,5vw,60px);border-right:1px solid var(--lm);transform:translateX(-32px);opacity:0}
.m-portal-r{padding:clamp(28px,5vw,60px);display:flex;flex-direction:column;justify-content:center;gap:16px;transform:translateX(32px);opacity:0}
.m-term{background:var(--ink);border-radius:4px;overflow:hidden;font-size:.76rem;color:var(--paper)}
.m-term-bar{display:flex;gap:6px;padding:10px 14px;border-bottom:1px solid rgba(255,255,255,.08);align-items:center}
.m-term-bar i{width:9px;height:9px;border-radius:50%}
.m-term-bar i:nth-child(1){background:#ff5f57}
.m-term-bar i:nth-child(2){background:#ffbd2e}
.m-term-bar i:nth-child(3){background:#27c93f}
.m-term-title{font-size:.58rem;letter-spacing:.12em;color:rgba(251,246,235,.3);margin-left:8px}
.m-term-body{padding:16px 14px;display:flex;flex-direction:column;gap:9px}
.m-term-row{display:flex;justify-content:space-between;gap:12px;transform:translateX(-12px);opacity:0}
.m-term-row b{color:var(--og2)}
.m-proc{display:grid;grid-template-columns:1fr 1fr;gap:1px;background:var(--lm)}
.m-proc-item{background:var(--paper);padding:clamp(24px,3.5vw,48px);display:grid;grid-template-columns:52px 1fr;gap:20px;align-items:start;transform:translateY(24px);opacity:0}
.m-proc-n{font-family:var(--display);font-size:2.6rem;font-weight:800;line-height:1;color:var(--orange);opacity:.22;transition:opacity .3s}
.m-proc-item:hover .m-proc-n{opacity:.8}
.m-proc-name{font-family:var(--display);font-size:clamp(1rem,2vw,1.4rem);font-weight:700;letter-spacing:-.018em;margin-bottom:6px}
.m-proc-desc{font-size:.84rem;color:var(--muted);line-height:1.78}
.m-calc{display:grid;grid-template-columns:1fr 320px;gap:clamp(24px,4vw,56px);align-items:start}
.m-calc-step{margin-bottom:28px}
.m-calc-lbl{font-size:.6rem;letter-spacing:.18em;color:var(--muted);margin-bottom:12px}
.m-choice-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(185px,1fr));gap:7px}
.m-choice{display:flex;flex-direction:column;gap:4px;padding:13px 15px;background:rgba(251,246,235,.6);border:1.5px solid var(--ls);cursor:pointer;text-align:left;font:inherit;color:inherit;transition:border-color .2s,background .2s;transform:translateY(16px);opacity:0}
.m-choice:hover{border-color:var(--lh)}
.m-choice.active{border-color:var(--orange);background:rgba(217,95,0,.06)}
.m-choice-name{font-family:var(--display);font-weight:700;font-size:.92rem}
.m-choice-desc{font-size:.7rem;color:var(--muted);line-height:1.5}
.m-addon-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(175px,1fr));gap:6px;margin-top:12px}
.m-addon{display:flex;align-items:center;gap:9px;padding:9px 13px;background:rgba(251,246,235,.6);border:1.5px solid var(--ls);cursor:pointer;font-size:.8rem;transition:border-color .2s,background .2s}
.m-addon:hover,.m-addon.checked{border-color:var(--orange);background:rgba(217,95,0,.05)}
.m-addon input{accent-color:var(--orange);flex-shrink:0}
.m-calc-aside{position:sticky;top:140px;background:var(--ink);color:var(--paper);padding:clamp(22px,3vw,34px);display:flex;flex-direction:column;gap:18px;transform:translateX(40px);opacity:0}
.m-res-lbl{font-size:.56rem;letter-spacing:.18em;color:rgba(251,246,235,.45);margin-bottom:4px}
.m-res-val{font-family:var(--display);font-size:clamp(1.9rem,3.6vw,2.8rem);font-weight:800;line-height:1;letter-spacing:-.04em}
.m-res-val.bump{animation:mBump .18s ease}
.m-res-note{font-size:.62rem;color:rgba(251,246,235,.38);margin-top:3px}
.m-divider{height:1px;background:rgba(255,255,255,.08)}
@keyframes mBump{0%{transform:scale(1)}50%{transform:scale(1.04)}100%{transform:scale(1)}}
.m-proj-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(340px,1fr));gap:1px;background:var(--lm)}
.m-proj-card{background:var(--paper);overflow:hidden;display:flex;flex-direction:column;text-decoration:none;color:var(--text);transform:translateY(32px);opacity:0;transition:transform .32s,box-shadow .32s}
.m-proj-card:hover{transform:translateY(-4px);box-shadow:0 22px 64px rgba(42,24,10,.12)}
.m-proj-img{aspect-ratio:16/10;overflow:hidden;position:relative}
.m-proj-img img{width:100%;height:100%;object-fit:cover;transition:transform .55s cubic-bezier(.2,.8,.2,1)}
.m-proj-card:hover .m-proj-img img{transform:scale(1.05)}
.m-proj-accent{position:absolute;inset-inline:0;bottom:0;height:3px;transform:scaleX(0);transform-origin:left;transition:transform .5s cubic-bezier(.2,.8,.2,1)}
.m-proj-card:hover .m-proj-accent{transform:scaleX(1)}
.m-proj-body{padding:clamp(16px,2.5vw,26px);flex:1;display:flex;flex-direction:column;gap:9px}
.m-proj-meta{display:flex;align-items:center;justify-content:space-between;gap:8px}
.m-proj-n{font-size:.56rem;letter-spacing:.14em;color:var(--muted)}
.m-proj-tags{display:flex;gap:5px;flex-wrap:wrap}
.m-proj-tag{font-size:.56rem;letter-spacing:.1em;padding:3px 7px;background:rgba(42,24,10,.07);color:var(--muted)}
.m-proj-name{font-family:var(--display);font-size:clamp(1.1rem,2vw,1.4rem);font-weight:700;letter-spacing:-.018em;line-height:1.1}
.m-proj-desc{font-size:.82rem;color:var(--muted);line-height:1.74;flex:1}
.m-proj-cta{font-size:.68rem;letter-spacing:.1em;color:var(--orange);margin-top:auto;display:flex;align-items:center;gap:6px}
.m-plan-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--lm)}
.m-plan-card{background:var(--paper);padding:clamp(22px,3vw,38px);display:flex;flex-direction:column;gap:13px;transform:translateY(28px);opacity:0}
.m-plan-card--feat{background:var(--ink);color:var(--paper)}
.m-plan-ey{font-size:.56rem;letter-spacing:.2em;color:var(--orange)}
.m-plan-card--feat .m-plan-ey{color:var(--og2)}
.m-plan-name{font-family:var(--display);font-size:1.4rem;font-weight:800;letter-spacing:-.02em}
.m-plan-price{font-family:var(--display);font-size:clamp(2rem,4vw,2.8rem);font-weight:800;line-height:1;color:var(--orange);letter-spacing:-.04em}
.m-plan-card--feat .m-plan-price{color:var(--og2)}
.m-plan-ul{list-style:none;display:flex;flex-direction:column;gap:7px;margin:4px 0}
.m-plan-li{font-size:.82rem;color:var(--muted);padding-left:14px;position:relative;line-height:1.6}
.m-plan-card--feat .m-plan-li{color:rgba(251,246,235,.7)}
.m-plan-li::before{content:'·';position:absolute;left:0;color:var(--orange)}
.m-stack{display:flex;flex-wrap:wrap;gap:7px}
.m-pill{display:inline-flex;align-items:center;gap:8px;padding:8px 13px;background:rgba(251,246,235,.6);border:1px solid var(--ls);font-size:.74rem;letter-spacing:.05em;transform:scale(.9);opacity:0;transition:border-color .22s,background .22s,transform .22s}
.m-pill:hover{border-color:var(--lh);background:rgba(251,246,235,.9);transform:scale(1)!important}
.m-pill img{width:15px;height:15px;object-fit:contain}
.m-faq{display:flex;flex-direction:column;border-top:1px solid var(--lm)}
.m-faq-item{border-bottom:1px solid var(--ls);transform:translateY(16px);opacity:0}
.m-faq-q{display:flex;align-items:center;justify-content:space-between;gap:16px;width:100%;padding:clamp(15px,2vw,20px) 0;font:inherit;color:inherit;background:none;border:none;cursor:pointer;text-align:left;font-family:var(--display);font-size:clamp(.9rem,1.8vw,1.12rem);font-weight:600;letter-spacing:-.01em;transition:color .2s}
.m-faq-q:hover{color:var(--orange)}
.m-faq-icon{width:24px;height:24px;border:1px solid var(--lm);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:1rem;line-height:1;flex-shrink:0;color:var(--muted);transition:transform .3s,border-color .2s,color .2s}
.m-faq-item.open .m-faq-icon{transform:rotate(45deg);border-color:var(--orange);color:var(--orange)}
.m-faq-a{max-height:0;overflow:hidden;transition:max-height .38s cubic-bezier(.4,0,.2,1)}
.m-faq-item.open .m-faq-a{max-height:400px}
.m-faq-a p{font-size:.88rem;color:var(--muted);line-height:1.84;padding-bottom:18px}
.m-contact{display:grid;grid-template-columns:1fr 1fr;gap:clamp(32px,6vw,80px);align-items:start}
.m-contact-lhs{overflow:hidden}
.m-contact-title{font-family:var(--display);font-size:clamp(3rem,7vw,8rem);font-weight:800;line-height:.78;letter-spacing:-.055em;margin:10px 0 20px}
.m-contact-title .m-line{display:block;overflow:hidden;padding:.03em 0}
.m-contact-title .m-word{display:block;transform:translateY(110%)}
.m-contact-sub{font-size:.9rem;color:var(--muted);line-height:1.84;max-width:42ch;opacity:0}
.m-contact-links{display:flex;flex-direction:column;margin-top:28px;border-top:1px solid var(--ls)}
.m-contact-link{display:flex;align-items:center;justify-content:space-between;padding:13px 0;font-family:var(--display);font-size:1rem;font-weight:600;border-bottom:1px solid var(--ls);color:var(--text);text-decoration:none;transition:color .2s,padding-left .22s;transform:translateX(-16px);opacity:0}
.m-contact-link:hover{color:var(--orange);padding-left:7px}
.m-form{display:flex;flex-direction:column;gap:14px;transform:translateX(28px);opacity:0}
.m-field{display:flex;flex-direction:column;gap:5px}
.m-field-row{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.m-lbl{font-size:.58rem;letter-spacing:.16em;color:var(--orange)}
.m-input{width:100%;padding:11px 13px;background:rgba(251,246,235,.6);border:1.5px solid var(--ls);font:inherit;color:var(--text);font-size:.86rem;transition:border-color .2s,background .2s;outline:none}
.m-input:focus{border-color:var(--orange);background:rgba(251,246,235,.9)}
.m-textarea{resize:vertical;min-height:108px}
.m-form-foot{display:flex;align-items:center;gap:14px;flex-wrap:wrap;margin-top:4px}
.m-form-note{font-size:.66rem;color:var(--muted);letter-spacing:.05em}
.m-form-status{font-size:.76rem;color:var(--orange);margin-top:4px}

/* ── COMMERCIAL REFORM COMPONENTS ── */
.m-section--compact{padding:clamp(56px,8vh,96px) 0}
.m-hero-showcase{position:relative;z-index:1;width:min(430px,36vw);min-height:420px;background:linear-gradient(145deg,#2a1105 0%,#160803 58%,#0e0601 100%);border:1px solid rgba(255,140,40,.18);border-radius:34px;padding:18px;box-shadow:0 0 0 1px rgba(251,246,235,.06) inset,0 30px 90px rgba(10,4,0,.38);animation:mFloatSoft 6s ease-in-out infinite}
.m-showcase-top{display:flex;align-items:center;justify-content:space-between;gap:18px;padding-bottom:18px;border-bottom:1px solid rgba(251,246,235,.08)}
.m-showcase-brand{display:flex;align-items:center;gap:10px;min-width:0;flex:1;font-size:.62rem;letter-spacing:.12em;color:rgba(251,246,235,.58)}
.m-showcase-brand span:last-child{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.m-showcase-logo{display:grid;place-items:center;width:38px;height:38px;border-radius:12px;background:var(--orange);color:var(--paper);font-family:var(--display);font-weight:800;font-size:1.05rem;letter-spacing:-.06em}
.m-showcase-status{flex-shrink:0;font-size:.55rem;letter-spacing:.14em;color:#68d391;border:1px solid rgba(104,211,145,.24);border-radius:100px;padding:6px 10px;background:rgba(104,211,145,.08)}
.m-showcase-grid{display:grid;grid-template-columns:minmax(0,1fr) minmax(0,1fr);gap:10px;margin-top:16px}
.m-showcase-panel{min-width:0;min-height:118px;border:1px solid rgba(251,246,235,.09);border-radius:22px;background:rgba(251,246,235,.055);padding:16px;display:flex;flex-direction:column;justify-content:space-between;overflow:hidden}
.m-showcase-panel--wide{grid-column:1/-1;min-height:150px;background:linear-gradient(135deg,rgba(217,95,0,.22),rgba(251,246,235,.05))}
.m-showcase-panel span{font-size:.58rem;letter-spacing:.14em;color:rgba(251,246,235,.46)}
.m-showcase-panel strong{font-family:var(--display);font-size:clamp(1.6rem,3vw,2.8rem);line-height:.9;color:var(--paper);letter-spacing:-.05em;max-width:100%;white-space:nowrap}
.m-showcase-panel--channel strong{font-size:clamp(1.35rem,2.45vw,2.1rem)}
.m-showcase-panel i{display:block;width:100%;height:42px;margin-top:18px;background:linear-gradient(90deg,rgba(251,246,235,.14),rgba(217,95,0,.65),rgba(251,246,235,.12));clip-path:polygon(0 80%,12% 60%,24% 70%,36% 35%,50% 50%,64% 20%,78% 42%,100% 10%)}
.m-showcase-flow{display:flex;align-items:center;gap:10px;justify-content:space-between;margin-top:14px;font-size:.56rem;letter-spacing:.13em;color:rgba(251,246,235,.54)}
.m-showcase-flow b{height:1px;flex:1;background:linear-gradient(90deg,rgba(217,95,0,.2),rgba(217,95,0,.8))}
@keyframes mFloatSoft{0%,100%{transform:translateY(0) rotate(-.6deg)}50%{transform:translateY(-12px) rotate(.6deg)}}
.m-proof-strip{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;min-width:0;background:var(--lm);margin-top:clamp(8px,2vh,24px);margin-bottom:clamp(32px,6vh,72px)}
.m-proof-item{min-width:0;background:rgba(251,246,235,.78);padding:clamp(18px,2.5vw,28px);display:flex;flex-direction:column;gap:8px;min-height:156px;position:relative;overflow:visible;transform:translateY(22px);opacity:0;transition:background .24s,box-shadow .24s}
.m-proof-item:hover{background:rgba(251,246,235,.96);box-shadow:0 16px 46px rgba(42,24,10,.07)}
.m-proof-item span{font-size:.56rem;letter-spacing:.18em;color:var(--orange)}
.m-proof-item strong{font-family:var(--display);font-size:clamp(1.05rem,2vw,1.4rem);line-height:1.05;letter-spacing:-.025em;overflow-wrap:break-word}
.m-proof-item p{font-size:.8rem;color:var(--muted);line-height:1.7;margin-top:auto;overflow-wrap:break-word}
.m-problem-grid,.m-diff-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--lm)}
.m-problem-card,.m-diff-card{background:rgba(251,246,235,.82);padding:clamp(22px,3vw,34px);min-height:210px;display:flex;flex-direction:column;gap:12px;position:relative;overflow:hidden}
.m-problem-card::after,.m-diff-card::after{content:'';position:absolute;inset:auto 18px 18px auto;width:70px;height:70px;border-radius:50%;background:radial-gradient(circle,rgba(217,95,0,.14),transparent 68%);opacity:.75}
.m-problem-card span{font-size:.58rem;letter-spacing:.18em;color:var(--orange)}
.m-problem-card h3,.m-diff-card h3{font-family:var(--display);font-size:clamp(1.08rem,2vw,1.45rem);line-height:1.05;letter-spacing:-.025em}
.m-problem-card p,.m-diff-card p{font-size:.82rem;color:var(--muted);line-height:1.72;margin-top:auto}
.m-solution-band{border:1px solid var(--lm);background:linear-gradient(135deg,rgba(18,13,8,.96),rgba(42,17,5,.94));color:var(--paper);padding:clamp(28px,5vw,58px);display:grid;grid-template-columns:1fr minmax(260px,.6fr) auto;gap:clamp(20px,4vw,44px);align-items:center;overflow:hidden;position:relative}
.m-solution-band::before{content:'';position:absolute;inset:-40% -10% auto auto;width:420px;height:420px;border-radius:50%;background:radial-gradient(circle,rgba(217,95,0,.28),transparent 68%);filter:blur(10px);pointer-events:none}
.m-solution-band h2{position:relative;font-family:var(--display);font-size:clamp(2rem,4.8vw,4.8rem);font-weight:800;line-height:.9;letter-spacing:-.045em;max-width:11ch}
.m-solution-band p{position:relative;font-size:.9rem;line-height:1.8;color:rgba(251,246,235,.68)}
.m-solution-band .m-eyebrow{font-size:.58rem;letter-spacing:.2em;color:var(--og2);margin-bottom:12px}
.m-svc-link{font-size:.62rem;letter-spacing:.1em;color:var(--orange);text-decoration:none;margin-top:2px}
.m-svc-link:hover{text-decoration:underline;text-underline-offset:4px}
.m-diagnostic{display:grid;grid-template-columns:minmax(0,.95fr) minmax(320px,.7fr);gap:1px;background:var(--lm);border:1px solid var(--lm)}
.m-diagnostic-copy,.m-diagnostic-panel{background:rgba(251,246,235,.78);padding:clamp(26px,4.5vw,56px)}
.m-diagnostic-copy{display:flex;flex-direction:column;align-items:flex-start;gap:18px;transform:translateX(-28px);opacity:0}
.m-diagnostic-copy .m-eyebrow{font-size:.58rem;letter-spacing:.2em;color:var(--orange);overflow:hidden}
.m-diagnostic-copy h2{font-family:var(--display);font-size:clamp(2.3rem,5vw,5.1rem);font-weight:800;line-height:.9;letter-spacing:-.045em;max-width:10ch}
.m-diagnostic-copy p{font-size:.9rem;color:var(--muted);line-height:1.82;max-width:54ch}
.m-diagnostic-panel{display:flex;flex-direction:column;justify-content:center;gap:1px;padding:clamp(18px,3vw,34px);transform:translateX(28px);opacity:0}
.m-diagnostic-row{display:grid;grid-template-columns:86px 1fr;gap:18px;align-items:start;background:rgba(18,13,8,.035);padding:clamp(16px,2vw,22px);border:1px solid rgba(42,24,10,.08)}
.m-diagnostic-row span{font-size:.56rem;letter-spacing:.16em;color:var(--orange)}
.m-diagnostic-row strong{font-family:var(--display);font-size:clamp(1rem,2vw,1.28rem);line-height:1.16;letter-spacing:-.02em;font-weight:700;color:var(--text)}

/* Dynamic commercial cards */
.m-sh-title,
.m-svc-name,
.m-proc-name,
.m-proj-name,
.m-plan-name,
.m-plan-price,
.m-faq-q,
.m-contact-title,
.m-proof-item strong,
.m-problem-card h3,
.m-diff-card h3,
.m-diagnostic-copy h2,
.m-diagnostic-row strong,
.m-choice-name,
.m-res-val,
.pmodal-title{
    font-family:var(--brand);
    font-weight:400;
}
.m-sh-title,
.m-contact-title,
.m-diagnostic-copy h2{
    letter-spacing:-.032em;
}
.m-svc-grid,
.m-proof-strip,
.m-problem-grid,
.m-diff-grid,
.m-proc,
.m-proj-grid,
.m-plan-grid{
    background:transparent;
    gap:clamp(12px,2vw,24px);
    align-items:stretch;
}
.m-svc-card,
.m-proof-item,
.m-problem-card,
.m-diff-card,
.m-proc-item,
.m-proj-card,
.m-plan-card,
.m-choice{
    position:relative;
    border:1px solid rgba(42,24,10,.12);
    border-radius:8px;
    background:rgba(251,246,235,.72);
    box-shadow:0 18px 50px rgba(42,24,10,.045);
    transition:border-color .24s,background .24s,box-shadow .28s,translate .28s;
}
.m-svc-card:hover,
.m-proof-item:hover,
.m-problem-card:hover,
.m-diff-card:hover,
.m-proc-item:hover,
.m-proj-card:hover,
.m-plan-card:hover,
.m-choice:hover{
    border-color:rgba(217,95,0,.34);
    background:rgba(251,246,235,.94);
    box-shadow:0 24px 70px rgba(42,24,10,.10);
    translate:0 -4px;
}
.m-svc-card:nth-child(2n),
.m-problem-card:nth-child(2n),
.m-diff-card:nth-child(2n),
.m-proj-card:nth-child(2n){
    margin-top:clamp(14px,2.4vw,32px);
}
.m-svc-card:nth-child(3n),
.m-problem-card:nth-child(3n),
.m-diff-card:nth-child(3n){
    min-height:clamp(240px,24vw,330px);
}
.m-proof-item:nth-child(2){
    margin-top:clamp(16px,2.4vw,28px);
}
.m-proof-item:nth-child(3){
    margin-top:clamp(4px,1.2vw,16px);
}
.m-proc{
    grid-template-columns:1.08fr .92fr;
}
.m-proc-item:nth-child(3n+2){
    margin-top:clamp(16px,2.2vw,30px);
}
.m-proc-item:nth-child(5){
    grid-column:1/-1;
    min-height:180px;
}
.m-plan-card:nth-child(1),
.m-plan-card:nth-child(3){
    margin-top:clamp(18px,2.6vw,38px);
}
.m-plan-card--feat{
    border-color:rgba(217,95,0,.40);
    box-shadow:0 26px 80px rgba(42,24,10,.16);
}
.m-problem-card::after,
.m-diff-card::after{
    border-radius:8px;
    transform:rotate(-8deg);
}
.m-proof-item::before,
.m-proc-item::before,
.m-plan-card::before{
    content:'';
    position:absolute;
    inset:12px 12px auto auto;
    width:44px;
    height:1px;
    background:var(--orange);
    opacity:.34;
    transform:rotate(-18deg);
    transform-origin:right center;
}
.m-proj-card{
    border-radius:8px;
}
.m-proj-card:hover{
    transform:none;
}
.m-portal-r h2{
    font-family:var(--brand)!important;
    font-weight:400!important;
    letter-spacing:-.032em!important;
}
.m-btn,
.m-svc-link,
.m-contact-link,
.pmodal-cta,
.pmodal-btn-close{
    font-family:var(--brand);
    font-weight:400;
    letter-spacing:.01em;
}
.m-btn{
    font-size:.92rem;
    padding:13px 24px;
}

/* Content must be readable without JavaScript. Motion starts only after the
   bootstrap class is present; a timed fallback removes the hidden state. */
.m-hero-logo-wrap,.m-hero-eyebrow,.m-hero-bio,.m-hero-actions,.m-avail,.m-sh-body,.m-proof-item,.m-svc-card,.m-problem-card,.m-diff-card,.m-solution-band,.m-diagnostic-copy,.m-diagnostic-panel,.m-portal-l,.m-portal-r,.m-term-row,.m-proc-item,.m-choice,.m-calc-aside,.m-proj-card,.m-plan-card,.m-pill,.m-faq-item,.m-contact-sub,.m-contact-link,.m-form{opacity:1;transform:none}
.m-hero-h1 .m-word,.m-sh-title .m-word,.m-sh-left .m-eyebrow span,.m-contact-title .m-word{transform:none}
.motion-ready:not(.motion-fallback) .m-hero-logo-wrap{opacity:0;transform:translateX(36px)}
.motion-ready:not(.motion-fallback) .m-hero-eyebrow{opacity:0;transform:translateY(10px)}
.motion-ready:not(.motion-fallback) .m-hero-h1 .m-word{transform:translateY(115%)}
.motion-ready:not(.motion-fallback) .m-hero-bio{opacity:0}
.motion-ready:not(.motion-fallback) .m-hero-actions{opacity:0;transform:translateY(12px)}
.motion-ready:not(.motion-fallback) .m-avail{opacity:0}
.motion-ready:not(.motion-fallback) .m-sh-left .m-eyebrow span{transform:translateX(-100%)}
.motion-ready:not(.motion-fallback) .m-sh-title .m-word{transform:translateY(110%)}
.motion-ready:not(.motion-fallback) .m-sh-body{opacity:0;transform:translateY(14px)}
.motion-ready:not(.motion-fallback) .m-proof-item,.motion-ready:not(.motion-fallback) .m-svc-card,.motion-ready:not(.motion-fallback) .m-problem-card,.motion-ready:not(.motion-fallback) .m-diff-card,.motion-ready:not(.motion-fallback) .m-proc-item,.motion-ready:not(.motion-fallback) .m-proj-card,.motion-ready:not(.motion-fallback) .m-plan-card{opacity:0;transform:translateY(24px)}
.motion-ready:not(.motion-fallback) .m-solution-band,.motion-ready:not(.motion-fallback) .m-diagnostic-panel,.motion-ready:not(.motion-fallback) .m-portal-r,.motion-ready:not(.motion-fallback) .m-calc-aside,.motion-ready:not(.motion-fallback) .m-form{opacity:0;transform:translateX(28px)}
.motion-ready:not(.motion-fallback) .m-diagnostic-copy,.motion-ready:not(.motion-fallback) .m-portal-l{opacity:0;transform:translateX(-28px)}
.motion-ready:not(.motion-fallback) .m-term-row{opacity:0;transform:translateX(-12px)}
.motion-ready:not(.motion-fallback) .m-choice,.motion-ready:not(.motion-fallback) .m-faq-item{opacity:0;transform:translateY(16px)}
.motion-ready:not(.motion-fallback) .m-pill{opacity:0;transform:scale(.9)}
.motion-ready:not(.motion-fallback) .m-contact-title .m-word{transform:translateY(110%)}
.motion-ready:not(.motion-fallback) .m-contact-sub{opacity:0}
.motion-ready:not(.motion-fallback) .m-contact-link{opacity:0;transform:translateX(-16px)}
@keyframes mSlideIn{to{transform:none;opacity:1}}
@keyframes mFadeUp{to{transform:translateY(0);opacity:1}}
@media(max-width:1100px){
    .m-hero{text-align:left;align-items:flex-start}
    .m-hero-foot{grid-template-columns:1fr}
    .m-hero-stats{margin-top:20px}
    .m-sh{grid-template-columns:1fr}
    .m-calc{grid-template-columns:1fr}
    .m-calc-aside{position:relative;top:auto}
    .m-portal,.m-diagnostic{grid-template-columns:1fr}
    .m-portal-l{border-right:0;border-bottom:1px solid var(--lm)}
    .m-plan-grid{grid-template-columns:1fr 1fr}
    .m-contact{grid-template-columns:1fr}
    .m-proc{grid-template-columns:1fr}
    .m-proj-grid{grid-template-columns:1fr 1fr}
    .m-problem-grid,.m-diff-grid{grid-template-columns:1fr 1fr}
    .m-solution-band{grid-template-columns:1fr}
    .m-solution-band h2{max-width:14ch}
    .m-hero-showcase{width:min(430px,42vw)}
}
@media(max-width:900px){
    .m-main{padding-top:92px}
    .m-hero{gap:28px;padding:clamp(28px,6vh,56px) 0 28px}
    .m-hero-logo-wrap{display:flex;width:100%;justify-content:center}
    .m-hero-logo-wrap::before{inset:-28px}
    .m-hero-logo-wrap::after{inset:-52px}
    .m-hero-showcase{width:min(430px,calc(100vw - 48px));min-height:auto;border-radius:28px;padding:16px}
    .m-showcase-panel--channel strong{font-size:1.75rem}
}
@media(max-width:768px){
    .m-main{padding-top:88px}
    .m-section{padding:clamp(48px,8vh,80px) 0}
    .m-svc-grid{grid-template-columns:1fr}
    .m-proc{grid-template-columns:1fr}
    .m-portal{grid-template-columns:1fr}
    .m-portal-l{border-right:0;border-bottom:1px solid var(--lm)}
    .m-hero-stats{gap:0}
    .m-hero-stat{padding:0 clamp(10px,3vw,20px)}
    .xnav-links{display:none}
    .xnav-lang{display:none}
    .m-proof-strip,.m-problem-grid,.m-diff-grid{grid-template-columns:1fr}
    .m-proof-strip{width:calc(100vw - 40px);margin-inline:auto}
    .m-proof-item,.m-problem-card,.m-diff-card{min-height:170px}
    .m-hero-showcase{display:block;width:min(420px,calc(100vw - 48px));max-width:none;border-radius:26px}
    .m-hero-logo-wrap{display:flex;justify-content:center}
    .m-showcase-top{gap:12px;padding-bottom:14px}
    .m-showcase-grid{gap:9px;margin-top:14px}
    .m-showcase-panel{min-height:104px;padding:14px;border-radius:18px}
    .m-showcase-panel--wide{min-height:128px}
    .m-showcase-panel span{font-size:.54rem;line-height:1.35}
    .m-showcase-panel strong{font-size:2rem}
    .m-showcase-panel--channel strong{font-size:1.55rem}
    .m-showcase-panel i{height:34px;margin-top:14px}
    .m-svc-card:nth-child(n),
    .m-proof-item:nth-child(n),
    .m-problem-card:nth-child(n),
    .m-diff-card:nth-child(n),
    .m-proc-item:nth-child(n),
    .m-proj-card:nth-child(n),
    .m-plan-card:nth-child(n){
        margin-top:0;
    }
    .m-svc-card:nth-child(3n),
    .m-problem-card:nth-child(3n),
    .m-diff-card:nth-child(3n),
    .m-proc-item:nth-child(5){
        min-height:auto;
        grid-column:auto;
    }
    .m-intro{display:none}
    .bg-layer canvas{display:none!important}
}
@media(max-width:720px){
    .m-plan-grid{grid-template-columns:1fr}
    .m-proj-grid{grid-template-columns:1fr}
    .m-field-row{grid-template-columns:1fr}
    .m-form-foot{flex-direction:column;align-items:flex-start}
    .m-choice-grid{grid-template-columns:1fr 1fr}
    .m-addon-grid{grid-template-columns:1fr}
    .m-diagnostic-row{grid-template-columns:1fr;gap:7px}
}
@media(max-width:540px){
    .m-hero,.m-hero-left,.m-hero-foot{width:100%;max-width:100%;min-width:0}
    .m-hero-left,.m-hero-foot,.m-hero-h1,.m-hero-bio,.m-hero-eyebrow,.m-hero-actions,.m-hero-stats,.m-avail{width:calc(100vw - 40px);max-width:calc(100vw - 40px)}
    .m-hero-bio{width:calc(100vw - 40px)}
    .m-hero-eyebrow{align-items:flex-start;gap:10px;letter-spacing:.14em}
    .m-hero-eyebrow::before{width:30px;margin-top:.7em}
    .m-hero-actions{width:100%;display:grid;grid-template-columns:1fr;gap:8px}
    .m-hero-actions .m-btn{width:100%}
    .m-hero-stats{width:100%;display:grid;grid-template-columns:1fr;gap:1px;background:var(--lm)}
    .m-hero-stat,.m-hero-stat:first-child{border-left:0;background:rgba(251,246,235,.62);padding:14px 16px}
    .m-choice-grid{grid-template-columns:1fr}
    .m-avail{display:flex;align-items:flex-start;max-width:100%;letter-spacing:.12em}
    .m-avail-text{line-height:1.5;overflow-wrap:break-word}
    .m-hero-showcase{width:calc(100vw - 40px);padding:13px;border-radius:24px}
    .m-showcase-status{width:10px;height:10px;padding:0;border:0;border-radius:50%;font-size:0;background:#68d391;box-shadow:0 0 0 5px rgba(104,211,145,.10)}
    .m-proof-item p{align-self:flex-start;width:31ch;max-width:100%}
}
@media(max-width:480px){
    .m-hero-h1{font-size:clamp(2.8rem,16vw,4.5rem)}
    .m-w{padding-inline:16px}
    .xnav-pill{padding:5px;max-width:calc(100vw - 24px)}
    .xnav-cta span{display:none}
    .m-hero-foot{gap:16px}
    .m-avail{line-height:1.45}
    .m-hero-showcase{width:calc(100vw - 40px);padding:13px;border-radius:24px}
    .m-showcase-logo{width:34px;height:34px;border-radius:10px}
    .m-showcase-brand{gap:8px;font-size:.56rem}
    .m-showcase-status{width:10px;height:10px;padding:0;border:0;border-radius:50%;font-size:0;background:#68d391;box-shadow:0 0 0 5px rgba(104,211,145,.10)}
    .m-showcase-grid{gap:8px}
    .m-showcase-panel{min-height:92px;padding:12px;border-radius:16px}
    .m-showcase-panel--wide{min-height:116px}
    .m-showcase-panel strong{font-size:1.85rem}
    .m-showcase-panel--channel strong{font-size:1.36rem}
    .m-showcase-flow{gap:7px;font-size:.5rem}
    .m-proof-item p{align-self:flex-start;width:31ch;max-width:100%}
    .m-proof-item,.m-svc-card{padding:20px 18px}
    .m-plan-card{padding:24px 20px}
    .m-proc-item{padding:18px 16px}
    .m-contact-title{font-size:clamp(2.2rem,14vw,4rem)}
    .m-solution-band,.m-diagnostic-copy,.m-diagnostic-panel{padding:24px 18px}
    .m-solution-band .m-btn,.m-diagnostic .m-btn{width:100%;justify-content:center}
}
@media(max-width:380px){
    .m-hero-h1{font-size:2.45rem;line-height:.94}
    .m-showcase-panel{padding:10px;min-height:88px}
    .m-showcase-panel strong{font-size:1.65rem}
    .m-showcase-panel--channel strong{font-size:1.18rem}
    .m-showcase-panel span{font-size:.49rem;letter-spacing:.1em}
    .m-showcase-flow{font-size:.48rem}
    .m-proof-item p{width:27ch;max-width:100%}
}
@media(prefers-reduced-motion:reduce){*,*::before,*::after{animation:none!important;transition:none!important;scroll-behavior:auto!important}.m-intro{display:none}.m-hero-logo-wrap,.m-hero-eyebrow,.m-hero-bio,.m-hero-actions,.m-avail,.m-hero-h1 .m-word,.m-sh-title .m-word,.m-sh-left .m-eyebrow span,.m-sh-body,.m-proof-item,.m-svc-card,.m-diagnostic-copy,.m-diagnostic-panel,.m-portal-l,.m-portal-r,.m-term-row,.m-proc-item,.m-choice,.m-calc-aside,.m-proj-card,.m-plan-card,.m-pill,.m-faq-item,.m-contact-title .m-word,.m-contact-sub,.m-contact-link,.m-form{opacity:1!important;transform:none!important}}

/* ── PROJECT MODAL ── */
.m-proj-card{cursor:pointer}
.pmodal-backdrop{position:fixed;inset:0;z-index:10000;background:rgba(17,10,3,.78);display:flex;align-items:center;justify-content:center;padding:20px;opacity:0;pointer-events:none;transition:opacity .28s ease}
.pmodal-backdrop.open{opacity:1;pointer-events:all}
.pmodal{position:relative;background:var(--paper);border:1px solid var(--lm);border-radius:16px;max-width:580px;width:100%;max-height:90vh;overflow-y:auto;box-shadow:0 32px 80px rgba(17,10,3,.28);transform:translateY(16px) scale(.97);transition:transform .32s cubic-bezier(.2,.8,.2,1);scrollbar-width:thin}
.pmodal-backdrop.open .pmodal{transform:none}
.pmodal-close{position:absolute;top:14px;right:14px;z-index:2;background:rgba(17,10,3,.07);border:none;width:32px;height:32px;border-radius:50%;cursor:pointer;font-size:.85rem;color:var(--ink);display:flex;align-items:center;justify-content:center;transition:background .2s}
.pmodal-close:hover{background:rgba(17,10,3,.14)}
.pmodal-img-wrap{position:relative;width:100%;aspect-ratio:16/9;overflow:hidden;border-radius:16px 16px 0 0}
.pmodal-img{width:100%;height:100%;object-fit:cover;display:block}
.pmodal-accent{position:absolute;inset:0;opacity:.18;pointer-events:none}
.pmodal-body{padding:clamp(20px,4vw,32px)}
.pmodal-meta{display:flex;align-items:center;gap:12px;margin-bottom:10px}
.pmodal-type{font-family:var(--mono);font-size:.58rem;letter-spacing:.16em;color:var(--orange);text-transform:uppercase}
.pmodal-year{font-family:var(--mono);font-size:.58rem;letter-spacing:.1em;color:var(--muted)}
.pmodal-title{font-family:var(--display);font-size:clamp(1.6rem,5vw,2.4rem);font-weight:800;letter-spacing:-.04em;line-height:.92;margin-bottom:14px}
.pmodal-desc{font-size:.88rem;line-height:1.72;color:var(--muted);margin-bottom:20px}
.pmodal-techs{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:24px}
.pmodal-tag{font-family:var(--mono);font-size:.6rem;letter-spacing:.1em;padding:5px 10px;border:1px solid var(--lm);border-radius:100px;color:var(--muted)}
.pmodal-actions{display:flex;align-items:center;gap:10px;flex-wrap:wrap}
.pmodal-cta{display:inline-flex;align-items:center;gap:6px;font-family:var(--mono);font-size:.68rem;letter-spacing:.08em;text-decoration:none;background:var(--ink);color:var(--paper);padding:11px 20px;border-radius:100px;transition:background .2s,transform .2s}
.pmodal-cta:hover{background:var(--orange);transform:translateY(-1px)}
.pmodal-btn-close{font-family:var(--mono);font-size:.68rem;letter-spacing:.08em;background:none;border:1px solid var(--lm);color:var(--muted);padding:11px 20px;border-radius:100px;cursor:pointer;transition:border-color .2s,color .2s}
.pmodal-btn-close:hover{border-color:var(--ink);color:var(--ink)}
@media(max-width:480px){.pmodal-actions{flex-direction:column;align-items:stretch}.pmodal-cta,.pmodal-btn-close{text-align:center;justify-content:center}}
