/* ============================================
   EMANOEL PERES — Global Stylesheet
   Fonts: Bricolage Grotesque (display) + Geist Mono (body)
   ============================================ */

/* ── TOKENS ── */
:root {
    --bg:        #f5efe4;
    --bg2:       #ede4d6;
    --bg3:       #e3d7c5;

    --text:      #2e1d0b;
    --muted:     rgba(41,25,9,.70);
    --dim:       rgba(87,57,30,.44);

    --accent:    #d95f00;
    --accent2:   #f07020;
    --accent-bg: rgba(217,95,0,.10);

    --line:      rgba(42,24,10,.10);
    --line2:     rgba(42,24,10,.18);

    --mono:    'Geist Mono','JetBrains Mono',monospace;
    --display: 'Bricolage Grotesque',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); }

/* ── SCROLL PROGRESS ── */
.scroll-progress {
    position: fixed; top: 0; left: 0;
    width: 0%; height: 2px;
    background: var(--accent);
    z-index: 200;
    transition: width .1s linear;
    box-shadow: 0 0 8px rgba(217,95,0,.4);
    pointer-events: none;
}

/* ── BACKGROUND BLOBS ── */
.bg-layer {
    position: fixed; inset: 0; z-index: 0;
    overflow: hidden; pointer-events: none;
    background: #f5ebe0;
}
.bg-blob {
    position: absolute;
    border-radius: 50%;
    filter: blur(72px);
    opacity: .55;
    will-change: transform;
}
.bg-blob--1 {
    width: 720px; height: 720px;
    background: radial-gradient(circle, #e8c49a 0%, #d4956a 60%, transparent 100%);
    top: -18%; left: -12%;
    animation: blob1 18s ease-in-out infinite;
}
.bg-blob--2 {
    width: 600px; height: 600px;
    background: radial-gradient(circle, #f0d0a0 0%, #c8804a 65%, transparent 100%);
    top: 30%; right: -14%;
    animation: blob2 22s ease-in-out infinite;
}
.bg-blob--3 {
    width: 500px; height: 500px;
    background: radial-gradient(circle, #fce4b8 0%, #e8a060 70%, transparent 100%);
    bottom: -10%; left: 25%;
    animation: blob3 20s ease-in-out infinite;
}
.bg-blob--4 {
    width: 440px; height: 440px;
    background: radial-gradient(circle, #f5d4a8 0%, #d4884c 60%, transparent 100%);
    top: 55%; left: -8%;
    animation: blob4 25s ease-in-out infinite;
}
.bg-blob--5 {
    width: 560px; height: 560px;
    background: radial-gradient(circle, #fce8c4 0%, #d4904e 55%, transparent 100%);
    top: 10%; left: 40%;
    animation: blob5 19s ease-in-out infinite;
}
.bg-cursor {
    position: absolute;
    width: 600px; height: 600px;
    border-radius: 50%;
    background: radial-gradient(circle, rgba(217,95,0,.16) 0%, transparent 68%);
    transform: translate(-50%, -50%);
    pointer-events: none;
    transition: left .12s ease, top .12s ease;
    left: 50%; top: 35%;
    filter: blur(8px);
}
@keyframes blob1 {
    0%,100% { transform: translate(0,0) scale(1); }
    33%      { transform: translate(6%,8%) scale(1.08); }
    66%      { transform: translate(-4%,5%) scale(.94); }
}
@keyframes blob2 {
    0%,100% { transform: translate(0,0) scale(1); }
    40%      { transform: translate(-7%,-6%) scale(1.10); }
    70%      { transform: translate(4%,8%) scale(.92); }
}
@keyframes blob3 {
    0%,100% { transform: translate(0,0) scale(1); }
    30%      { transform: translate(8%,-5%) scale(1.06); }
    65%      { transform: translate(-5%,6%) scale(.96); }
}
@keyframes blob4 {
    0%,100% { transform: translate(0,0) scale(1); }
    45%      { transform: translate(9%,-8%) scale(1.12); }
    75%      { transform: translate(-3%,4%) scale(.90); }
}
@keyframes blob5 {
    0%,100% { transform: translate(0,0) scale(1); }
    35%      { transform: translate(-6%,7%) scale(1.07); }
    68%      { transform: translate(5%,-4%) scale(.95); }
}

/* ── 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(245,239,228,.72);
    backdrop-filter: blur(28px); -webkit-backdrop-filter: blur(28px);
    border: 1px solid rgba(42,24,10,.10);
    border-radius: 100px;
    box-shadow: 0 4px 32px rgba(42,24,10,.08), 0 1px 0 rgba(255,255,255,.6) inset;
    transition: background .3s, box-shadow .3s;
}
.xnav-pill:hover {
    background: rgba(245,239,228,.88);
    box-shadow: 0 8px 40px rgba(42,24,10,.13), 0 1px 0 rgba(255,255,255,.6) inset;
}
.xnav.scrolled .xnav-pill {
    background: rgba(245,239,228,.95);
    box-shadow: 0 8px 48px rgba(42,24,10,.16), 0 1px 0 rgba(255,255,255,.7) inset;
}
/* 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); }

/* ── 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{padding-inline:clamp(16px,4vw,56px)}
.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;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{min-height:calc(100svh - 96px);display:grid;grid-template-columns: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}
.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}
@media(max-width:900px){.m-hero{grid-template-columns:1fr}.m-hero-logo-wrap{display:none}}
.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:1fr auto;align-items:end;gap:clamp(24px,4vw,64px);border-top:1px solid var(--lm);padding-top:clamp(20px,3vh,32px);width:100%}
.m-hero-bio{font-size:.9rem;color:var(--muted);line-height:1.88;max-width:44ch;opacity:0;text-align:left}
.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;gap:9px;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}
@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}
@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{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}}
@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}}
@media(max-width:480px){.m-hero-h1{font-size:clamp(3.2rem,18vw,5rem)}}
@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-svc-card,.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}}
