/* =================================================================
   AStudyo — style.css
   Single-page agency website stylesheet
   Sections: Global → 02 Metrics → 03 Tiers → 04 Work →
             05 Stack → 06 Process → 07 Showcase →
             07.5 Portal → 08 Contact
================================================================= */

/* ─────────────────────────────────────────────────────────────
   GLOBAL — reset, CSS variables, custom cursor, nav, hero, canvas, noise overlay, word-swap animation, keyframes
───────────────────────────────────────────────────────────── */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

  :root {
    --lime: #C8FF00;
    --lime-dim: rgba(200,255,0,0.12);
    --lime-glow: rgba(200,255,0,0.06);
    --bg: #080808;
    --bg2: #0f0f0f;
    --text: #f0f0ee;
    --muted: rgba(240,240,238,0.45);
    --border: rgba(240,240,238,0.08);
    --font-display: 'Syne', sans-serif;
    --font-mono: 'DM Mono', monospace;
  }

  html { scroll-behavior: smooth; width: 100%; overflow-x: clip; }

  body {
    background: var(--bg);
    color: var(--text);
    font-family: var(--font-display);
    width: 100%;
    overflow-x: clip;
    cursor: auto;
  }

  img, svg, video { max-width: 100%; }

  /* Custom cursor */
  .cursor {
    position: fixed;
    width: 10px;
    height: 10px;
    background: var(--lime);
    border-radius: 50%;
    pointer-events: none;
    z-index: 9999;
    transform: translate(-50%, -50%);
    transition: width 0.2s, height 0.2s, opacity 0.2s;
    mix-blend-mode: difference;
  }
  .cursor-ring {
    position: fixed;
    width: 36px;
    height: 36px;
    border: 1px solid var(--lime);
    border-radius: 50%;
    pointer-events: none;
    z-index: 9998;
    transform: translate(-50%, -50%);
    opacity: 0.4;
    transition: width 0.35s ease, height 0.35s ease, opacity 0.35s ease;
  }
  body:has(a:hover) .cursor-ring,
  body:has(button:hover) .cursor-ring { width: 56px; height: 56px; opacity: 0.7; }

  /* NAV */
  nav {
    position: fixed;
    top: 0; left: 0; right: 0;
    z-index: 100;
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 28px 48px;
    mix-blend-mode: normal;
  }
  nav::after {
    content: '';
    position: absolute;
    inset: 0;
    background: linear-gradient(to bottom, rgba(8,8,8,0.9) 0%, transparent 100%);
    z-index: -1;
    pointer-events: none;
  }
  .nav-logo {
    font-family: var(--font-display);
    font-size: 20px;
    font-weight: 800;
    letter-spacing: -0.03em;
    color: var(--text);
    text-decoration: none;
  }
  .nav-logo span { color: var(--lime); }
  .nav-right { display: flex; align-items: center; gap: 40px; }
  .nav-links { display: flex; gap: 32px; list-style: none; }
  .nav-links a {
    font-family: var(--font-mono);
    font-size: 12px;
    font-weight: 400;
    color: var(--muted);
    text-decoration: none;
    letter-spacing: 0.04em;
    transition: color 0.2s;
  }
  .nav-links a:hover { color: var(--text); }
  .nav-cta {
    font-family: var(--font-mono);
    font-size: 12px;
    font-weight: 500;
    color: var(--bg);
    background: var(--lime);
    border: none;
    padding: 10px 22px;
    border-radius: 2px;
    cursor: none;
    letter-spacing: 0.05em;
    text-transform: uppercase;
    transition: opacity 0.2s, transform 0.2s;
    text-decoration: none;
    display: inline-block;
  }
  .nav-cta:hover { opacity: 0.85; transform: translateY(-1px); }

  /* CANVAS — hero-scoped only */
  #bg-canvas {
    position: absolute;
    inset: 0;
    z-index: 0;
    opacity: 1;
    pointer-events: none;
  }

  /* HERO */
  .hero {
    position: relative;
    overflow: hidden;
    z-index: 1;
    min-height: 100vh;
    display: flex;
    flex-direction: column;
    justify-content: center;
    padding: 0 48px;
    padding-top: 100px;
  }

  .hero-kicker {
    font-family: var(--font-mono);
    font-size: 11px;
    font-weight: 400;
    color: var(--lime);
    letter-spacing: 0.18em;
    text-transform: uppercase;
    margin-bottom: 28px;
    opacity: 0;
    transform: translateY(12px);
    animation: fadeUp 0.7s 0.2s forwards;
    display: flex;
    align-items: center;
    gap: 12px;
  }
  .hero-kicker::before {
    content: '';
    display: block;
    width: 32px;
    height: 1px;
    background: var(--lime);
  }

  .hero-headline {
    font-size: clamp(52px, 8.5vw, 128px);
    font-weight: 800;
    line-height: 0.92;
    letter-spacing: -0.04em;
    max-width: 900px;
    opacity: 0;
    transform: translateY(20px);
    animation: fadeUp 0.8s 0.4s forwards;
  }
  .hero-headline .line2 {
    display: block;
    color: var(--muted);
  }
  .hero-headline .word-swap {
    display: inline-block;
    color: var(--lime);
    position: relative;
    min-width: 4ch;
  }

  .hero-sub {
    margin-top: 40px;
    font-family: var(--font-mono);
    font-size: 14px;
    color: var(--muted);
    line-height: 1.7;
    max-width: 420px;
    opacity: 0;
    transform: translateY(16px);
    animation: fadeUp 0.8s 0.65s forwards;
  }

  .hero-actions {
    margin-top: 52px;
    display: flex;
    align-items: center;
    gap: 32px;
    opacity: 0;
    transform: translateY(16px);
    animation: fadeUp 0.8s 0.85s forwards;
  }
  .btn-primary {
    font-family: var(--font-mono);
    font-size: 13px;
    font-weight: 500;
    color: var(--bg);
    background: var(--lime);
    border: none;
    padding: 16px 36px;
    border-radius: 2px;
    cursor: none;
    letter-spacing: 0.06em;
    text-transform: uppercase;
    transition: opacity 0.2s, transform 0.2s;
    text-decoration: none;
  }
  .btn-primary:hover { opacity: 0.88; transform: translateY(-2px); }
  .btn-ghost {
    font-family: var(--font-mono);
    font-size: 12px;
    color: var(--muted);
    text-decoration: none;
    letter-spacing: 0.06em;
    display: flex;
    align-items: center;
    gap: 8px;
    transition: color 0.2s;
  }
  .btn-ghost:hover { color: var(--text); }
  .btn-ghost .arrow { transition: transform 0.2s; }
  .btn-ghost:hover .arrow { transform: translateX(4px); }

  /* HERO BOTTOM */
  .hero-bottom {
    position: absolute;
    bottom: 36px;
    left: 48px;
    right: 48px;
    display: flex;
    align-items: flex-end;
    justify-content: space-between;
    opacity: 0;
    animation: fadeIn 1s 1.4s forwards;
  }
  .hero-domain {
    font-family: var(--font-mono);
    font-size: 11px;
    color: var(--muted);
    letter-spacing: 0.1em;
  }
  .scroll-hint {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 8px;
  }
  .scroll-line {
    width: 1px;
    height: 48px;
    background: linear-gradient(to bottom, transparent, var(--lime));
    animation: scrollPulse 2s ease-in-out infinite;
  }
  .scroll-label {
    font-family: var(--font-mono);
    font-size: 10px;
    color: var(--muted);
    letter-spacing: 0.15em;
    text-transform: uppercase;
    writing-mode: vertical-lr;
  }

  /* NOISE OVERLAY */
  .noise {
    position: fixed;
    inset: 0;
    z-index: 2;
    pointer-events: none;
    opacity: 0.028;
    background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
    background-size: 180px;
  }

  /* WORD SWAP ANIMATION */
  .word-swap { overflow: hidden; vertical-align: bottom; }
  .word-inner {
    display: inline-block;
    animation: none;
  }
  .word-enter { animation: wordIn 0.45s cubic-bezier(0.22,1,0.36,1) forwards; }
  .word-exit { animation: wordOut 0.3s ease-in forwards; }

  /* KEYFRAMES */
  @keyframes fadeUp {
    to { opacity: 1; transform: translateY(0); }
  }
  @keyframes fadeIn {
    to { opacity: 1; }
  }
  @keyframes scrollPulse {
    0%, 100% { opacity: 0.3; transform: scaleY(1); }
    50% { opacity: 1; transform: scaleY(1.08); }
  }
  @keyframes wordIn {
    from { opacity: 0; transform: translateY(60%); }
    to { opacity: 1; transform: translateY(0); }
  }
  @keyframes wordOut {
    from { opacity: 1; transform: translateY(0); }
    to { opacity: 0; transform: translateY(-60%); }
  }


/* ─────────────────────────────────────────────────────────────
   SECTION 02 — Metrics strip (count-up stats, progress bars, footnote)
───────────────────────────────────────────────────────────── */
/* ── METRICS ── */
  .metrics {
    position: relative;
    z-index: 3;
    background: var(--bg2);
    border-top: 1px solid var(--border);
    border-bottom: 1px solid var(--border);
    padding: 80px 48px;
    overflow: hidden;
  }
  .metrics::before {
    content: '';
    position: absolute;
    top: 0; left: 50%; transform: translateX(-50%);
    width: 600px; height: 1px;
    background: linear-gradient(to right, transparent, var(--lime), transparent);
    opacity: 0.35;
  }

  .metrics-inner {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0;
    max-width: 1200px;
    margin: 0 auto;
  }

  .metric-divider {
    width: 1px;
    height: 80px;
    background: var(--border);
    flex-shrink: 0;
  }

  .metric-item {
    flex: 1;
    text-align: center;
    padding: 0 32px;
    opacity: 0;
    transform: translateY(24px);
    transition: opacity 0.6s ease, transform 0.6s ease;
  }
  .metric-item.visible {
    opacity: 1;
    transform: translateY(0);
  }
  .metric-item:nth-child(1)  { transition-delay: 0.0s; }
  .metric-item:nth-child(3)  { transition-delay: 0.1s; }
  .metric-item:nth-child(5)  { transition-delay: 0.2s; }
  .metric-item:nth-child(7)  { transition-delay: 0.3s; }
  .metric-item:nth-child(9)  { transition-delay: 0.4s; }

  .metric-num {
    font-family: var(--font-display);
    font-size: clamp(42px, 5vw, 72px);
    font-weight: 800;
    letter-spacing: -0.04em;
    color: var(--lime);
    line-height: 1;
    margin-bottom: 10px;
    display: flex;
    align-items: baseline;
    justify-content: center;
    gap: 1px;
  }
  .metric-suffix {
    font-size: 0.45em;
    font-weight: 600;
    opacity: 0.75;
    letter-spacing: 0;
  }

  .metric-bar {
    width: 40px;
    height: 2px;
    background: var(--border);
    margin: 12px auto;
    border-radius: 99px;
    overflow: hidden;
  }
  .metric-bar-fill {
    height: 100%;
    width: 0%;
    background: var(--lime);
    border-radius: 99px;
    transition: width 1.4s cubic-bezier(0.16,1,0.3,1);
  }
  .metric-item.visible .metric-bar-fill { width: 100%; }

  .metric-label {
    font-family: var(--font-mono);
    font-size: 11px;
    font-weight: 400;
    color: var(--muted);
    letter-spacing: 0.08em;
    text-transform: uppercase;
    margin-top: 4px;
  }

  .metrics-footnote {
    display: flex;
    align-items: center;
    gap: 16px;
    justify-content: center;
    margin-top: 52px;
    opacity: 0;
    transition: opacity 0.8s 0.6s ease;
  }
  .metrics-footnote.visible { opacity: 1; }
  .fn-line {
    flex: 1;
    max-width: 120px;
    height: 1px;
    background: var(--border);
  }
  .fn-text {
    font-family: var(--font-mono);
    font-size: 10px;
    color: rgba(240,240,238,0.2);
    letter-spacing: 0.1em;
    white-space: nowrap;
  }


/* ─────────────────────────────────────────────────────────────
   SECTION 03 — Capability tiers (3-column card grid, descriptor pills, hover states)
───────────────────────────────────────────────────────────── */
/* ── TIERS ── */
  .tiers {
    position: relative;
    z-index: 3;
    background: var(--bg);
    padding: 120px 48px;
    overflow: hidden;
  }
  .tiers::before {
    content: '';
    position: absolute;
    top: 50%; left: 50%;
    transform: translate(-50%, -50%);
    width: 600px; height: 600px;
    background: radial-gradient(circle, rgba(200,255,0,0.03) 0%, transparent 70%);
    pointer-events: none;
  }
  .tiers-header {
    max-width: 1200px;
    margin: 0 auto 72px;
    display: grid;
    grid-template-columns: auto 1fr auto;
    align-items: end;
    gap: 32px;
  }
  .section-tag {
    font-family: var(--font-mono);
    font-size: 11px;
    color: var(--lime);
    letter-spacing: 0.14em;
    text-transform: uppercase;
    align-self: start;
    padding-top: 6px;
  }
  .tiers-title {
    font-family: var(--font-display);
    font-size: clamp(36px, 5vw, 68px);
    font-weight: 800;
    letter-spacing: -0.04em;
    line-height: 0.95;
    color: var(--text);
  }
  .tiers-sub {
    font-family: var(--font-mono);
    font-size: 13px;
    color: var(--muted);
    line-height: 1.7;
    max-width: 260px;
    text-align: right;
  }

  /* Grid */
  .tiers-grid {
    max-width: 1200px;
    margin: 0 auto;
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 1px;
    background: var(--border);
    border: 1px solid var(--border);
    border-radius: 4px;
    overflow: hidden;
  }

  /* Card base — all identical */
  .tier-card {
    background: var(--bg);
    padding: 0 36px 36px;
    position: relative;
    opacity: 0;
    transform: translateY(32px);
    cursor: none;
    overflow: hidden;
  }
  .tier-card.visible {
    opacity: 1;
    transform: translateY(0);
    transition: opacity 0.65s ease, transform 0.65s ease;
  }
  .tier-card:nth-child(1).visible { transition-delay: 0s; }
  .tier-card:nth-child(2).visible { transition-delay: 0.12s; }
  .tier-card:nth-child(3).visible { transition-delay: 0.24s; }

  /* Hover state — lime tint bg */
  .tier-card:hover { background: rgba(200,255,0,0.03); }

  /* Green top bar — slides in on hover */
  .tier-top-bar {
    position: absolute;
    top: 0; left: 0; right: 0;
    height: 2px;
    background: var(--lime);
    transform: scaleX(0);
    transform-origin: left;
    transition: transform 0.35s cubic-bezier(0.16,1,0.3,1);
  }
  .tier-card:hover .tier-top-bar { transform: scaleX(1); }

  /* Descriptor pills container — sits above tier-top */
  .tier-descriptors {
    display: flex;
    gap: 6px;
    flex-wrap: wrap;
    padding-top: 28px;
    margin-bottom: 20px;
    min-height: 52px;
    align-items: flex-start;
  }

  /* Each descriptor pill */
  .td-pill {
    font-family: var(--font-mono);
    font-size: 10px;
    font-weight: 500;
    letter-spacing: 0.07em;
    text-transform: uppercase;
    padding: 4px 10px;
    border-radius: 2px;
    border: 1px solid rgba(200,255,0,0.18);
    color: rgba(200,255,0,0.45);
    background: rgba(200,255,0,0.04);

    /* Hidden by default */
    opacity: 0;
    transform: translateY(8px);
    transition:
      opacity 0.3s ease,
      transform 0.3s ease,
      border-color 0.2s,
      color 0.2s,
      background 0.2s;
  }

  /* Stagger each pill on card hover */
  .tier-card:hover .td-pill:nth-child(1) {
    opacity: 1; transform: translateY(0);
    transition-delay: 0s;
  }
  .tier-card:hover .td-pill:nth-child(2) {
    opacity: 1; transform: translateY(0);
    transition-delay: 0.07s;
  }
  .tier-card:hover .td-pill:nth-child(3) {
    opacity: 1; transform: translateY(0);
    transition-delay: 0.14s;
  }

  /* Pills get brighter on hover */
  .tier-card:hover .td-pill {
    border-color: rgba(200,255,0,0.45);
    color: rgba(200,255,0,0.85);
    background: rgba(200,255,0,0.07);
  }

  /* Rest of card elements */
  .tier-top {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    margin-bottom: 24px;
  }
  .tier-index {
    font-family: var(--font-mono);
    font-size: 11px;
    color: rgba(240,240,238,0.2);
    letter-spacing: 0.1em;
  }
  .tier-complexity { text-align: right; }
  .cx-label {
    font-family: var(--font-mono);
    font-size: 9px;
    color: rgba(240,240,238,0.2);
    letter-spacing: 0.1em;
    text-transform: uppercase;
    display: block;
    margin-bottom: 5px;
  }
  .cx-dots { display: flex; gap: 4px; justify-content: flex-end; }
  .cx-dot {
    width: 6px; height: 6px;
    border-radius: 50%;
    background: var(--border);
    border: 1px solid rgba(240,240,238,0.12);
    transition: background 0.25s, border-color 0.25s;
  }
  .cx-dot.active { background: rgba(200,255,0,0.5); border-color: rgba(200,255,0,0.5); }
  .tier-card:hover .cx-dot.active { background: var(--lime); border-color: var(--lime); }

  .tier-name {
    font-family: var(--font-display);
    font-size: clamp(26px, 2.6vw, 38px);
    font-weight: 800;
    letter-spacing: -0.03em;
    line-height: 1.05;
    color: var(--text);
    margin-bottom: 16px;
  }
  .tier-desc {
    font-family: var(--font-mono);
    font-size: 12px;
    color: var(--muted);
    line-height: 1.75;
    margin-bottom: 28px;
  }
  .tier-examples {
    list-style: none;
    margin-bottom: 28px;
    display: flex;
    flex-direction: column;
    gap: 8px;
  }
  .tier-examples li {
    font-family: var(--font-mono);
    font-size: 12px;
    color: rgba(240,240,238,0.6);
    padding-left: 16px;
    position: relative;
  }
  .tier-examples li::before {
    content: '→';
    position: absolute;
    left: 0;
    color: var(--lime);
    font-size: 10px;
  }

  /* Stack tags — turn lime on hover */
  .tier-stack { display: flex; flex-wrap: wrap; gap: 6px; margin-bottom: 28px; }
  .stack-tag {
    font-family: var(--font-mono);
    font-size: 10px;
    color: rgba(240,240,238,0.35);
    border: 1px solid var(--border);
    padding: 3px 8px;
    border-radius: 2px;
    letter-spacing: 0.04em;
    transition: color 0.25s, border-color 0.25s, background 0.25s;
  }
  .tier-card:hover .stack-tag {
    color: rgba(200,255,0,0.8);
    border-color: rgba(200,255,0,0.3);
    background: rgba(200,255,0,0.05);
  }

  .tier-timeline {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding-top: 20px;
    border-top: 1px solid var(--border);
  }
  .tl-label {
    font-family: var(--font-mono);
    font-size: 10px;
    color: rgba(240,240,238,0.2);
    letter-spacing: 0.08em;
    text-transform: uppercase;
  }
  .tl-val {
    font-family: var(--font-mono);
    font-size: 12px;
    font-weight: 500;
    color: var(--lime);
    letter-spacing: 0.04em;
  }

  .tiers-footer { max-width: 1200px; margin: 40px auto 0; text-align: center; }
  .tf-text { font-family: var(--font-mono); font-size: 13px; color: var(--muted); }
  .tf-link { font-family: var(--font-mono); font-size: 13px; color: var(--lime); text-decoration: none; transition: opacity 0.2s; }
  .tf-link:hover { opacity: 0.7; }


/* ─────────────────────────────────────────────────────────────
   SECTION 04 — Work showcase (sticky label column, horizontal scroll track, project cards, browser mockups)
───────────────────────────────────────────────────────────── */
.work{position:relative;z-index:3;background:var(--bg2);border-top:1px solid var(--border);}
  .work-sticky{display:flex;min-height:100dvh;overflow:hidden;}
  /* Label col — fixed 280px, never scrolls */
  .work-label-col{position:sticky;top:0;height:100dvh;width:280px;min-width:280px;display:flex;flex-direction:column;justify-content:center;padding:60px 36px;border-right:1px solid var(--border);background:var(--bg2);z-index:2;}
  .work-title{font-family:var(--font-display);font-size:clamp(34px,3.5vw,54px);font-weight:800;letter-spacing:-0.04em;line-height:0.95;color:var(--text);margin:16px 0 36px;}
  .work-nav{display:flex;align-items:center;gap:12px;margin-bottom:20px;}
  .wnav-btn{width:34px;height:34px;border:1px solid var(--border);background:transparent;color:var(--muted);border-radius:2px;cursor:none;display:flex;align-items:center;justify-content:center;transition:border-color 0.2s,color 0.2s,background 0.2s;flex-shrink:0;}
  .wnav-btn:hover{border-color:var(--lime);color:var(--lime);background:rgba(200,255,0,0.05);}
  .wnav-progress{flex:1;display:flex;align-items:center;gap:8px;}
  .wnav-current,.wnav-total{font-family:var(--font-mono);font-size:11px;color:var(--muted);min-width:16px;}
  .wnav-current{color:var(--lime);}
  .wnav-track{flex:1;height:1px;background:var(--border);border-radius:99px;overflow:hidden;}
  .wnav-fill{height:100%;background:var(--lime);border-radius:99px;transition:width 0.4s cubic-bezier(0.16,1,0.3,1);width:16.7%;}
  .work-drag-hint{font-family:var(--font-mono);font-size:10px;color:rgba(240,240,238,0.2);letter-spacing:0.08em;}
  /* Track wrap: fills remaining width, scrolls horizontally */
  .work-track-wrap{flex:1;overflow-x:auto;overflow-y:hidden;scrollbar-width:none;cursor:grab;position:relative;}
.work-track-wrap{touch-action:pan-y;}
  .work-track-wrap{-webkit-overflow-scrolling:touch;overscroll-behavior-x:contain;}
  .work-track-wrap:active{cursor:grabbing;}
  .work-track-wrap::-webkit-scrollbar{display:none;}
  /* Track: cards sit inline, padding makes first/last card centerable */
  .work-track{display:flex;min-height:100dvh;align-items:center;}
  /* Cards: 420px wide, gap via margin */
  .work-card{flex-shrink:0;width:420px;margin-right:32px;display:flex;flex-direction:column;gap:20px;opacity:0.32;transform:scale(0.95);transition:opacity 0.45s ease,transform 0.45s ease;}
  .work-card.active-card{opacity:1;transform:scale(1);}
  .wcard-screen{background:#111;border:1px solid var(--border);border-radius:6px;overflow:hidden;}
  .wcard-browser-bar{display:flex;align-items:center;gap:5px;padding:9px 12px;background:#0d0d0d;border-bottom:1px solid var(--border);}
  .wbb-dot{width:8px;height:8px;border-radius:50%;}
  .wbb-dot:nth-child(1){background:#ff5f57;}.wbb-dot:nth-child(2){background:#febc2e;}.wbb-dot:nth-child(3){background:#28c840;}
  .wbb-url{font-family:var(--font-mono);font-size:10px;color:rgba(240,240,238,0.22);margin-left:8px;letter-spacing:0.03em;}
  .wcard-mockup{height:210px;overflow:hidden;position:relative;}
  .wm-line{height:6px;border-radius:3px;background:rgba(240,240,238,0.1);}
  .w15{width:15%}.w20{width:20%}.w25{width:25%}.w30{width:30%}.w35{width:35%}.w40{width:40%}.w45{width:45%}.w50{width:50%}.w55{width:55%}.w60{width:60%}.w70{width:70%}.w75{width:75%}.w80{width:80%}.w90{width:90%}
  .wm-streaming{display:flex;background:#0a0a12;}
  .wm-sidebar{width:44px;background:#080810;border-right:1px solid rgba(255,255,255,0.05);display:flex;flex-direction:column;align-items:center;padding:12px 0;gap:18px;}
  .wm-logo-mark{width:22px;height:22px;background:var(--lime);border-radius:3px;}
  .wm-nav-items{display:flex;flex-direction:column;gap:12px;}
  .wm-nav-item{width:18px;height:3px;border-radius:2px;background:rgba(255,255,255,0.1);}
  .wm-nav-item.active{background:var(--lime);}
  .wm-main{flex:1;overflow:hidden;display:flex;flex-direction:column;}
  .wm-hero-banner{height:100px;background:linear-gradient(135deg,#1a0a2e,#0d1a3a);display:flex;align-items:flex-end;padding:12px;}
  .wm-banner-text{display:flex;flex-direction:column;gap:5px;}
  .wm-play-btn{width:26px;height:16px;background:var(--lime);border-radius:2px;margin-top:5px;}
  .wm-row-label{padding:5px 8px 3px;}
  .wm-thumb-row{display:flex;gap:5px;padding:0 8px;}
  .wm-thumb{flex:1;height:32px;border-radius:2px;}
  .t1{background:#1a2a4a}.t2{background:#2a1a3a}.t3{background:#1a3a2a}.t4{background:#3a2a1a}.t5{background:#2a3a1a}
  .wm-fintech{background:#080f08;padding:12px;display:flex;flex-direction:column;gap:8px;}
  .wm-topbar{display:flex;align-items:center;gap:8px;}
  .wm-fintech-bal{font-family:var(--font-mono);font-size:12px;font-weight:500;color:var(--lime);flex:1;text-align:center;}
  .wm-avatar{width:20px;height:20px;border-radius:50%;background:rgba(200,255,0,0.2);}
  .wm-chart-area{flex:1;min-height:70px;}
  .wm-cards-row{display:flex;gap:5px;}
  .wm-fin-card{flex:1;background:rgba(255,255,255,0.04);border:1px solid rgba(255,255,255,0.06);border-radius:3px;padding:7px;}
  .wm-fin-num{font-family:var(--font-mono);font-size:10px;font-weight:500;margin-top:4px;}
  .wm-fin-num.positive{color:var(--lime);}.wm-fin-num.negative{color:#ff6b6b;}
  .wm-market{background:#0f0f0f;padding:10px;display:flex;flex-direction:column;gap:8px;}
  .wm-mkt-header{display:flex;align-items:center;gap:7px;}
  .wm-search-bar{flex:1;height:18px;background:rgba(255,255,255,0.05);border:1px solid var(--border);border-radius:2px;}
  .wm-mkt-grid{display:grid;grid-template-columns:1fr 1fr;gap:6px;flex:1;}
  .wm-mkt-item{background:rgba(255,255,255,0.03);border:1px solid var(--border);border-radius:3px;overflow:hidden;}
  .wm-mkt-img{height:55px;}
  .mi1 .wm-mkt-img{background:linear-gradient(135deg,#1a2a3a,#2a3a4a);}
  .mi2 .wm-mkt-img{background:linear-gradient(135deg,#2a1a3a,#3a2a4a);}
  .mi3 .wm-mkt-img{background:linear-gradient(135deg,#1a3a2a,#2a4a3a);}
  .mi4 .wm-mkt-img{background:linear-gradient(135deg,#3a2a1a,#4a3a2a);}
  .wm-ai{background:#080808;padding:12px;display:flex;flex-direction:column;gap:8px;}
  .wm-ai-top{display:flex;align-items:center;justify-content:space-between;}
  .wm-ai-badge{font-family:var(--font-mono);font-size:9px;background:rgba(200,255,0,0.12);color:var(--lime);padding:2px 7px;border-radius:99px;letter-spacing:0.1em;}
  .wm-ai-chat{flex:1;display:flex;flex-direction:column;gap:7px;}
  .wm-msg{padding:7px 9px;border-radius:4px;max-width:85%;}
  .wm-msg-in{background:rgba(255,255,255,0.05);align-self:flex-start;}
  .wm-msg-out{background:rgba(200,255,0,0.08);border:1px solid rgba(200,255,0,0.18);align-self:flex-end;}
  .wm-msg.typing{display:flex;align-items:center;gap:4px;padding:9px;}
  .wm-msg.typing span{width:5px;height:5px;border-radius:50%;background:var(--lime);opacity:0.4;animation:typingDot 1.2s infinite;}
  .wm-msg.typing span:nth-child(2){animation-delay:0.2s;}.wm-msg.typing span:nth-child(3){animation-delay:0.4s;}
  @keyframes typingDot{0%,80%,100%{opacity:0.2;transform:translateY(0)}40%{opacity:1;transform:translateY(-3px)}}
  .wm-ai-input{display:flex;align-items:center;gap:7px;background:rgba(255,255,255,0.04);border:1px solid var(--border);border-radius:3px;padding:7px 9px;}
  .wm-send-btn{width:18px;height:18px;background:var(--lime);border-radius:2px;flex-shrink:0;margin-left:auto;}
  .wm-edu{background:#090909;padding:12px;display:flex;flex-direction:column;gap:8px;}
  .wm-edu-hero{background:rgba(200,255,0,0.04);border:1px solid rgba(200,255,0,0.08);border-radius:3px;padding:12px;}
  .wm-prog-track{height:3px;background:var(--border);border-radius:99px;overflow:hidden;margin-top:5px;}
  .wm-prog-fill{height:100%;background:var(--lime);border-radius:99px;}
  .wm-edu-modules{display:flex;flex-direction:column;gap:6px;}
  .wm-edu-mod{display:flex;align-items:center;gap:9px;padding:6px 9px;background:rgba(255,255,255,0.02);border-radius:2px;}
  .wm-edu-mod.done{background:rgba(200,255,0,0.03);}
  .wm-edu-mod.active-mod{background:rgba(200,255,0,0.07);border:1px solid rgba(200,255,0,0.12);}
  .wm-mod-check{width:14px;height:14px;border-radius:50%;background:var(--lime);color:#080808;font-size:7px;font-weight:700;display:flex;align-items:center;justify-content:center;flex-shrink:0;}
  .wm-mod-dot{width:7px;height:7px;border-radius:50%;flex-shrink:0;margin:0 3.5px;}
  .wm-mod-dot.lime{background:var(--lime);}.wm-mod-dot.muted{background:var(--border);}
  .wm-logistics{background:#0a100a;position:relative;height:100%;}
  .wm-map-bg{width:100%;height:100%;position:relative;}
  .wm-log-panel{position:absolute;bottom:10px;right:10px;background:rgba(8,8,8,0.88);border:1px solid rgba(200,255,0,0.18);border-radius:3px;padding:9px 11px;}
  .wm-log-stat{display:flex;align-items:center;gap:7px;margin-top:4px;}
  .wm-log-num{font-family:var(--font-mono);font-size:13px;font-weight:500;color:rgba(240,240,238,0.65);min-width:32px;}
  .wm-log-num.lime-txt{color:var(--lime);}
  .wcard-info{}
  .wcard-tags{display:flex;gap:5px;margin-bottom:10px;flex-wrap:wrap;}
  .wtag{font-family:var(--font-mono);font-size:10px;color:var(--lime);border:1px solid rgba(200,255,0,0.22);padding:3px 7px;border-radius:2px;letter-spacing:0.05em;text-transform:uppercase;}
  .wcard-name{font-family:var(--font-display);font-size:26px;font-weight:800;letter-spacing:-0.03em;color:var(--text);margin-bottom:9px;line-height:1;}
  .wcard-challenge{font-family:var(--font-mono);font-size:12px;color:var(--muted);line-height:1.7;margin-bottom:14px;}
  .wc-label{color:var(--lime);font-weight:500;}
  .wcard-meta{display:flex;gap:24px;padding-top:12px;border-top:1px solid var(--border);}
  .wm-stat{display:flex;flex-direction:column;gap:3px;}
  .wms-val{font-family:var(--font-display);font-size:19px;font-weight:800;letter-spacing:-0.03em;color:var(--text);line-height:1;}
  .wms-label{font-family:var(--font-mono);font-size:10px;color:var(--muted);letter-spacing:0.05em;}


/* ─────────────────────────────────────────────────────────────
   SECTION 05 — Tech stack (layered grid, category labels, stack item hover, tooltip)
───────────────────────────────────────────────────────────── */
.stack-section{position:relative;z-index:3;background:var(--bg);border-top:1px solid var(--border);padding:120px 48px;}
  .stack-inner{max-width:1200px;margin:0 auto;}
  .stack-header{display:grid;grid-template-columns:auto 1fr auto;align-items:end;gap:32px;margin-bottom:80px;}
  .stack-title{font-family:var(--font-display);font-size:clamp(36px,4.5vw,64px);font-weight:800;letter-spacing:-0.04em;line-height:0.95;color:var(--text);}
  .stack-sub{font-family:var(--font-mono);font-size:12px;color:var(--muted);line-height:1.7;max-width:240px;text-align:right;}

  .stack-layers{display:flex;flex-direction:column;gap:0;}
  .stack-layer{border-top:1px solid var(--border);padding:32px 0;opacity:0;transform:translateY(20px);transition:opacity 0.6s ease,transform 0.6s ease;}
  .stack-layer.visible{opacity:1;transform:translateY(0);}
  .stack-layer:nth-child(1).visible{transition-delay:0s;}
  .stack-layer:nth-child(2).visible{transition-delay:0.1s;}
  .stack-layer:nth-child(3).visible{transition-delay:0.2s;}
  .stack-layer:nth-child(4).visible{transition-delay:0.3s;}
  .stack-layer:nth-child(5).visible{transition-delay:0.4s;}

  .layer-label{display:flex;align-items:center;gap:14px;margin-bottom:20px;}
  .layer-num{font-family:var(--font-mono);font-size:10px;color:rgba(240,240,238,0.18);letter-spacing:0.1em;}
  .layer-name{font-family:var(--font-mono);font-size:11px;font-weight:500;color:var(--lime);letter-spacing:0.12em;text-transform:uppercase;white-space:nowrap;}
  .layer-line{flex:1;height:1px;background:var(--border);}

  .stack-grid{display:flex;flex-wrap:wrap;gap:8px;}

  .stack-item{
    display:flex;align-items:center;gap:10px;
    padding:10px 14px;
    border:1px solid var(--border);
    border-radius:4px;
    background:var(--bg2);
    cursor:none;
    transition:border-color 0.2s,background 0.2s,transform 0.2s;
    position:relative;
  }
  .stack-item:hover{
    border-color:rgba(200,255,0,0.35);
    background:#111;
    transform:translateY(-2px);
  }
  .stack-item:hover .si-name{color:var(--text);}

  .si-icon{width:28px;height:28px;flex-shrink:0;display:flex;align-items:center;justify-content:center;}
  .si-icon svg{width:100%;height:100%;}

  .si-name{font-family:var(--font-mono);font-size:11px;color:var(--muted);letter-spacing:0.04em;white-space:nowrap;transition:color 0.2s;}

  /* Tooltip */
  .stack-tooltip{
    position:fixed;
    background:#111;
    border:1px solid rgba(200,255,0,0.25);
    border-radius:3px;
    padding:5px 10px;
    font-family:var(--font-mono);
    font-size:11px;
    color:var(--lime);
    letter-spacing:0.04em;
    pointer-events:none;
    z-index:9990;
    opacity:0;
    transition:opacity 0.15s;
    white-space:nowrap;
  }


/* ─────────────────────────────────────────────────────────────
   SECTION 06 — Process timeline (vertical spine, phase dots, phase cards, scroll-driven reveal)
───────────────────────────────────────────────────────────── */
.process{position:relative;z-index:3;background:var(--bg2);border-top:1px solid var(--border);padding:120px 48px;}
  .process-inner{max-width:1100px;margin:0 auto;}

  .process-header{display:grid;grid-template-columns:auto 1fr auto;align-items:end;gap:32px;margin-bottom:96px;}
  .process-title{font-family:var(--font-display);font-size:clamp(36px,4.5vw,64px);font-weight:800;letter-spacing:-0.04em;line-height:0.95;color:var(--text);}
  .process-sub{font-family:var(--font-mono);font-size:12px;color:var(--muted);line-height:1.7;max-width:240px;text-align:right;}

  .process-body{position:relative;padding-left:60px;}

  /* Spine */
  .spine-track{position:absolute;left:19px;top:0;bottom:0;width:1px;background:var(--border);}
  .spine-fill{position:absolute;top:0;left:0;width:100%;background:var(--lime);height:0%;transition:height 0.1s linear;}

  /* Phase row */
  .phase{display:grid;grid-template-columns:180px 1fr;gap:48px;margin-bottom:72px;position:relative;}
  .phase:last-child{margin-bottom:0;}

  .phase-left{display:flex;align-items:flex-start;gap:20px;padding-top:28px;}

  .phase-dot-wrap{
    position:absolute;
    left:-60px;
    top:28px;
    width:40px;
    height:40px;
    display:flex;align-items:center;justify-content:center;
  }
  .phase-dot{
    width:10px;height:10px;border-radius:50%;
    background:var(--border);
    border:1px solid rgba(240,240,238,0.15);
    transition:background 0.4s,border-color 0.4s,box-shadow 0.4s;
  }
  .phase.active .phase-dot{
    background:var(--lime);
    border-color:var(--lime);
    box-shadow:0 0 12px rgba(200,255,0,0.5);
  }

  .phase-num-block{display:flex;flex-direction:column;gap:4px;}
  .phase-num{font-family:var(--font-mono);font-size:11px;color:rgba(240,240,238,0.2);letter-spacing:0.1em;}
  .phase-name{font-family:var(--font-display);font-size:18px;font-weight:700;letter-spacing:-0.02em;color:rgba(240,240,238,0.3);transition:color 0.4s;}
  .phase.active .phase-name{color:var(--text);}

  /* Phase card */
  .phase-right{opacity:0;transform:translateX(20px);transition:opacity 0.55s ease,transform 0.55s ease;}
  .phase.active .phase-right{opacity:1;transform:translateX(0);}

  .phase-card{
    background:var(--bg);
    border:1px solid var(--border);
    border-radius:4px;
    padding:32px 36px;
    position:relative;
    transition:border-color 0.4s;
  }
  .phase.active .phase-card{border-color:rgba(240,240,238,0.12);}

  .phase-card-featured{background:#0c0c0c;}
  .phase-card-featured::before{content:'';position:absolute;top:0;left:0;right:0;height:2px;background:var(--lime);border-radius:2px 2px 0 0;}

  .phase-featured-bar{display:none;}

  .phase-duration{
    font-family:var(--font-mono);font-size:10px;
    color:var(--lime);letter-spacing:0.12em;text-transform:uppercase;
    margin-bottom:14px;
    opacity:0.7;
  }
  .phase-title{
    font-family:var(--font-display);font-size:clamp(18px,1.8vw,24px);
    font-weight:700;letter-spacing:-0.02em;line-height:1.2;
    color:var(--text);margin-bottom:12px;
  }
  .phase-desc{
    font-family:var(--font-mono);font-size:12px;color:var(--muted);
    line-height:1.8;margin-bottom:24px;
  }

  .phase-deliverables{margin-bottom:20px;}
  .deliv-label{
    font-family:var(--font-mono);font-size:10px;color:rgba(240,240,238,0.25);
    letter-spacing:0.1em;text-transform:uppercase;display:block;margin-bottom:10px;
  }
  .deliv-list{list-style:none;display:grid;grid-template-columns:1fr 1fr;gap:6px 24px;}
  .deliv-list li{
    font-family:var(--font-mono);font-size:12px;color:rgba(240,240,238,0.55);
    padding-left:14px;position:relative;
  }
  .deliv-list li::before{content:'→';position:absolute;left:0;color:var(--lime);font-size:10px;}

  .phase-tag-row{display:flex;flex-wrap:wrap;gap:6px;}
  .phase-tag{
    font-family:var(--font-mono);font-size:10px;
    color:rgba(240,240,238,0.3);
    border:1px solid var(--border);
    padding:3px 9px;border-radius:2px;
    letter-spacing:0.04em;
    transition:color 0.3s,border-color 0.3s;
  }
  .phase.active .phase-tag{color:rgba(240,240,238,0.55);border-color:rgba(240,240,238,0.12);}


/* ─────────────────────────────────────────────────────────────
   SECTION 07 — Previous work showcase (project tabs, browser window, screen mockups per project, info panel)
───────────────────────────────────────────────────────────── */
.showcase{position:relative;z-index:3;background:var(--bg);border-top:1px solid var(--border);padding:120px 48px;}

  .showcase-header{max-width:1200px;margin:0 auto 64px;display:flex;align-items:flex-end;gap:48px;}
  .showcase-title{font-family:var(--font-display);font-size:clamp(36px,4.5vw,64px);font-weight:800;letter-spacing:-0.04em;line-height:0.95;color:var(--text);}

  .showcase-body{max-width:1200px;margin:0 auto;display:flex;flex-direction:column;gap:0;}

  /* TABS */
  .proj-tabs{display:flex;border-bottom:1px solid var(--border);margin-bottom:48px;overflow-x:auto;overflow-y:hidden;scrollbar-width:none;flex-wrap:nowrap;touch-action:pan-x;-webkit-overflow-scrolling:touch;overscroll-behavior-x:contain;}
  .proj-tabs::-webkit-scrollbar{display:none;}
  .proj-tab{
    display:flex;flex-direction:column;gap:3px;
    padding:16px 24px;
    background:transparent;border:none;
    border-bottom:2px solid transparent;
    cursor:none;text-align:left;
    white-space:nowrap;
    transition:border-color 0.2s,background 0.2s;
    margin-bottom:-1px;
  }
  .proj-tab{flex:0 0 auto;}
  .proj-tab:hover{background:rgba(255,255,255,0.02);}
  .proj-tab.active{border-bottom-color:var(--lime);}
  .pt-num{font-family:var(--font-mono);font-size:10px;color:rgba(240,240,238,0.2);letter-spacing:0.08em;}
  .pt-name{font-family:var(--font-display);font-size:14px;font-weight:700;color:var(--muted);letter-spacing:-0.01em;transition:color 0.2s;}
  .proj-tab.active .pt-name,.proj-tab:hover .pt-name{color:var(--text);}
  .pt-cat{font-family:var(--font-mono);font-size:10px;color:rgba(240,240,238,0.2);letter-spacing:0.04em;}
  .proj-tab.active .pt-cat{color:var(--lime);}

  /* STAGE */
  .showcase-stage{display:grid;grid-template-columns:1fr 360px;gap:48px;align-items:start;}

  /* BROWSER */
  .proj-browser{background:#111;border:1px solid var(--border);border-radius:8px;overflow:hidden;}
  .browser-chrome{display:flex;align-items:center;gap:0;padding:12px 16px;background:#0d0d0d;border-bottom:1px solid var(--border);}
  .bc-dots{display:flex;gap:6px;margin-right:14px;}
  .bc-dots span{width:10px;height:10px;border-radius:50%;}
  .bc-dots span:nth-child(1){background:#ff5f57;}
  .bc-dots span:nth-child(2){background:#febc2e;}
  .bc-dots span:nth-child(3){background:#28c840;}
  .bc-bar{flex:1;display:flex;align-items:center;gap:6px;background:rgba(255,255,255,0.05);border:1px solid var(--border);border-radius:4px;padding:5px 10px;margin:0 12px;}
  .bc-lock{color:rgba(240,240,238,0.3);display:flex;align-items:center;}
  .bc-url{font-family:var(--font-mono);font-size:11px;color:rgba(240,240,238,0.35);letter-spacing:0.03em;}
  .bc-actions{display:flex;gap:8px;}
  .bc-dot-sm{width:16px;height:16px;border-radius:2px;background:rgba(255,255,255,0.06);}

  .browser-viewport{
    position:relative;
    overflow:hidden;
    aspect-ratio: 16 / 10;
    height:auto;
    min-height:320px;
    max-height:540px;
  }
  .proj-screen{position:absolute;inset:0;opacity:0;transition:opacity 0.5s ease;pointer-events:none;}
  .proj-screen.active{opacity:1;pointer-events:auto;}

  /* ── GoGlobal ── */
  /* GoGlobal — red · white · gold */
  .ps-goglobal{background:#fff;height:100%;display:flex;flex-direction:column;}
  .gg-nav{display:flex;align-items:center;justify-content:space-between;padding:14px 20px;background:#fff;border-bottom:1px solid #f0e0e0;}
  .gg-logo{font-family:var(--font-display);font-size:14px;font-weight:800;color:#c0152a;letter-spacing:-0.02em;}
  .gg-links{display:flex;gap:8px;align-items:center;}
  .gg-link{height:6px;border-radius:3px;background:#f0e0e0;width:40px;}
  .gg-link.cta{background:#c0152a;width:60px;height:26px;border-radius:4px;}
  .gg-hero{padding:28px 20px 16px;flex:1;background:#fff;}
  .gg-badge{display:inline-block;font-family:var(--font-mono);font-size:9px;background:#fdf3d0;color:#9a6c00;border:1px solid #e8c84a;padding:3px 8px;border-radius:99px;letter-spacing:0.08em;margin-bottom:12px;}
  .gg-h1{font-family:var(--font-display);font-size:22px;font-weight:800;color:#c0152a;line-height:1.15;margin-bottom:12px;}
  .gg-sub-line{height:5px;border-radius:3px;background:#f0e0e0;margin-bottom:7px;width:80%;}
  .gg-sub-line.w60{width:60%;}
  .gg-btns{display:flex;gap:8px;margin-top:16px;}
  .gg-btn-p{background:#c0152a;color:white;font-family:var(--font-mono);font-size:11px;padding:8px 16px;border-radius:4px;}
  .gg-btn-s{border:1px solid #e8c84a;color:#9a6c00;font-family:var(--font-mono);font-size:11px;padding:8px 16px;border-radius:4px;}
  .gg-cards{display:flex;gap:10px;padding:0 20px 16px;}
  .gg-card{background:#fff;border:1px solid #f0e0e0;border-top:2px solid #e8c84a;border-radius:6px;padding:14px;flex:1;display:flex;flex-direction:column;gap:7px;}
  .gg-card-icon{font-size:18px;}
  .gg-card-line{height:5px;border-radius:3px;background:#f0e0e0;width:90%;}
  .gg-card-line.w70{width:70%;}
  .gg-card-line.w55{width:55%;}
  .gg-card-line.w65{width:65%;}

  /* ── HookahPalace ── */
  .ps-hookah{background:#0a0608;height:100%;display:flex;flex-direction:column;}
  .hp-nav{display:flex;align-items:center;justify-content:space-between;padding:14px 20px;border-bottom:1px solid rgba(255,255,255,0.06);}
  .hp-logo{font-family:var(--font-display);font-size:12px;font-weight:800;color:#c9a96e;letter-spacing:0.12em;}
  .hp-logo span{color:rgba(201,169,110,0.5);}
  .hp-links{display:flex;gap:10px;}
  .hp-link{height:4px;border-radius:2px;background:rgba(255,255,255,0.1);width:35px;}
  .hp-hero{flex:1;position:relative;display:flex;align-items:center;justify-content:center;background:linear-gradient(to bottom,#100a0e,#0a0608);}
  .hp-smoke{position:absolute;inset:0;background:radial-gradient(ellipse at 50% 80%,rgba(180,120,60,0.08) 0%,transparent 70%);pointer-events:none;}
  .hp-center{text-align:center;z-index:1;}
  .hp-eyebrow{font-family:var(--font-mono);font-size:9px;color:#c9a96e;letter-spacing:0.2em;text-transform:uppercase;margin-bottom:10px;opacity:0.7;}
  .hp-h1{font-family:var(--font-display);font-size:26px;font-weight:800;color:#f5e6c8;line-height:1.1;margin-bottom:14px;letter-spacing:-0.02em;}
  .hp-cta{display:inline-block;border:1px solid #c9a96e;color:#c9a96e;font-family:var(--font-mono);font-size:10px;padding:8px 18px;letter-spacing:0.1em;text-transform:uppercase;}
  .hp-products{display:flex;gap:8px;padding:14px 16px;background:#080406;border-top:1px solid rgba(255,255,255,0.05);}
  .hp-prod{flex:1;display:flex;flex-direction:column;gap:6px;}
  .hp-prod-img{height:70px;border-radius:3px;}
  .hp1{background:linear-gradient(135deg,#2a1a0a,#3d2510);}
  .hp2{background:linear-gradient(135deg,#1a1a2a,#2a1a3a);}
  .hp3{background:linear-gradient(135deg,#0a1a1a,#0f2a2a);}
  .hp4{background:linear-gradient(135deg,#2a0a1a,#3a0f25);}
  .hp-prod-line{height:4px;border-radius:2px;background:rgba(255,255,255,0.07);}
  .hp-prod-price{font-family:var(--font-mono);font-size:10px;color:#c9a96e;letter-spacing:0.04em;}

  /* ── Altezza Cento ── */
  .ps-altezza{background:#f7f5f0;height:100%;display:flex;flex-direction:column;}
  .ac-nav{display:flex;align-items:center;justify-content:space-between;padding:14px 20px;background:#f7f5f0;border-bottom:1px solid #e8e4dc;}
  .ac-logo{font-family:var(--font-display);font-size:12px;font-weight:700;color:#1a1612;letter-spacing:0.1em;text-transform:uppercase;}
  .ac-logo em{font-style:italic;font-weight:400;color:#8b7355;}
  .ac-links{display:flex;gap:10px;}
  .ac-link{height:4px;border-radius:2px;background:#d4c9b0;width:36px;}
  .ac-hero{flex:1;display:grid;grid-template-columns:1fr 1fr;gap:0;}
  .ac-img-block{display:grid;grid-template-rows:1fr auto;gap:6px;padding:12px 6px 12px 12px;}
  .ac-img-main{background:linear-gradient(160deg,#e8dcc8,#d4c5a9);border-radius:3px;flex:1;}
  .ac-img-side{background:linear-gradient(160deg,#c9b89a,#b8a07e);border-radius:3px;height:60px;}
  .ac-text-block{padding:24px 16px 16px 10px;display:flex;flex-direction:column;justify-content:center;gap:10px;}
  .ac-eyebrow{font-family:var(--font-mono);font-size:8px;color:#8b7355;letter-spacing:0.15em;text-transform:uppercase;}
  .ac-h1{font-family:var(--font-display);font-size:18px;font-weight:700;color:#1a1612;line-height:1.2;letter-spacing:-0.02em;}
  .ac-line{height:4px;border-radius:2px;background:#d4c9b0;}
  .ac-line.w75{width:75%;}
  .ac-cta{font-family:var(--font-mono);font-size:9px;color:#8b7355;letter-spacing:0.08em;margin-top:4px;}
  .ac-cats{display:flex;gap:0;border-top:1px solid #e8e4dc;}
  .ac-cat{flex:1;border-right:1px solid #e8e4dc;display:flex;flex-direction:column;overflow:hidden;}
  .ac-cat:last-child{border-right:none;}
  .ac-cat-img{height:50px;}
  .ac1{background:linear-gradient(135deg,#d4c5a9,#c9b48a);}
  .ac2{background:linear-gradient(135deg,#c5b89a,#b8a07e);}
  .ac3{background:linear-gradient(135deg,#bfb090,#b09878);}
  .ac4{background:linear-gradient(135deg,#e8d8c0,#d4c0a0);}
  .ac-cat-name{font-family:var(--font-mono);font-size:9px;color:#8b7355;letter-spacing:0.1em;text-align:center;padding:6px 0;background:#f7f5f0;}

  /* ── SalesVideo ── */
  .ps-salesvideo{background:#050505;height:100%;display:flex;flex-direction:column;}
  .sv-nav{display:flex;align-items:center;gap:16px;padding:14px 20px;border-bottom:1px solid rgba(255,255,255,0.06);}
  .sv-logo{font-family:var(--font-display);font-size:14px;font-weight:800;color:white;letter-spacing:-0.02em;}
  .sv-logo span{color:#ff3c00;}
  .sv-link{height:4px;border-radius:2px;background:rgba(255,255,255,0.1);width:32px;}
  .sv-cta{margin-left:auto;background:#ff3c00;color:white;font-family:var(--font-mono);font-size:10px;padding:6px 12px;border-radius:2px;letter-spacing:0.06em;}
  .sv-hero{flex:1;display:grid;grid-template-columns:1fr 1fr;align-items:center;padding:20px;}
  .sv-reel{display:flex;flex-direction:column;align-items:center;gap:12px;}
  .sv-play-ring{width:80px;height:80px;border:2px solid rgba(255,60,0,0.4);border-radius:50%;display:flex;align-items:center;justify-content:center;box-shadow:0 0 30px rgba(255,60,0,0.15);}
  .sv-play-btn{font-size:20px;color:white;margin-left:4px;}
  .sv-reel-label{font-family:var(--font-mono);font-size:9px;color:rgba(255,255,255,0.3);letter-spacing:0.2em;}
  .sv-h1{font-family:var(--font-display);font-size:20px;font-weight:800;color:white;line-height:1.1;letter-spacing:-0.03em;margin-bottom:16px;}
  .sv-accent{color:#ff3c00;}
  .sv-stat-row{display:flex;gap:16px;}
  .sv-stat{display:flex;flex-direction:column;gap:2px;}
  .sv-sval{font-family:var(--font-display);font-size:16px;font-weight:800;color:white;letter-spacing:-0.02em;}
  .sv-slabel{font-family:var(--font-mono);font-size:9px;color:rgba(255,255,255,0.3);letter-spacing:0.06em;}
  .sv-logos{display:flex;gap:8px;padding:10px 20px;background:#080808;border-top:1px solid rgba(255,255,255,0.05);justify-content:center;}
  .sv-logo-item{height:18px;border-radius:2px;background:rgba(255,255,255,0.07);width:50px;}

  /* ── Fromagerie ── */
  .ps-fromage{background:#faf6ee;height:100%;display:flex;flex-direction:column;}
  .fm-nav{display:flex;align-items:center;justify-content:space-between;padding:14px 20px;background:#faf6ee;border-bottom:1px solid #e8dcc8;}
  .fm-logo{font-family:var(--font-display);font-size:11px;font-weight:700;color:#2c1a08;letter-spacing:0.15em;}
  .fm-links{display:flex;gap:10px;}
  .fm-link{height:4px;border-radius:2px;background:#d4b896;width:36px;}
  .fm-hero{flex:1;display:grid;grid-template-columns:1fr 1fr;align-items:center;padding:20px;gap:20px;}
  .fm-img-area{position:relative;height:160px;}
  .fm-cheese-1{position:absolute;width:90px;height:70px;border-radius:50%;background:radial-gradient(circle,#f5d98c,#e8c45a);top:10px;left:20px;opacity:0.9;}
  .fm-cheese-2{position:absolute;width:70px;height:55px;border-radius:4px;background:linear-gradient(135deg,#f0e0a0,#d4b860);top:40px;left:80px;transform:rotate(-8deg);}
  .fm-cheese-3{position:absolute;width:80px;height:60px;border-radius:50%;background:radial-gradient(circle,#d4c8a8,#b8a878);top:20px;left:40px;opacity:0.6;}
  .fm-text{display:flex;flex-direction:column;gap:10px;}
  .fm-eyebrow{font-family:var(--font-mono);font-size:8px;color:#8b6914;letter-spacing:0.15em;text-transform:uppercase;}
  .fm-h1{font-family:var(--font-display);font-size:22px;font-weight:800;color:#2c1a08;line-height:1.1;letter-spacing:-0.02em;}
  .fm-line{height:4px;border-radius:2px;background:#d4b896;width:80%;}
  .fm-cta{font-family:var(--font-mono);font-size:9px;color:#8b6914;letter-spacing:0.08em;border-bottom:1px solid #d4b896;padding-bottom:2px;display:inline-block;width:fit-content;}
  .fm-range{display:flex;gap:8px;padding:12px 20px;background:#f5f0e4;border-top:1px solid #e8dcc8;}
  .fm-range-item{flex:1;display:flex;flex-direction:column;gap:6px;align-items:center;}
  .fm-ri-dot{width:28px;height:28px;border-radius:50%;background:radial-gradient(circle,#f5d98c,#d4a832);}
  .fm-ri-line{height:4px;border-radius:2px;background:#d4b896;width:70%;}

  /* ── Osteria ── */
  .ps-osteria{background:#0d0a06;height:100%;display:flex;flex-direction:column;position:relative;}
  .os-nav{display:flex;align-items:center;gap:12px;padding:14px 20px;position:absolute;top:0;left:0;right:0;z-index:2;background:linear-gradient(to bottom,rgba(13,10,6,0.95),transparent);}
  .os-logo{font-family:var(--font-display);font-size:13px;font-weight:700;color:#f5e6c8;letter-spacing:0.08em;flex:1;}
  .os-logo em{font-style:italic;font-weight:400;color:#b8955a;font-size:11px;}
  .os-links{display:flex;gap:12px;align-items:center;}
  .os-link{height:4px;border-radius:2px;background:rgba(245,230,200,0.2);width:32px;}
  .os-cta{background:rgba(184,149,90,0.9);color:#1a0f00;font-family:var(--font-mono);font-size:10px;padding:6px 12px;letter-spacing:0.06em;}
  .os-hero{flex:1;position:relative;}
  .os-img{position:absolute;inset:0;background:linear-gradient(160deg,#1a0f06,#2a1508,#0d0a06);opacity:0.9;}
  .os-img::after{content:'';position:absolute;inset:0;background:radial-gradient(ellipse at 60% 40%,rgba(184,149,90,0.08),transparent 60%);}
  .os-overlay{position:absolute;inset:0;display:flex;flex-direction:column;justify-content:flex-end;padding:60px 20px 20px;}
  .os-eyebrow{font-family:var(--font-mono);font-size:8px;color:#b8955a;letter-spacing:0.2em;text-transform:uppercase;margin-bottom:10px;opacity:0.8;}
  .os-h1{font-family:var(--font-display);font-size:24px;font-weight:800;color:#f5e6c8;line-height:1.1;letter-spacing:-0.02em;margin-bottom:14px;}
  .os-cta-large{display:inline-block;border:1px solid rgba(184,149,90,0.6);color:#b8955a;font-family:var(--font-mono);font-size:10px;padding:8px 16px;letter-spacing:0.12em;text-transform:uppercase;}
  .os-menu-strip{background:#080604;border-top:1px solid rgba(245,230,200,0.06);padding:12px 20px;}
  .os-menu-label{font-family:var(--font-mono);font-size:9px;color:rgba(184,149,90,0.6);letter-spacing:0.12em;text-transform:uppercase;margin-bottom:8px;}
  .os-menu-items{display:flex;flex-direction:column;gap:6px;}
  .os-mi{display:flex;align-items:center;justify-content:space-between;gap:8px;}
  .os-mi-line{height:4px;border-radius:2px;background:rgba(245,230,200,0.08);}
  .os-mi-price{font-family:var(--font-mono);font-size:10px;color:rgba(184,149,90,0.7);white-space:nowrap;}

  /* INFO PANEL */
  .proj-info{display:flex;flex-direction:column;justify-content:center;min-height:0;}
  .pi-block{display:none;flex-direction:column;gap:16px;animation:piFadeIn 0.4s ease forwards;}
  .pi-block.active{display:flex;}
  @keyframes piFadeIn{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}
  .pi-cat{font-family:var(--font-mono);font-size:10px;color:var(--lime);letter-spacing:0.1em;text-transform:uppercase;}
  .pi-name{font-family:var(--font-display);font-size:clamp(24px,2.5vw,36px);font-weight:800;letter-spacing:-0.03em;color:var(--text);line-height:1;}
  .pi-desc{font-family:var(--font-mono);font-size:12px;color:var(--muted);line-height:1.8;}
  .pi-tags{display:flex;flex-wrap:wrap;gap:6px;}
  .pi-tag{font-family:var(--font-mono);font-size:10px;color:rgba(240,240,238,0.4);border:1px solid var(--border);padding:4px 10px;border-radius:2px;letter-spacing:0.04em;}
  .pi-url-row{display:flex;align-items:center;gap:8px;margin-top:8px;}
  .pi-url-dot{width:6px;height:6px;border-radius:50%;background:rgba(240,240,238,0.2);}
  .pi-url-text{font-family:var(--font-mono);font-size:11px;color:rgba(240,240,238,0.3);letter-spacing:0.04em;}
  .pi-url-soon{font-family:var(--font-mono);font-size:9px;color:rgba(240,240,238,0.15);letter-spacing:0.06em;border:1px solid var(--border);padding:2px 6px;border-radius:2px;}


/* ─────────────────────────────────────────────────────────────
   SECTION 07.5 — Client portal (codename input, grid background, corner marks, feedback states)
───────────────────────────────────────────────────────────── */
/* ── PORTAL ── */
  .portal {
    position: relative;
    z-index: 3;
    background: #060606;
    border-top: 1px solid var(--border);
    border-bottom: 1px solid var(--border);
    padding: 100px 48px;
    overflow: hidden;
  }

  /* Grid bg */
  .portal::before {
    content: '';
    position: absolute;
    inset: 0;
    background-image:
      linear-gradient(rgba(200,255,0,0.025) 1px, transparent 1px),
      linear-gradient(90deg, rgba(200,255,0,0.025) 1px, transparent 1px);
    background-size: 48px 48px;
    pointer-events: none;
  }
  .portal::after {
    content: '';
    position: absolute;
    inset: 0;
    background: radial-gradient(ellipse at 60% 50%, rgba(200,255,0,0.04) 0%, transparent 65%);
    pointer-events: none;
  }

  /* Corner marks */
  .portal-corner {
    position: absolute;
    width: 16px;
    height: 16px;
    border-color: rgba(200,255,0,0.25);
    border-style: solid;
  }
  .portal-corner.tl { top: 20px; left: 20px; border-width: 1px 0 0 1px; }
  .portal-corner.tr { top: 20px; right: 20px; border-width: 1px 1px 0 0; }
  .portal-corner.bl { bottom: 20px; left: 20px; border-width: 0 0 1px 1px; }
  .portal-corner.br { bottom: 20px; right: 20px; border-width: 0 1px 1px 0; }

  .portal-inner {
    max-width: 1200px;
    margin: 0 auto;
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 80px;
    align-items: center;
    position: relative;
    z-index: 1;
  }

  /* LEFT */
  .portal-title {
    font-family: var(--font-display);
    font-size: clamp(40px, 5vw, 72px);
    font-weight: 800;
    letter-spacing: -0.04em;
    line-height: 0.93;
    color: var(--text);
    margin: 16px 0 20px;
  }
  .portal-sub {
    font-family: var(--font-mono);
    font-size: 12px;
    color: var(--muted);
    line-height: 1.8;
    max-width: 340px;
  }

  /* RIGHT */
  .portal-right {
    display: flex;
    align-items: center;
  }
  .portal-form-wrap {
    width: 100%;
    display: flex;
    flex-direction: column;
    gap: 14px;
  }

  .portal-input-row {
    display: flex;
    align-items: center;
    gap: 0;
    border: 1px solid rgba(200,255,0,0.2);
    border-radius: 3px;
    background: rgba(200,255,0,0.02);
    padding: 0 0 0 20px;
    transition: border-color 0.2s, background 0.2s;
  }
  .portal-input-row:focus-within {
    border-color: rgba(200,255,0,0.5);
    background: rgba(200,255,0,0.04);
  }
  .portal-input-row.shake {
    animation: inputShake 0.4s ease;
  }
  .portal-input-row.error {
    border-color: rgba(255, 80, 80, 0.5);
    background: rgba(255, 80, 80, 0.03);
  }

  @keyframes inputShake {
    0%, 100% { transform: translateX(0); }
    20% { transform: translateX(-8px); }
    40% { transform: translateX(8px); }
    60% { transform: translateX(-5px); }
    80% { transform: translateX(5px); }
  }

  .portal-prompt {
    font-family: var(--font-mono);
    font-size: 18px;
    color: var(--lime);
    margin-right: 10px;
    line-height: 1;
    animation: blink 1.1s step-end infinite;
    user-select: none;
  }
  @keyframes blink { 0%, 100% { opacity: 1; } 50% { opacity: 0; } }

  .portal-input {
    flex: 1;
    background: transparent;
    border: none;
    outline: none;
    font-family: var(--font-mono);
    font-size: 18px;
    font-weight: 500;
    color: var(--lime);
    letter-spacing: 0.12em;
    text-transform: uppercase;
    padding: 20px 0;
    caret-color: var(--lime);
    cursor: none;
  }
  .portal-input::placeholder {
    color: rgba(200,255,0,0.18);
    font-weight: 400;
    letter-spacing: 0.06em;
    text-transform: none;
  }

  .portal-submit {
    width: 64px;
    height: 64px;
    background: var(--lime);
    border: none;
    border-radius: 0 2px 2px 0;
    color: #080808;
    cursor: none;
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
    transition: opacity 0.2s;
    align-self: stretch;
  }
  .portal-submit:hover { opacity: 0.85; }

  .portal-feedback {
    font-family: var(--font-mono);
    font-size: 11px;
    letter-spacing: 0.08em;
    min-height: 16px;
    transition: opacity 0.2s;
  }
  .portal-feedback.error { color: rgba(255, 100, 100, 0.8); }
  .portal-feedback.success { color: var(--lime); }

  .portal-hint {
    font-family: var(--font-mono);
    font-size: 10px;
    color: rgba(240,240,238,0.15);
    letter-spacing: 0.06em;
  }


/* ─────────────────────────────────────────────────────────────
   SECTION 08 — Contact form + Footer (grid bg, headline, form fields, scope pills, submit button, footer)
───────────────────────────────────────────────────────────── */
.contact { position:relative; z-index:3; background:#050505; border-top:1px solid var(--border); overflow:hidden; }
  .contact-grid-bg { position:absolute; inset:0; background-image: linear-gradient(rgba(200,255,0,0.03) 1px, transparent 1px), linear-gradient(90deg, rgba(200,255,0,0.03) 1px, transparent 1px); background-size:60px 60px; pointer-events:none; }
  .contact-grid-bg::after { content:''; position:absolute; inset:0; background:radial-gradient(ellipse at 30% 50%, rgba(200,255,0,0.04) 0%, transparent 60%); }
  .contact-inner { max-width:1200px; margin:0 auto; display:grid; grid-template-columns:1fr 1fr; gap:80px; padding:120px 48px 100px; position:relative; z-index:1; }
  .contact-left { display:flex; flex-direction:column; gap:0; }
  .contact-headline { font-family:var(--font-display); font-size:clamp(44px,5.5vw,84px); font-weight:800; letter-spacing:-0.04em; line-height:0.92; color:var(--text); margin:20px 0 28px; }
  .ch-outline { -webkit-text-stroke:1px rgba(200,255,0,0.6); color:transparent; }
  .contact-sub { font-family:var(--font-mono); font-size:13px; color:var(--muted); line-height:1.8; max-width:400px; margin-bottom:48px; }
  .contact-details { display:flex; flex-direction:column; gap:18px; margin-bottom:40px; }
  .cd-item { display:flex; flex-direction:column; gap:3px; }
  .cd-label { font-family:var(--font-mono); font-size:10px; color:rgba(240,240,238,0.2); letter-spacing:0.1em; text-transform:uppercase; }
  .cd-val { font-family:var(--font-mono); font-size:13px; color:rgba(240,240,238,0.6); letter-spacing:0.02em; text-decoration:none; transition:color 0.2s; }
  a.cd-val:hover { color:var(--lime); }
  .cd-telegram-link {
    position: relative;
    display: inline-flex;
    flex-direction: column;
    gap: 3px;
    align-self: flex-start;
    padding: 10px 14px;
    margin: -10px -14px;
    text-decoration: none;
  }
  .cd-telegram-link::before {
    content: '';
    position: absolute;
    inset: 0;
    border: 1px solid transparent;
    transition: border-color 0.2s;
    pointer-events: none;
  }
  .cd-telegram-link .cd-label,
  .cd-telegram-link .cd-val {
    transition: color 0.2s;
  }
  .cd-telegram-link:hover::before,
  .cd-telegram-link:focus-visible::before {
    border-color: var(--lime);
  }
  .cd-telegram-link:hover .cd-label,
  .cd-telegram-link:hover .cd-val,
  .cd-telegram-link:focus-visible .cd-label,
  .cd-telegram-link:focus-visible .cd-val {
    color: var(--lime);
  }
  .contact-availability { display:flex; align-items:center; gap:10px; }
  .avail-dot { width:8px; height:8px; border-radius:50%; background:var(--lime); box-shadow:0 0 10px rgba(200,255,0,0.6); animation:availPulse 2s ease-in-out infinite; }
  @keyframes availPulse { 0%,100%{box-shadow:0 0 8px rgba(200,255,0,0.4)} 50%{box-shadow:0 0 18px rgba(200,255,0,0.8)} }
  .avail-text { font-family:var(--font-mono); font-size:11px; color:var(--lime); letter-spacing:0.06em; }
  .contact-right { display:flex; align-items:flex-start; padding-top:80px; }
  .contact-form-wrap { width:100%; display:flex; flex-direction:column; gap:24px; }
  .form-field { display:flex; flex-direction:column; gap:8px; }
  .field-label { font-family:var(--font-mono); font-size:10px; color:rgba(240,240,238,0.3); letter-spacing:0.1em; text-transform:uppercase; }
  .field-input { background:rgba(255,255,255,0.03); border:1px solid var(--border); border-radius:3px; padding:14px 16px; font-family:var(--font-mono); font-size:13px; color:var(--text); width:100%; outline:none; transition:border-color 0.2s,background 0.2s; cursor:text; }
  .field-input::placeholder { color:rgba(240,240,238,0.18); }
  .field-input:focus { border-color:rgba(200,255,0,0.4); background:rgba(200,255,0,0.02); }
  .field-textarea { resize:vertical; min-height:110px; font-family:var(--font-mono); line-height:1.6; }
  .scope-pills { display:flex; flex-wrap:wrap; gap:8px; }
  .scope-pill { font-family:var(--font-mono); font-size:11px; color:var(--muted); border:1px solid var(--border); background:transparent; padding:7px 14px; border-radius:2px; cursor:pointer; letter-spacing:0.03em; transition:border-color 0.2s,color 0.2s,background 0.2s; }
  .scope-pill:hover { border-color:rgba(200,255,0,0.3); color:var(--text); }
  .scope-pill.selected { border-color:var(--lime); color:var(--lime); background:rgba(200,255,0,0.06); }
  .contact-submit { display:flex; align-items:center; justify-content:center; gap:12px; background:var(--lime); border:none; border-radius:3px; padding:18px 36px; font-family:var(--font-mono); font-size:13px; font-weight:500; color:#080808; letter-spacing:0.06em; text-transform:uppercase; cursor:pointer; width:100%; position:relative; overflow:hidden; transition:opacity 0.2s,transform 0.2s; }
  .contact-submit:hover { opacity:0.88; transform:translateY(-1px); }
  .cs-arrow { font-size:16px; transition:transform 0.2s; }
  .contact-submit:hover .cs-arrow { transform:translateX(4px); }
  .cs-loader { position:absolute; inset:0; background:var(--lime); display:flex; align-items:center; justify-content:center; opacity:0; pointer-events:none; transition:opacity 0.2s; }
  .cs-loader::after { content:''; width:16px; height:16px; border:2px solid rgba(8,8,8,0.3); border-top-color:#080808; border-radius:50%; animation:spin 0.7s linear infinite; }
  @keyframes spin { to{transform:rotate(360deg)} }
  .form-note { font-family:var(--font-mono); font-size:10px; color:rgba(240,240,238,0.15); line-height:1.6; text-align:center; letter-spacing:0.04em; }
  .form-success { display:none; flex-direction:column; align-items:center; gap:12px; padding:28px; border:1px solid rgba(200,255,0,0.2); border-radius:3px; background:rgba(200,255,0,0.04); text-align:center; }
  .form-success.show { display:flex; }
  .fs-icon { font-size:28px; color:var(--lime); }
  .fs-text { font-family:var(--font-mono); font-size:12px; color:var(--muted); line-height:1.7; letter-spacing:0.04em; }
  .site-footer { position:relative; z-index:1; border-top:1px solid var(--border); padding:0 48px; }
  .footer-inner { max-width:1200px; margin:0 auto; display:flex; align-items:center; justify-content:space-between; padding:28px 0; gap:32px; }
  .footer-logo { font-family:var(--font-display); font-size:16px; font-weight:800; letter-spacing:-0.03em; color:var(--text); }
  .footer-logo span { color:var(--lime); }
  .footer-links { display:flex; gap:28px; }
  .footer-links a { font-family:var(--font-mono); font-size:11px; color:rgba(240,240,238,0.25); letter-spacing:0.06em; text-decoration:none; transition:color 0.2s; }
  .footer-links a:hover { color:var(--lime); }
  .footer-copy { font-family:var(--font-mono); font-size:10px; color:rgba(240,240,238,0.15); letter-spacing:0.06em; }
  .footer-bottom-line { max-width:1200px; margin:0 auto; height:1px; background:linear-gradient(to right,transparent,var(--lime),transparent); opacity:0.15; }

  /* Desktop-only custom cursor behavior */
  @media (hover: hover) and (pointer: fine) {
    body { cursor: none; }
    a, button, input, textarea, .stack-item, .scope-pill, .portal-input, .portal-submit { cursor: none; }
  }

  /* Touch/pen: disable custom cursor layer and restore native cursors */
  @media (hover: none), (pointer: coarse) {
    .cursor, .cursor-ring { display: none !important; }
    body, a, button, input, textarea, .stack-item, .scope-pill, .portal-input, .portal-submit {
      cursor: auto !important;
    }
    .work-track-wrap { cursor: auto; }
  }

  /* ===========================
     Responsive Layout
  =========================== */
  @media (max-width: 1100px) {
    nav { padding: 20px 24px; }
    .nav-right { gap: 20px; }
    .hero,
    .metrics,
    .tiers,
    .stack-section,
    .process,
    .showcase,
    .portal,
    .contact-inner,
    .site-footer { padding-left: 24px; padding-right: 24px; }

    .tiers-header,
    .stack-header,
    .process-header {
      grid-template-columns: 1fr;
      gap: 14px;
      align-items: start;
    }
    .tiers-sub,
    .stack-sub,
    .process-sub { max-width: 100%; text-align: left; }

    .showcase-stage { grid-template-columns: 1fr; gap: 28px; }
    .proj-info { min-height: auto; }

    .portal-inner,
    .contact-inner {
      grid-template-columns: 1fr;
      gap: 40px;
    }
    .contact-right { padding-top: 0; }
  }

  @media (max-width: 900px) {
    .metrics,
    .tiers,
    .work,
    .stack-section,
    .process,
    .showcase,
    .portal,
    .contact {
      overflow: visible;
    }

    .metrics-inner,
    .tiers-header,
    .tiers-grid,
    .stack-inner,
    .process-inner,
    .showcase-header,
    .showcase-body,
    .portal-inner,
    .contact-inner,
    .footer-inner,
    .footer-bottom-line {
      width: 100%;
      max-width: none;
      margin-left: 0;
      margin-right: 0;
    }

    .nav-links { display: none; }
    .nav-cta { padding: 9px 14px; font-size: 11px; }
    .hero { min-height: 92vh; padding-top: 90px; }
    .hero-sub { max-width: 100%; }
    .hero-actions { gap: 18px; flex-wrap: wrap; }
    .hero-bottom { left: 24px; right: 24px; bottom: 24px; }

    .metrics { padding-top: 56px; padding-bottom: 56px; }
    .metrics-inner {
      display: grid;
      grid-template-columns: repeat(2, minmax(0, 1fr));
      gap: 1px;
      background: var(--border);
      border: 1px solid var(--border);
      border-radius: 4px;
      overflow: hidden;
    }
    .metric-item { background: var(--bg2); padding: 28px 12px; }
    .metric-divider { display: none; }
    .metrics-footnote { margin-top: 24px; }
    .fn-line { max-width: 56px; }
    .fn-text { white-space: normal; text-align: center; }

    .tiers-grid { grid-template-columns: 1fr; gap: 1px; }

    .work-sticky { display: block; min-height: auto; overflow: visible; }
    .work-label-col {
      position: static;
      width: 100%;
      min-width: 0;
      height: auto;
      border-right: none;
      border-bottom: 1px solid var(--border);
      padding: 28px 24px 20px;
      justify-content: flex-start;
    }
    .work-track-wrap {
      width: 100%;
      height: auto;
      overflow-x: auto;
      overflow-y: visible;
      padding: 18px 0 30px;
    }
    .work-track { height: auto; align-items: stretch; }
    .work-card { width: min(78vw, 360px); margin-right: 18px; }
    .work-track {
      padding-left: 24px !important;
      padding-right: 24px !important;
    }
    .work-track-wrap{
      touch-action: pan-x;
      scroll-snap-type: x mandatory;
    }
    .work-card{scroll-snap-align:center;}

    .stack-section,
    .process,
    .showcase,
    .portal { padding-top: 80px; padding-bottom: 80px; }

    .process-body { padding-left: 40px; }
    .spine-track { left: 10px; }
    .phase { grid-template-columns: 1fr; gap: 14px; margin-bottom: 34px; }
    .phase-left { padding-top: 0; }
    .phase-dot-wrap { left: -40px; top: 4px; }
    .deliv-list { grid-template-columns: 1fr; }

    .browser-viewport {
      min-height: 0;
      max-height: none;
      aspect-ratio: 16 / 10;
      height: auto;
    }

    .tiers-title,
    .stack-title,
    .process-title,
    .showcase-title,
    .portal-title,
    .contact-headline,
    .hero-headline {
      line-height: 1.02;
      letter-spacing: -0.03em;
      overflow-wrap: anywhere;
      word-break: normal;
    }

    .stack-grid,
    .pi-tags,
    .scope-pills,
    .phase-tag-row,
    .footer-links {
      justify-content: flex-start;
      align-content: flex-start;
    }
  }

  @media (max-width: 680px) {
    .hero { overflow: visible; }

    nav { padding: 16px; }
    .nav-logo { font-size: 18px; }
    .nav-cta { padding: 8px 12px; letter-spacing: 0.03em; }

    .hero,
    .metrics,
    .tiers,
    .stack-section,
    .process,
    .showcase,
    .portal { padding-left: 16px; padding-right: 16px; }

    .hero { min-height: 88vh; padding-top: 84px; }
    .hero-headline{
      font-size: clamp(34px, 9vw, 50px);
      line-height: 1.02;
    }
    .hero-headline .line2{
      display: inline;
      margin-right: 0.25ch;
    }
    .hero-headline .word-swap{
      white-space: nowrap;
      display: inline-block;
    }
    .hero-kicker { margin-bottom: 18px; }
    .hero-sub { margin-top: 22px; font-size: 12px; line-height: 1.65; }
    .hero-actions { margin-top: 28px; width: 100%; }
    .btn-primary { width: 100%; text-align: center; padding: 14px 16px; }
    .btn-ghost { font-size: 11px; }
    .hero-bottom { left: 16px; right: 16px; bottom: 14px; }
    .scroll-line { height: 34px; }

    .metric-num { font-size: clamp(30px, 9vw, 44px); }
    .metric-label { font-size: 10px; letter-spacing: 0.05em; }

    .tier-card { padding: 0 20px 24px; }
    .tier-name { font-size: clamp(24px, 9vw, 34px); }

    .work-label-col { padding: 22px 16px 16px; }
    .work-track-wrap { padding-top: 14px; padding-bottom: 20px; }
    .work-card { width: 85vw; margin-right: 12px; }
    .work-track {
      padding-left: 16px !important;
      padding-right: 16px !important;
    }
    .wcard-name { font-size: 22px; }
    .wcard-meta { gap: 12px; }

    .stack-grid { gap: 6px; }
    .stack-item { padding: 8px 10px; gap: 8px; }
    .si-icon { width: 22px; height: 22px; }
    .si-name { font-size: 10px; white-space: normal; }

    .showcase { padding-top: 70px; padding-bottom: 70px; }
    .showcase-header { margin-bottom: 28px; gap: 16px; }
    .proj-tabs { margin-bottom: 20px; }
    .proj-tabs{
      position: sticky;
      top: 56px;
      z-index: 5;
      background: var(--bg);
    }
    .proj-tab { padding: 12px 14px; }
    .pt-name { font-size: 13px; }
    .pt-cat { font-size: 9px; }
    .browser-viewport { aspect-ratio: 16 / 11; height: auto; }
    .pi-desc { font-size: 11px; line-height: 1.7; }

    .portal { padding-top: 64px; padding-bottom: 64px; }
    .portal-inner { gap: 24px; }
    .portal-input-row { padding-left: 12px; }
    .portal-input { font-size: 14px; padding: 14px 0; letter-spacing: 0.04em; }
    .portal-submit { width: 46px; height: 46px; }
    .portal-submit svg { width: 16px; height: 16px; }

    .contact-inner { padding: 70px 16px 60px; gap: 28px; }
    .contact-sub { margin-bottom: 28px; font-size: 12px; }
    .contact-details { gap: 12px; margin-bottom: 24px; }
    .field-input { padding: 12px 12px; font-size: 12px; }
    .scope-pills { gap: 6px; }
    .scope-pill { font-size: 10px; padding: 6px 10px; }
    .contact-submit { padding: 15px 18px; font-size: 12px; }

    .site-footer { padding-left: 16px; padding-right: 16px; }
    .footer-inner {
      flex-direction: column;
      align-items: flex-start;
      gap: 14px;
      padding: 20px 0;
    }
    .footer-links { gap: 14px; flex-wrap: wrap; }
  }

  /* Short-height screens (small laptops / landscape tablets) */
  @media (max-height: 820px) and (min-width: 901px) {
    .hero { min-height: 92dvh; padding-top: 86px; }
    .hero-sub { margin-top: 24px; }
    .hero-actions { margin-top: 30px; }
    .hero-bottom { bottom: 18px; }

    .work-label-col { padding-top: 30px; padding-bottom: 30px; }
    .work-track,
    .work-label-col { min-height: 92dvh; height: 92dvh; }
    .work-card { width: min(34vw, 400px); }
  }


