/* ══════════════════════════════════════════
   Daily Shot Solutions — Styles v2.1
   Dark/Light Theme · Epic Backgrounds
   ══════════════════════════════════════════ */

/* ═══ THEME VARIABLES ═══ */
:root {
  /* Accent (shared) */
  --accent: #facc15;
  --accent-hover: #fde047;
  --accent-rgb: 250, 204, 21;
  --accent-on: #09090b;

  /* Default: Dark Theme */
  --bg: #09090b;
  --bg-rgb: 9, 9, 11;
  --text: #fafafa;
  --text-rgb: 255, 255, 255;
  --text-muted: rgba(255, 255, 255, .65);
  --text-subtle: rgba(255, 255, 255, .45);
  --text-faint: rgba(255, 255, 255, .25);
  --text-ghost: rgba(255, 255, 255, .4);
  --border: rgba(255, 255, 255, .06);
  --border-hover: rgba(255, 255, 255, .15);
  --border-input: rgba(255, 255, 255, .08);
  --card-bg: rgba(255, 255, 255, .03);
  --card-bg-hover: rgba(255, 255, 255, .06);
  --nav-scrolled: rgba(9, 9, 11, .85);
  --mega-bg: rgba(9, 9, 11, .96);
  --mobile-bg: rgba(9, 9, 11, .97);
  --input-bg: rgba(255, 255, 255, .04);
  --input-bg-focus: rgba(255, 255, 255, .06);
  --select-option-bg: #1a1a1e;
  --grain-opacity: .5;
  --logo-text-span: rgba(255, 255, 255, .4);
  --select-arrow: rgba(255,255,255,0.4);
  --pill-bg: rgba(250, 204, 21, .08);
  --pill-border: rgba(250, 204, 21, .15);
  --pill-text: rgba(250, 204, 21, .85);
  --shadow-cta: rgba(250, 204, 21, .25);
  --outline-border: rgba(255, 255, 255, .2);
  --selection-bg: rgba(250, 204, 21, .3);
  --selection-text: #fff;

  /* Hero background - Dark */
  --hero-glow-1: rgba(250, 204, 21, .12);
  --hero-glow-2: rgba(249, 115, 22, .08);
  --hero-glow-3: rgba(139, 92, 246, .06);

  /* Section accent backgrounds */
  --section-glow: rgba(250, 204, 21, .03);

  /* CTA section */
  --cta-section-bg: rgba(250, 204, 21, .04);
  --cta-section-border: rgba(250, 204, 21, .08);
}

/* ═══ LIGHT THEME ═══ */
[data-theme="light"] {
  --bg: #fafaf8;
  --bg-rgb: 250, 250, 248;
  --text: #1a1a2e;
  --text-rgb: 26, 26, 46;
  --text-muted: rgba(26, 26, 46, .7);
  --text-subtle: rgba(26, 26, 46, .55);
  --text-faint: rgba(26, 26, 46, .35);
  --text-ghost: rgba(26, 26, 46, .45);
  --border: rgba(26, 26, 46, .08);
  --border-hover: rgba(26, 26, 46, .18);
  --border-input: rgba(26, 26, 46, .12);
  --card-bg: rgba(255, 255, 255, .75);
  --card-bg-hover: rgba(255, 255, 255, .95);
  --nav-scrolled: rgba(250, 250, 248, .9);
  --mega-bg: rgba(250, 250, 248, .97);
  --mobile-bg: rgba(250, 250, 248, .98);
  --input-bg: rgba(26, 26, 46, .04);
  --input-bg-focus: rgba(26, 26, 46, .07);
  --select-option-bg: #f0f0f4;
  --grain-opacity: .12;
  --logo-text-span: rgba(26, 26, 46, .4);
  --select-arrow: rgba(26,26,46,0.4);
  --pill-bg: rgba(217, 119, 6, .08);
  --pill-border: rgba(217, 119, 6, .2);
  --pill-text: #b45309;
  --shadow-cta: rgba(217, 119, 6, .18);
  --outline-border: rgba(26, 26, 46, .18);
  --selection-bg: rgba(217, 119, 6, .2);
  --selection-text: #1a1a2e;
  --accent: #d97706;
  --accent-hover: #b45309;
  --accent-rgb: 217, 119, 6;
  --accent-on: #fff;

  /* Hero background - Light */
  --hero-glow-1: rgba(217, 119, 6, .08);
  --hero-glow-2: rgba(234, 88, 12, .06);
  --hero-glow-3: rgba(99, 102, 241, .04);

  /* Section accent backgrounds */
  --section-glow: rgba(217, 119, 6, .03);

  /* CTA section */
  --cta-section-bg: rgba(217, 119, 6, .04);
  --cta-section-border: rgba(217, 119, 6, .1);
}

/* Light theme: specific overrides */
[data-theme="light"] .cta-btn {
  background: linear-gradient(135deg, #d97706, #b45309);
  color: #fff;
}
[data-theme="light"] .cta-btn:hover {
  background: linear-gradient(135deg, #b45309, #92400e);
  box-shadow: 0 8px 30px rgba(217, 119, 6, .2);
}
[data-theme="light"] .nav-logo-icon {
  background: linear-gradient(135deg, #d97706, #ea580c);
  color: #fff;
}
[data-theme="light"] .solution-tab.active {
  background: var(--accent);
  color: #fff;
  border-color: var(--accent);
}
[data-theme="light"] .site-card,
[data-theme="light"] .portfolio-card,
[data-theme="light"] .service-page-card {
  box-shadow: 0 1px 3px rgba(0,0,0,.04), 0 4px 16px rgba(0,0,0,.04);
  border-color: rgba(26, 26, 46, .06);
}
[data-theme="light"] .site-card:hover,
[data-theme="light"] .portfolio-card:hover,
[data-theme="light"] .service-page-card:hover {
  box-shadow: 0 4px 20px rgba(0,0,0,.08);
}

/* ═══ RESET ═══ */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:'DM Sans','Outfit',sans-serif;background:var(--bg);color:var(--text);min-height:100vh;overflow-x:hidden;transition:background .4s ease,color .4s ease}
::selection{background:var(--selection-bg);color:var(--selection-text)}

/* Grain */
.grain::after{content:'';position:fixed;top:-50%;left:-50%;width:200%;height:200%;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.04'/%3E%3C/svg%3E");animation:grain 8s steps(10) infinite;pointer-events:none;z-index:9999;opacity:var(--grain-opacity)}

/* ═══ EPIC HERO BACKGROUND ═══ */
.hero-bg {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  overflow: hidden;
  z-index: 0;
  pointer-events: none;
}

/* Main mesh gradient orbs */
.hero-bg::before {
  content: '';
  position: absolute;
  top: -20%;
  left: -10%;
  width: 70%;
  height: 70%;
  background: radial-gradient(ellipse at center, var(--hero-glow-1) 0%, transparent 70%);
  animation: heroFloat1 12s ease-in-out infinite;
}
.hero-bg::after {
  content: '';
  position: absolute;
  bottom: -10%;
  right: -15%;
  width: 65%;
  height: 65%;
  background: radial-gradient(ellipse at center, var(--hero-glow-2) 0%, transparent 70%);
  animation: heroFloat2 15s ease-in-out infinite;
}

/* Third orb */
.hero-bg-orb {
  position: absolute;
  top: 20%;
  right: 10%;
  width: 50%;
  height: 60%;
  background: radial-gradient(ellipse at center, var(--hero-glow-3) 0%, transparent 65%);
  animation: heroFloat3 18s ease-in-out infinite;
}

/* Subtle grid pattern overlay */
.hero-bg-grid {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background-image:
    linear-gradient(var(--border) 1px, transparent 1px),
    linear-gradient(90deg, var(--border) 1px, transparent 1px);
  background-size: 80px 80px;
  opacity: .35;
  mask-image: radial-gradient(ellipse 80% 70% at 50% 40%, black 20%, transparent 70%);
  -webkit-mask-image: radial-gradient(ellipse 80% 70% at 50% 40%, black 20%, transparent 70%);
}

@keyframes heroFloat1 {
  0%, 100% { transform: translate(0, 0) scale(1); }
  33% { transform: translate(5%, 8%) scale(1.05); }
  66% { transform: translate(-3%, -5%) scale(.97); }
}
@keyframes heroFloat2 {
  0%, 100% { transform: translate(0, 0) scale(1); }
  33% { transform: translate(-6%, -4%) scale(1.03); }
  66% { transform: translate(4%, 6%) scale(.98); }
}
@keyframes heroFloat3 {
  0%, 100% { transform: translate(0, 0) scale(1); }
  50% { transform: translate(-8%, 5%) scale(1.06); }
}

/* ═══ SECTION GLOW BACKGROUNDS ═══ */
.section-glow {
  position: relative;
}
.section-glow::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background: radial-gradient(ellipse 60% 50% at 50% 0%, var(--section-glow) 0%, transparent 100%);
  pointer-events: none;
  z-index: 0;
}

/* CTA section special glow */
.cta-glow {
  position: relative;
  background: var(--cta-section-bg);
  border-top: 1px solid var(--cta-section-border);
  border-bottom: 1px solid var(--cta-section-border);
}
.cta-glow::before {
  content: '';
  position: absolute;
  top: -1px;
  left: 10%;
  right: 10%;
  height: 1px;
  background: linear-gradient(90deg, transparent, rgba(var(--accent-rgb), .3), transparent);
}

/* Keyframes */
@keyframes grain{0%,100%{transform:translate(0)}10%{transform:translate(-5%,-10%)}20%{transform:translate(-15%,5%)}30%{transform:translate(7%,-25%)}40%{transform:translate(-5%,25%)}50%{transform:translate(-15%,10%)}60%{transform:translate(15%)}70%{transform:translate(0,15%)}80%{transform:translate(3%,35%)}90%{transform:translate(-10%,10%)}}
@keyframes float{0%,100%{transform:translateY(0)}50%{transform:translateY(-12px)}}
@keyframes pulse-ring{0%{transform:scale(.95);opacity:.6}50%{transform:scale(1.05);opacity:.3}100%{transform:scale(.95);opacity:.6}}
@keyframes marquee{0%{transform:translateX(0)}100%{transform:translateX(-50%)}}
@keyframes megaIn{from{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}
@keyframes fadeUp{from{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}

/* Nav */
.nav{position:fixed;top:0;left:0;right:0;z-index:100;padding:0 clamp(20px,4vw,60px);height:72px;display:flex;align-items:center;justify-content:space-between;transition:all .4s;border-bottom:1px solid transparent}
.nav.scrolled{background:var(--nav-scrolled);backdrop-filter:blur(20px) saturate(1.5);border-bottom-color:var(--border)}
.nav-logo{text-decoration:none;display:flex;align-items:center;gap:10px;cursor:pointer}
.nav-logo-icon{width:36px;height:36px;border-radius:10px;background:linear-gradient(135deg,#facc15,#f97316);display:flex;align-items:center;justify-content:center;font-family:'Space Mono',monospace;font-weight:700;font-size:16px;color:#09090b;transition:background .3s}
.nav-logo-text{font-family:'Playfair Display',serif;font-weight:700;font-size:18px;color:var(--text);letter-spacing:-.5px;transition:color .3s}
.nav-logo-text span{color:var(--logo-text-span);font-weight:400;transition:color .3s}

.desktop-nav{display:flex;align-items:center;gap:32px}
.nav-link{color:var(--text-muted);text-decoration:none;font-size:14px;font-weight:500;letter-spacing:.3px;transition:color .25s;position:relative;cursor:pointer}
.nav-link:hover,.nav-link.active{color:var(--accent)}
.nav-link::after{content:'';position:absolute;bottom:-3px;left:0;width:0;height:1.5px;background:var(--accent);transition:width .3s}
.nav-link:hover::after,.nav-link.active::after{width:100%}
.nav-trigger{display:flex;align-items:center}

/* Mega Menu */
.mega-menu{position:absolute;top:72px;left:0;right:0;background:var(--mega-bg);backdrop-filter:blur(24px) saturate(1.4);border-bottom:1px solid var(--border);padding:32px clamp(20px,4vw,60px);z-index:99;animation:megaIn .3s cubic-bezier(.22,1,.36,1);display:none;justify-content:center}
.mega-menu.active{display:flex}
.mega-site-link{display:flex;align-items:center;gap:14px;padding:12px 16px;border-radius:12px;text-decoration:none;color:var(--text);transition:all .25s}
.mega-site-link:hover{background:var(--card-bg-hover)}
.mega-sol-link{display:flex;align-items:flex-start;gap:14px;padding:14px 16px;border-radius:12px;text-decoration:none;color:var(--text);transition:all .25s;cursor:pointer}
.mega-sol-link:hover{background:var(--card-bg-hover)}

/* Buttons */
.cta-btn{display:inline-flex;align-items:center;gap:10px;padding:16px 36px;background:var(--accent);color:var(--accent-on);font-weight:600;font-size:15px;border:none;border-radius:100px;cursor:pointer;transition:all .3s;text-decoration:none;letter-spacing:.3px;font-family:'DM Sans',sans-serif}
.cta-btn:hover{background:var(--accent-hover);transform:translateY(-2px);box-shadow:0 8px 30px var(--shadow-cta)}
.cta-btn-outline{background:transparent;border:1.5px solid var(--outline-border);color:var(--text)}
.cta-btn-outline:hover{border-color:var(--accent);color:var(--accent);background:transparent;box-shadow:none}

/* ═══ HERO CENTERED ═══ */
.hero-title{font-family:'Playfair Display',serif;font-weight:800;line-height:1.05;letter-spacing:-1.5px}
.hero-centered{text-align:center;display:flex;flex-direction:column;align-items:center}
.hero-centered .hero-buttons{justify-content:center}

/* Site Cards */
.site-card{background:var(--card-bg);border:1px solid var(--border);border-radius:16px;padding:32px 28px;transition:all .4s cubic-bezier(.22,1,.36,1);cursor:pointer;position:relative;overflow:hidden}
.site-card:hover{border-color:var(--border-hover);transform:translateY(-6px);background:var(--card-bg-hover)}

/* Solutions Tabs */
.solution-tab{padding:14px 24px;border:1px solid var(--border-input);border-radius:100px;font-size:14px;font-weight:500;cursor:pointer;transition:all .3s;background:transparent;color:var(--text-subtle);white-space:nowrap;font-family:'DM Sans',sans-serif}
.solution-tab:hover{border-color:var(--border-hover);color:var(--text-muted)}
.solution-tab.active{background:var(--accent);color:var(--accent-on);border-color:var(--accent)}

/* Stats */
.stat-item{text-align:center}
.stat-value{font-family:'Space Mono',monospace;font-size:clamp(32px,5vw,56px);font-weight:700;color:var(--accent);line-height:1}
.stat-label{font-size:13px;color:var(--text-subtle);margin-top:8px;text-transform:uppercase;letter-spacing:1.5px;font-weight:500}

/* Feature Pill */
.feature-pill{display:inline-flex;align-items:center;gap:6px;padding:6px 14px;background:var(--pill-bg);border:1px solid var(--pill-border);border-radius:100px;font-size:13px;color:var(--pill-text)}

/* Marquee */
.marquee-track{display:flex;gap:60px;animation:marquee 30s linear infinite;width:max-content}

/* Form */
.form-input,.form-select,.form-textarea{width:100%;padding:14px 18px;background:var(--input-bg);border:1px solid var(--border-input);border-radius:12px;color:var(--text);font-size:15px;font-family:'DM Sans',sans-serif;outline:none;transition:border-color .3s,background .3s}
.form-input:focus,.form-select:focus,.form-textarea:focus{border-color:rgba(var(--accent-rgb),.4);background:var(--input-bg-focus)}
.form-input::placeholder,.form-textarea::placeholder{color:var(--text-faint)}
.form-select{appearance:none;cursor:pointer;background-repeat:no-repeat;background-position:right 16px center}
.form-select option{background:var(--select-option-bg);color:var(--text)}
.form-textarea{resize:vertical;min-height:120px}
.form-label{display:block;font-size:13px;font-weight:500;color:var(--text-subtle);margin-bottom:8px;letter-spacing:.3px}

/* Footer */
.footer-link{color:var(--text-ghost);text-decoration:none;font-size:14px;transition:color .25s}
.footer-link:hover{color:var(--accent)}

/* Language dropdown */
.lang-dropdown{position:relative}
.lang-toggle{display:inline-flex;align-items:center;justify-content:center;gap:4px;height:36px;padding:0 12px;border-radius:8px;border:1px solid var(--border-input);color:var(--text-subtle);font-family:'Space Mono',monospace;font-size:12px;font-weight:700;text-decoration:none;transition:all .25s;letter-spacing:.5px;background:transparent;cursor:pointer}
.lang-toggle:hover{border-color:var(--accent);color:var(--accent);background:rgba(var(--accent-rgb),.05)}
.lang-dropdown-menu{position:absolute;top:calc(100% + 8px);right:0;min-width:160px;background:var(--nav-scrolled);backdrop-filter:blur(20px) saturate(1.5);border:1px solid var(--border);border-radius:12px;padding:6px;opacity:0;visibility:hidden;transform:translateY(-8px);transition:all .25s cubic-bezier(.22,1,.36,1);z-index:200;box-shadow:0 8px 30px rgba(0,0,0,.15)}
.lang-dropdown.open .lang-dropdown-menu{opacity:1;visibility:visible;transform:translateY(0)}
.lang-dropdown-item{display:flex;align-items:center;gap:8px;padding:10px 14px;border-radius:8px;font-size:13px;font-weight:500;color:var(--text-subtle);text-decoration:none;transition:all .2s}
.lang-dropdown-item:hover{background:var(--card-bg-hover);color:var(--text)}
.lang-dropdown-item.active{color:var(--accent);font-weight:600}

/* ═══ THEME TOGGLE BUTTON ═══ */
.theme-toggle{display:inline-flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:8px;border:1px solid var(--border-input);background:transparent;color:var(--text-subtle);cursor:pointer;transition:all .25s;position:relative;overflow:hidden}
.theme-toggle:hover{border-color:var(--accent);color:var(--accent);background:rgba(var(--accent-rgb),.05)}
.theme-toggle svg{width:18px;height:18px;transition:transform .4s cubic-bezier(.22,1,.36,1),opacity .3s}
.theme-toggle .icon-sun,
.theme-toggle .icon-moon{position:absolute}
.theme-toggle .icon-sun{opacity:0;transform:rotate(-90deg) scale(.5)}
.theme-toggle .icon-moon{opacity:1;transform:rotate(0) scale(1)}

[data-theme="light"] .theme-toggle .icon-sun{opacity:1;transform:rotate(0) scale(1)}
[data-theme="light"] .theme-toggle .icon-moon{opacity:0;transform:rotate(90deg) scale(.5)}

/* Portfolio card */
.portfolio-card{background:var(--card-bg);border:1px solid var(--border);border-radius:16px;padding:32px 28px;transition:all .4s cubic-bezier(.22,1,.36,1);overflow:hidden;position:relative}
.portfolio-card:hover{border-color:var(--border-hover);transform:translateY(-6px);background:var(--card-bg-hover)}

/* Service page card */
.service-page-card{background:var(--card-bg);border:1px solid var(--border);border-radius:20px;padding:clamp(28px,4vw,48px);transition:border-color .3s}
.service-page-card:hover{border-color:var(--border-hover)}

/* Fade in sections */
.fade-section{opacity:0;transform:translateY(40px);transition:opacity .7s cubic-bezier(.22,1,.36,1),transform .7s cubic-bezier(.22,1,.36,1)}
.fade-section.visible{opacity:1;transform:translateY(0)}

/* Back link */
.back-link{display:inline-flex;align-items:center;gap:6px;font-size:13px;color:var(--text-ghost);text-decoration:none;margin-bottom:24px;transition:color .25s}
.back-link:hover{color:var(--accent)}

/* Mobile */
.burger{display:none;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer;z-index:1001;padding:8px}
.burger span{width:24px;height:2px;background:var(--text);border-radius:2px;transition:all .3s}
.mobile-menu{position:fixed;top:0;left:0;right:0;bottom:0;background:var(--mobile-bg);z-index:999;display:none;flex-direction:column;align-items:center;justify-content:center;gap:28px;backdrop-filter:blur(20px)}
.mobile-menu.active{display:flex}
.mobile-menu a{color:var(--text);text-decoration:none;font-size:24px;font-family:'Playfair Display',serif;font-weight:700}

/* Legal pages */
.legal-content{max-width:800px;margin:0 auto;padding:0 clamp(20px,6vw,80px) 100px}
.legal-content h2{font-family:'Playfair Display',serif;font-size:24px;font-weight:700;margin:48px 0 16px;color:var(--text)}
.legal-content h3{font-size:18px;font-weight:600;margin:32px 0 12px;color:var(--text-muted)}
.legal-content p{font-size:15px;color:var(--text-subtle);line-height:1.8;margin-bottom:16px}
.legal-content ul{list-style:none;padding:0;margin-bottom:16px}
.legal-content ul li{font-size:15px;color:var(--text-subtle);line-height:1.8;padding-left:20px;position:relative}
.legal-content ul li::before{content:'—';position:absolute;left:0;color:var(--accent)}
.legal-content a{color:var(--accent);text-decoration:none;transition:opacity .25s}
.legal-content a:hover{opacity:.7}

/* Solution detail responsive */
.solution-detail{animation:fadeUp .5s ease}

/* ═══ PORTFOLIO FILTERS & CARDS ═══ */
.pf-filter{display:inline-flex;align-items:center;gap:6px;padding:10px 20px;border:1px solid var(--border-input);border-radius:100px;font-size:13px;font-weight:600;cursor:pointer;transition:all .3s;background:transparent;color:var(--text-subtle);font-family:'DM Sans',sans-serif}
.pf-filter:hover{border-color:var(--border-hover);color:var(--text)}
.pf-filter.active{background:var(--accent);color:var(--accent-on);border-color:var(--accent)}
.pf-filter-count{font-family:'Space Mono',monospace;font-size:11px;opacity:.6}
.pf-filter.active .pf-filter-count{opacity:.8}

.pf-filter-sm{padding:6px 14px;border:1px solid var(--border-input);border-radius:100px;font-size:12px;font-weight:500;cursor:pointer;transition:all .3s;background:transparent;color:var(--text-faint);font-family:'DM Sans',sans-serif}
.pf-filter-sm:hover{border-color:var(--border-hover);color:var(--text-subtle)}
.pf-filter-sm.active{background:var(--card-bg-hover);color:var(--text);border-color:var(--border-hover)}

.pf-card{display:flex;flex-direction:column;background:var(--card-bg);border:1px solid var(--border);border-radius:16px;overflow:hidden;text-decoration:none;color:var(--text);transition:all .4s cubic-bezier(.22,1,.36,1)}
.pf-card:hover{border-color:var(--border-hover);transform:translateY(-6px)}
[data-theme="light"] .pf-card:hover{box-shadow:0 8px 30px rgba(0,0,0,.06)}
.pf-card.pf-hidden{display:none}

.pf-card-img{position:relative;aspect-ratio:16/10;overflow:hidden;background:var(--card-bg)}
.pf-card-img img{width:100%;height:100%;object-fit:cover;transition:transform .5s cubic-bezier(.22,1,.36,1)}
.pf-card:hover .pf-card-img img{transform:scale(1.04)}
.pf-card-overlay{position:absolute;inset:0;background:rgba(var(--bg-rgb),.6);opacity:0;transition:opacity .3s;display:flex;align-items:center;justify-content:center;backdrop-filter:blur(4px)}
.pf-card:hover .pf-card-overlay{opacity:1}
.pf-card-visit{padding:10px 24px;background:var(--accent);color:var(--accent-on);border-radius:100px;font-size:13px;font-weight:600;transform:translateY(10px);transition:transform .3s}
.pf-card:hover .pf-card-visit{transform:translateY(0)}

.pf-card-body{padding:20px 22px 24px;flex:1;display:flex;flex-direction:column}
.pf-card-title{font-family:'Playfair Display',serif;font-size:18px;font-weight:700}
.pf-card-desc{font-size:13px;color:var(--text-subtle);line-height:1.65;margin-bottom:16px;flex:1}
.pf-card-tags{display:flex;flex-wrap:wrap;gap:6px}
.pf-tag{font-size:11px;padding:4px 10px;background:var(--pill-bg);border:1px solid var(--pill-border);border-radius:100px;color:var(--pill-text);font-weight:500}

/* ═══ WHY US CARDS ═══ */
.why-card{display:flex;gap:20px;align-items:flex-start;padding:28px 24px;background:var(--card-bg);border:1px solid var(--border);border-radius:16px;transition:all .4s cubic-bezier(.22,1,.36,1)}
.why-card:hover{border-color:var(--border-hover);transform:translateY(-4px);background:var(--card-bg-hover)}
[data-theme="light"] .why-card:hover{box-shadow:0 8px 30px rgba(0,0,0,.05)}
.why-card-icon{width:52px;height:52px;border-radius:14px;background:color-mix(in srgb,var(--why-color) 10%,transparent);border:1px solid color-mix(in srgb,var(--why-color) 15%,transparent);display:flex;align-items:center;justify-content:center;font-size:24px;flex-shrink:0;transition:transform .3s}
.why-card:hover .why-card-icon{transform:scale(1.08) rotate(-3deg)}
.why-card-content{flex:1;min-width:0}
.why-card-title{font-size:17px;font-weight:600;margin-bottom:8px;color:var(--text)}
.why-card-desc{font-size:14px;color:var(--text-subtle);line-height:1.7}

@media(max-width:768px){
  .why-card{flex-direction:column;text-align:center;align-items:center}
}

/* ═══ SERVICE PILLAR CARDS (Services page) ═══ */
.service-pillar-inner{background:var(--card-bg);border:1px solid var(--border);border-radius:20px;padding:clamp(28px,4vw,40px);transition:all .4s cubic-bezier(.22,1,.36,1);position:relative;overflow:hidden}
.service-pillar-inner::before{content:'';position:absolute;top:0;left:0;width:4px;height:100%;background:var(--pillar-color);opacity:0;transition:opacity .3s;border-radius:20px 0 0 20px}
.service-pillar-inner:hover{border-color:var(--border-hover)}
.service-pillar-inner:hover::before{opacity:1}
[data-theme="light"] .service-pillar-inner{box-shadow:0 1px 3px rgba(0,0,0,.03)}
[data-theme="light"] .service-pillar-inner:hover{box-shadow:0 4px 24px rgba(0,0,0,.06)}

.service-pillar-header{display:flex;align-items:flex-start;gap:20px;margin-bottom:28px;flex-wrap:wrap}
.service-pillar-number{font-family:'Space Mono',monospace;font-size:42px;font-weight:700;color:rgba(var(--accent-rgb),.08);line-height:1;flex-shrink:0;display:none}
.service-pillar-icon{width:52px;height:52px;border-radius:14px;background:color-mix(in srgb,var(--pillar-color) 10%,transparent);border:1px solid color-mix(in srgb,var(--pillar-color) 18%,transparent);display:flex;align-items:center;justify-content:center;color:var(--pillar-color);flex-shrink:0;transition:transform .3s}
.service-pillar-inner:hover .service-pillar-icon{transform:scale(1.05)}

.service-pillar-caps{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:10px}

@media(max-width:768px){
  .service-pillar-header{flex-direction:column}
  .service-pillar-caps{grid-template-columns:1fr!important}
}

/* ═══ LARGE CAPABILITY CARDS (Category pages) ═══ */
.svc-cap-card-lg{display:flex;flex-direction:column;gap:12px;padding:28px 24px;background:var(--card-bg);border:1px solid var(--border);border-radius:16px;text-decoration:none;color:var(--text);transition:all .4s cubic-bezier(.22,1,.36,1);position:relative;overflow:hidden}
.svc-cap-card-lg::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:var(--cap-color);opacity:0;transition:opacity .3s}
.svc-cap-card-lg:hover{border-color:color-mix(in srgb,var(--cap-color) 30%,transparent);transform:translateY(-6px);background:var(--card-bg-hover)}
.svc-cap-card-lg:hover::before{opacity:1}
[data-theme="light"] .svc-cap-card-lg:hover{box-shadow:0 8px 30px rgba(0,0,0,.06)}
.svc-cap-lg-icon{font-size:32px;margin-bottom:4px}
.svc-cap-lg-title{font-family:'Playfair Display',serif;font-size:20px;font-weight:700;line-height:1.2}
.svc-cap-lg-desc{font-size:14px;color:var(--text-subtle);line-height:1.65;flex:1}
.svc-cap-lg-link{font-size:13px;font-weight:600;color:var(--accent);transition:transform .3s;display:inline-block}
.svc-cap-card-lg:hover .svc-cap-lg-link{transform:translateX(6px)}

/* ═══ INTERACTIVE SERVICE TABS (Homepage) ═══ */
.svc-tab{display:inline-flex;align-items:center;gap:8px;padding:14px 28px;border:1px solid var(--border-input);border-radius:100px;font-size:14px;font-weight:600;cursor:pointer;transition:all .35s cubic-bezier(.22,1,.36,1);background:transparent;color:var(--text-subtle);white-space:nowrap;font-family:'DM Sans',sans-serif;letter-spacing:.3px}
.svc-tab:hover{border-color:var(--border-hover);color:var(--text);transform:translateY(-2px)}
.svc-tab.active{background:var(--accent);color:var(--accent-on);border-color:var(--accent);box-shadow:0 4px 20px var(--shadow-cta);transform:translateY(-2px)}
.svc-tab svg{opacity:.6;transition:opacity .3s}
.svc-tab.active svg,.svc-tab:hover svg{opacity:1}

.svc-panel{display:none;animation:svcPanelIn .5s cubic-bezier(.22,1,.36,1)}
.svc-panel.active{display:block}
@keyframes svcPanelIn{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}

.svc-panel-inner{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:start;background:var(--card-bg);border:1px solid var(--border);border-radius:20px;padding:clamp(28px,4vw,48px);transition:border-color .3s}
.svc-panel-inner:hover{border-color:var(--border-hover)}
[data-theme="light"] .svc-panel-inner{box-shadow:0 2px 12px rgba(0,0,0,.04)}

.svc-icon-wrap{width:56px;height:56px;border-radius:14px;background:color-mix(in srgb,var(--svc-color) 10%,transparent);border:1px solid color-mix(in srgb,var(--svc-color) 20%,transparent);display:flex;align-items:center;justify-content:center;color:var(--svc-color);margin-bottom:24px;transition:transform .3s}
.svc-panel-inner:hover .svc-icon-wrap{transform:scale(1.05)}

.svc-panel-title{font-family:'Playfair Display',serif;font-size:clamp(24px,3vw,34px);font-weight:700;margin-bottom:16px;line-height:1.2;color:var(--text)}
.svc-panel-desc{font-size:15px;color:var(--text-subtle);line-height:1.75;margin-bottom:28px;max-width:500px}

.svc-panel-stats{display:flex;gap:24px;margin-bottom:32px;flex-wrap:wrap}
.svc-mini-stat{display:flex;flex-direction:column;gap:2px}
.svc-mini-val{font-family:'Space Mono',monospace;font-size:22px;font-weight:700;color:var(--accent);line-height:1}
.svc-mini-label{font-size:11px;color:var(--text-faint);text-transform:uppercase;letter-spacing:1px;font-weight:500}

.svc-caps-label{display:block;font-size:11px;font-family:'Space Mono',monospace;color:var(--text-faint);text-transform:uppercase;letter-spacing:2px;margin-bottom:16px}
.svc-caps-grid{display:grid;grid-template-columns:1fr;gap:10px}

.svc-cap-card{display:flex;align-items:center;gap:14px;padding:16px 18px;background:var(--card-bg);border:1px solid var(--border);border-radius:12px;text-decoration:none;color:var(--text);transition:all .3s cubic-bezier(.22,1,.36,1);cursor:pointer}
.svc-cap-card:hover{border-color:color-mix(in srgb,var(--cap-color) 40%,transparent);background:color-mix(in srgb,var(--cap-color) 5%,transparent);transform:translateX(6px)}
[data-theme="light"] .svc-cap-card:hover{box-shadow:0 2px 12px rgba(0,0,0,.05)}
.svc-cap-icon{font-size:22px;flex-shrink:0;width:36px;height:36px;display:flex;align-items:center;justify-content:center;background:color-mix(in srgb,var(--cap-color) 8%,transparent);border-radius:8px}
.svc-cap-name{flex:1;font-size:14px;font-weight:500}
.svc-cap-arrow{font-size:16px;color:var(--text-faint);transition:all .3s;transform:translateX(0)}
.svc-cap-card:hover .svc-cap-arrow{color:var(--cap-color,var(--accent));transform:translateX(4px)}

/* ═══ GLOBAL SECTION CENTERING ═══ */
/* Centers all section headers, labels, titles, descriptions across all pages */
.fade-section > div > div:first-child {
  text-align: center;
}
.fade-section > div > div:first-child > p {
  margin-left: auto;
  margin-right: auto;
}

/* Center the "Why Us" number cards grid title block */
.fade-section > div > div[style*="margin-bottom"] {
  text-align: center;
}
.fade-section > div > div[style*="margin-bottom"] > p {
  margin-left: auto;
  margin-right: auto;
}

/* Center CTA section (already centered via inline style, reinforce) */
.cta-glow {
  text-align: center;
}

/* Center section labels (Space Mono uppercase labels like "01 — OS NOSSOS SERVIÇOS") */
.fade-section span[style*="Space Mono"],
.fade-section span[style*="letter-spacing:3px"],
.fade-section span[style*="letter-spacing: 3px"] {
  text-align: center;
  display: block;
}

/* Center page-level titles on inner pages (services, portfolio, about, blog, contact) */
main > div:first-child,
main > section:first-child > div {
  text-align: center;
}
main > div:first-child > p,
main > section:first-child > div > p {
  margin-left: auto;
  margin-right: auto;
}

/* Don't center card/panel internals, form content, legal content, or footer */
.service-page-card,
.site-card,
.portfolio-card,
.legal-content,
.form-label,
.footer-link,
#contactFormArea,
.mobile-menu {
  text-align: left;
}
.service-page-card *,
.legal-content * {
  text-align: left;
}

/* ═══ INLINE STYLE OVERRIDES ═══ */
/* These override hardcoded inline colors from PHP templates */

/* Force any inline white text to use theme var */
[data-theme="light"] [style*="color:rgba(255,255,255"],
[data-theme="light"] [style*="color: rgba(255,255,255"],
[data-theme="light"] [style*="color:#fafafa"],
[data-theme="light"] [style*="color: #fafafa"] {
  color: var(--text) !important;
}

/* Force accent color in light mode */
[data-theme="light"] [style*="color:#facc15"],
[data-theme="light"] [style*="color: #facc15"] {
  color: var(--accent) !important;
}

/* Force backgrounds in light mode */
[data-theme="light"] [style*="background:#09090b"],
[data-theme="light"] [style*="background: #09090b"],
[data-theme="light"] [style*="background-color:#09090b"],
[data-theme="light"] [style*="background-color: #09090b"] {
  background: var(--bg) !important;
  background-color: var(--bg) !important;
}

/* Force borders in light mode */
[data-theme="light"] [style*="border-color:rgba(255,255,255"],
[data-theme="light"] [style*="border:1px solid rgba(255,255,255"],
[data-theme="light"] [style*="border: 1px solid rgba(255,255,255"] {
  border-color: var(--border) !important;
}

/* Force inline rgba white text colors to theme color in light mode */
[data-theme="light"] [style*="rgba(255,255,255,0."],
[data-theme="light"] [style*="rgba(255,255,255,."],
[data-theme="light"] [style*="rgba(255, 255, 255, 0."],
[data-theme="light"] [style*="rgba(255, 255, 255, ."] {
  color: var(--text-subtle) !important;
}

/* ═══ SMOOTH TRANSITIONS ═══ */
.nav, .site-card, .portfolio-card, .service-page-card,
.form-input, .form-select, .form-textarea,
.lang-toggle, .theme-toggle, .burger span,
.mobile-menu, .mega-menu, .cta-btn, .cta-btn-outline,
.feature-pill, .stat-value, .stat-label, .form-label,
.footer-link, .back-link, .nav-link, .nav-logo-text,
.nav-logo-text span, .legal-content h2, .legal-content h3,
.legal-content p, .legal-content ul li, .solution-tab {
  transition-property: background, background-color, color, border-color, box-shadow, transform, opacity;
  transition-duration: .3s;
  transition-timing-function: ease;
}

@media(max-width:1024px){
  .footer-grid{grid-template-columns:1fr 1fr 1fr!important;gap:32px!important}
}

@media(max-width:768px){
  .hero-title{font-size:clamp(36px,9vw,52px)!important}
  .desktop-nav{display:none!important}
  .desktop-only{display:none!important}
  .burger{display:flex!important}
  .sites-grid{grid-template-columns:1fr!important}
  .stats-row{grid-template-columns:repeat(2,1fr)!important;gap:32px!important}
  .solutions-tabs{flex-wrap:wrap!important;justify-content:center!important}
  .solution-detail{flex-direction:column!important}
  .footer-cols{flex-direction:column!important;gap:32px!important}
  .footer-grid{grid-template-columns:1fr!important;gap:32px!important}
  .footer-bottom-grid{grid-template-columns:1fr!important;gap:24px!important}
  .svc-panel-inner{grid-template-columns:1fr!important;gap:32px!important}
  .svc-panel-stats{gap:16px!important}
  .hero-buttons{flex-direction:column!important;align-items:stretch!important}
  .hero-buttons .cta-btn{justify-content:center}
  .contact-layout{grid-template-columns:1fr!important}
  .form-row{grid-template-columns:1fr!important}
  .about-what-grid{grid-template-columns:1fr!important}
}

/* ══════════════════════════════════════════
   Accessibility & UX v2.2 — added 2026-04-17
   ══════════════════════════════════════════ */

/* M16 — Respeitar preferência de movimento reduzido */
@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after {
    animation-duration: 0.01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.01ms !important;
    scroll-behavior: auto !important;
  }
}

/* M11 — Esconder scroll hint no mobile (estava cortado no viewport) */
@media (max-width: 768px) {
  .hero-scroll-hint { display: none !important; }
}

/* L1 parcial — Focus states acessíveis (para quem usa Tab) */
:focus-visible {
  outline: 2px solid var(--accent);
  outline-offset: 3px;
  border-radius: 4px;
}

/* Selos de spinner usado no form de contacto */
@keyframes spin { from { transform: rotate(0deg); } to { transform: rotate(360deg); } }

/* ══════════════════════════════════════════
   Self-hosted Fonts v2.3 — added 2026-04-17
   M10 + L2 + L8 — fonts locais (latin subset)
   Zero external requests. Zero tracking.
   ══════════════════════════════════════════ */

/* ─── DM Sans (body) ─── */
@font-face {
  font-family: 'DM Sans';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url('/fonts/dm-sans-400.woff2') format('woff2');
}
@font-face {
  font-family: 'DM Sans';
  font-style: italic;
  font-weight: 400;
  font-display: swap;
  src: url('/fonts/dm-sans-400-italic.woff2') format('woff2');
}
@font-face {
  font-family: 'DM Sans';
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url('/fonts/dm-sans-500.woff2') format('woff2');
}
@font-face {
  font-family: 'DM Sans';
  font-style: normal;
  font-weight: 600;
  font-display: swap;
  src: url('/fonts/dm-sans-600.woff2') format('woff2');
}
@font-face {
  font-family: 'DM Sans';
  font-style: normal;
  font-weight: 700;
  font-display: swap;
  src: url('/fonts/dm-sans-700.woff2') format('woff2');
}

/* ─── Playfair Display (headings) ─── */
@font-face {
  font-family: 'Playfair Display';
  font-style: normal;
  font-weight: 700;
  font-display: swap;
  src: url('/fonts/playfair-700.woff2') format('woff2');
}
@font-face {
  font-family: 'Playfair Display';
  font-style: italic;
  font-weight: 700;
  font-display: swap;
  src: url('/fonts/playfair-700-italic.woff2') format('woff2');
}
@font-face {
  font-family: 'Playfair Display';
  font-style: normal;
  font-weight: 800;
  font-display: swap;
  src: url('/fonts/playfair-800.woff2') format('woff2');
}

/* ─── Space Mono (accent monospace) ─── */
@font-face {
  font-family: 'Space Mono';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url('/fonts/space-mono-400.woff2') format('woff2');
}
@font-face {
  font-family: 'Space Mono';
  font-style: normal;
  font-weight: 700;
  font-display: swap;
  src: url('/fonts/space-mono-700.woff2') format('woff2');
}

/* ══════════════════════════════════════════════════════════
   DAILY SHOT SOLUTIONS v3.0 — REDESIGN GLOBAL (2026-04-24)
   Estética: Resend + Vercel
   Dark-only forçado · Geist Sans/Mono · Paleta minimalista
   Este bloco OVERRIDES tudo acima. Preserva layout, muda visual.
   ══════════════════════════════════════════════════════════ */

/* ─── Geist self-hosted ─── */
@font-face { font-family:'Geist'; font-style:normal; font-weight:400; font-display:swap; src:url('/fonts/geist/geist-400.woff2') format('woff2'); }
@font-face { font-family:'Geist'; font-style:normal; font-weight:500; font-display:swap; src:url('/fonts/geist/geist-500.woff2') format('woff2'); }
@font-face { font-family:'Geist'; font-style:normal; font-weight:600; font-display:swap; src:url('/fonts/geist/geist-600.woff2') format('woff2'); }
@font-face { font-family:'Geist'; font-style:normal; font-weight:700; font-display:swap; src:url('/fonts/geist/geist-700.woff2') format('woff2'); }
@font-face { font-family:'Geist Mono'; font-style:normal; font-weight:400; font-display:swap; src:url('/fonts/geist/geist-mono-400.woff2') format('woff2'); }
@font-face { font-family:'Geist Mono'; font-style:normal; font-weight:500; font-display:swap; src:url('/fonts/geist/geist-mono-500.woff2') format('woff2'); }
@font-face { font-family:'Geist Mono'; font-style:normal; font-weight:700; font-display:swap; src:url('/fonts/geist/geist-mono-700.woff2') format('woff2'); }

/* ─── Tokens v3 (DARK como default; light override mais abaixo) ─── */
:root {
  --bg: #0a0a0a;
  --bg-rgb: 10, 10, 10;
  --text: #fafafa;
  --text-rgb: 250, 250, 250;
  --text-muted: #a1a1aa;
  --text-subtle: #71717a;
  --text-faint: #52525b;
  --text-ghost: #71717a;
  --border: rgba(255,255,255,.08);
  --border-hover: rgba(255,255,255,.18);
  --border-input: rgba(255,255,255,.08);
  --card-bg: rgba(255,255,255,.02);
  --card-bg-hover: rgba(255,255,255,.04);
  --nav-scrolled: rgba(10,10,10,.8);
  --mega-bg: rgba(10,10,10,.96);
  --mobile-bg: rgba(10,10,10,.98);
  --input-bg: rgba(255,255,255,.04);
  --input-bg-focus: rgba(255,255,255,.06);
  --select-option-bg: #111;
  --grain-opacity: 0;
  --logo-text-span: rgba(255,255,255,.5);
  --select-arrow: rgba(255,255,255,.4);
  --pill-bg: rgba(249,115,22,.08);
  --pill-border: rgba(249,115,22,.2);
  --pill-text: #fb923c;
  --shadow-cta: rgba(249,115,22,.15);
  --outline-border: rgba(255,255,255,.15);
  --selection-bg: rgba(249,115,22,.25);
  --selection-text: #fff;
  --accent: #f97316;
  --accent-hover: #ea580c;
  --accent-rgb: 249, 115, 22;
  --accent-on: #fff;
  --hero-glow-1: rgba(249,115,22,.05);
  --hero-glow-2: transparent;
  --hero-glow-3: transparent;
  --section-glow: transparent;
  --cta-section-bg: rgba(255,255,255,.02);
  --cta-section-border: rgba(255,255,255,.08);
  --font-sans: 'Geist', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
  --font-mono: 'Geist Mono', 'JetBrains Mono', Consolas, monospace;
  /* Surface tokens — usados pelos cards no redesign v3 (substituem hard-coded rgba(255,255,255,...)) */
  --surface-1: rgba(255,255,255,.02);
  --surface-2: rgba(255,255,255,.03);
  --surface-3: rgba(255,255,255,.04);
  --surface-4: rgba(255,255,255,.05);
  --grid-line: rgba(255,255,255,.03);
  color-scheme: dark;
}

/* ─── LIGHT THEME (v3) ─── */
html[data-theme="light"] {
  --bg: #fafafa;
  --bg-rgb: 250, 250, 250;
  --text: #18181b;
  --text-rgb: 24, 24, 27;
  --text-muted: #52525b;
  --text-subtle: #71717a;
  --text-faint: #a1a1aa;
  --text-ghost: #71717a;
  --border: rgba(0,0,0,.08);
  --border-hover: rgba(0,0,0,.18);
  --border-input: rgba(0,0,0,.10);
  --card-bg: #ffffff;
  --card-bg-hover: #f4f4f5;
  --nav-scrolled: rgba(250,250,250,.85);
  --mega-bg: rgba(255,255,255,.98);
  --mobile-bg: rgba(255,255,255,.98);
  --input-bg: #ffffff;
  --input-bg-focus: #ffffff;
  --select-option-bg: #ffffff;
  --grain-opacity: 0;
  --logo-text-span: rgba(0,0,0,.5);
  --select-arrow: rgba(0,0,0,.4);
  --pill-bg: rgba(249,115,22,.08);
  --pill-border: rgba(249,115,22,.25);
  --pill-text: #ea580c;
  --shadow-cta: rgba(249,115,22,.18);
  --outline-border: rgba(0,0,0,.15);
  --selection-bg: rgba(249,115,22,.25);
  --selection-text: #18181b;
  --accent: #f97316;
  --accent-hover: #ea580c;
  --accent-rgb: 249, 115, 22;
  --accent-on: #ffffff;
  --hero-glow-1: rgba(249,115,22,.06);
  --hero-glow-2: transparent;
  --hero-glow-3: transparent;
  --section-glow: transparent;
  --cta-section-bg: #ffffff;
  --cta-section-border: rgba(0,0,0,.08);
  /* Surfaces para light: usar branco puro para contraste limpo */
  --surface-1: #ffffff;
  --surface-2: #ffffff;
  --surface-3: #f8f8f8;
  --surface-4: #f4f4f5;
  --grid-line: rgba(0,0,0,.04);
  color-scheme: light;
}

/* ─── Body base ─── */
html, body {
  background: var(--bg) !important;
  color: var(--text) !important;
}
body {
  font-family: var(--font-sans) !important;
  -webkit-font-smoothing: antialiased;
  transition: background .3s ease, color .3s ease;
}

/* ─── Grain: desligar ─── */
.grain::after { display: none !important; }

/* ─── Hero background — simplificar ─── */
.hero-bg::before, .hero-bg::after { display: none !important; }
.hero-bg-orb {
  background: radial-gradient(circle, rgba(var(--accent-rgb),.06) 0%, transparent 55%) !important;
  animation: none !important;
  top: -300px !important; left: 50% !important; right: auto !important;
  transform: translateX(-50%) !important;
  width: 800px !important; height: 800px !important;
}
.hero-bg-grid {
  opacity: 1 !important;
  background-size: 64px 64px !important;
  background-image:
    linear-gradient(var(--grid-line) 1px, transparent 1px),
    linear-gradient(90deg, var(--grid-line) 1px, transparent 1px) !important;
  mask-image: radial-gradient(ellipse 80% 60% at top, #000 0%, transparent 70%) !important;
  -webkit-mask-image: radial-gradient(ellipse 80% 60% at top, #000 0%, transparent 70%) !important;
}
.section-glow::before { display: none !important; }

/* ─── Tipografia: Playfair → Geist ─── */
h1, h2, h3, h4, h5, h6,
.hero-title,
.why-card-title,
.svc-panel-title,
[style*="Playfair Display"] {
  font-family: var(--font-sans) !important;
  font-weight: 500 !important;
  letter-spacing: -.03em !important;
}
.hero-title,
.hero-title span {
  background: none !important;
  background-image: none !important;
  -webkit-background-clip: initial !important;
  -webkit-text-fill-color: initial !important;
  background-clip: initial !important;
  color: var(--text) !important;
  font-weight: 500 !important;
  letter-spacing: -.035em !important;
}
.hero-title span { color: var(--text-muted) !important; }
[style*="Space Mono"],
[style*="'Space Mono'"] { font-family: var(--font-mono) !important; }

/* ─── Nav ─── */
.nav-logo-icon {
  background: transparent !important;
  background-image: none !important;
  border: 1px solid var(--text) !important;
  color: var(--text) !important;
  font-family: var(--font-mono) !important;
  font-weight: 500 !important;
  font-size: 11px !important;
  border-radius: 5px !important;
  width: 28px !important; height: 28px !important;
}
.nav-logo-text {
  font-family: var(--font-mono) !important;
  font-weight: 500 !important;
  font-size: 14px !important;
  letter-spacing: -.02em !important;
}
.nav-logo-text span { color: var(--text-muted) !important; font-weight: 400 !important; }
.nav-link { color: var(--text-muted) !important; font-weight: 400 !important; font-size: 14px !important; }
.nav-link:hover, .nav-link.active { color: var(--text) !important; }
.nav-link::after { display: none !important; }
.nav.scrolled {
  background: var(--nav-scrolled) !important;
  backdrop-filter: blur(16px) saturate(1.5) !important;
  -webkit-backdrop-filter: blur(16px) saturate(1.5) !important;
  border-bottom: 1px solid var(--border) !important;
}

/* ─── CTAs Resend-style ─── */
.cta-btn {
  background: var(--text) !important;
  background-image: none !important;
  color: var(--bg) !important;
  border-radius: 6px !important;
  padding: 11px 18px !important;
  font-family: var(--font-sans) !important;
  font-size: 14px !important;
  font-weight: 500 !important;
  letter-spacing: -.01em !important;
  border: 1px solid var(--text) !important;
  box-shadow: none !important;
}
.cta-btn:hover {
  background: #e5e5e5 !important;
  border-color: #e5e5e5 !important;
  box-shadow: none !important;
  transform: translateY(-1px) !important;
  color: var(--bg) !important;
}
.cta-btn-outline {
  background: transparent !important;
  color: var(--text) !important;
  border: 1px solid var(--border) !important;
}
.cta-btn-outline:hover {
  background: var(--surface-2) !important;
  border-color: var(--border-hover) !important;
  color: var(--text) !important;
  box-shadow: none !important;
}

/* ─── Feature pills / eyebrows ─── */
.feature-pill {
  background: transparent !important;
  border: 1px solid var(--border) !important;
  color: var(--text-muted) !important;
  font-family: var(--font-mono) !important;
  font-size: 12px !important;
  font-weight: 400 !important;
  letter-spacing: 0 !important;
  padding: 6px 12px !important;
  border-radius: 999px !important;
}

/* ─── Stats (mono massivo) ─── */
.stat-value {
  font-family: var(--font-mono) !important;
  font-weight: 500 !important;
  letter-spacing: -.03em !important;
  color: var(--text) !important;
}
.stat-label {
  font-family: var(--font-mono) !important;
  text-transform: uppercase !important;
  letter-spacing: .06em !important;
  font-size: 11px !important;
  color: var(--text-muted) !important;
}

/* ─── Why-us cards monocromáticos ─── */
.why-card {
  background: var(--surface-1) !important;
  border: 1px solid var(--border) !important;
  border-radius: 12px !important;
  transition: background .2s, border-color .2s !important;
  padding: 28px !important;
}
.why-card:hover {
  background: var(--surface-3) !important;
  border-color: var(--border-hover) !important;
  transform: none !important;
  box-shadow: none !important;
}
.why-card-icon {
  background: transparent !important;
  background-image: none !important;
  color: var(--text-muted) !important;
  font-size: 22px !important;
  width: auto !important; height: auto !important;
  padding: 0 !important;
  margin-bottom: 16px !important;
  transition: color .2s !important;
}
.why-card:hover .why-card-icon { color: var(--accent) !important; }
.why-card-title {
  font-family: var(--font-sans) !important;
  font-weight: 500 !important;
  font-size: 16px !important;
  color: var(--text) !important;
  margin-bottom: 8px !important;
  letter-spacing: -.01em !important;
}
.why-card-desc { color: var(--text-muted) !important; font-size: 14px !important; line-height: 1.6 !important; }

/* ─── Service panels / tabs ─── */
.svc-panel {
  background: var(--surface-1) !important;
  border: 1px solid var(--border) !important;
  border-radius: 12px !important;
}
.svc-icon-wrap {
  background: transparent !important;
  background-image: none !important;
  border: 1px solid var(--border) !important;
  color: var(--text) !important;
  border-radius: 8px !important;
}
.svc-tab {
  background: transparent !important;
  border: 1px solid var(--border) !important;
  color: var(--text-muted) !important;
  border-radius: 6px !important;
  font-family: var(--font-sans) !important;
  font-weight: 500 !important;
  font-size: 13px !important;
}
.svc-tab:hover { color: var(--text) !important; border-color: var(--border-hover) !important; }
.svc-tab.active {
  background: var(--text) !important;
  color: var(--bg) !important;
  border-color: var(--text) !important;
}
.svc-cap-card {
  background: var(--surface-1) !important;
  border: 1px solid var(--border) !important;
  color: var(--text) !important;
  border-radius: 8px !important;
}
.svc-cap-card:hover {
  border-color: var(--border-hover) !important;
  background: var(--surface-3) !important;
  transform: none !important;
}
.svc-mini-val {
  font-family: var(--font-mono) !important;
  font-weight: 500 !important;
  color: var(--text) !important;
  letter-spacing: -.02em !important;
}
.svc-mini-label {
  font-family: var(--font-mono) !important;
  color: var(--text-muted) !important;
  text-transform: uppercase !important;
  letter-spacing: .06em !important;
  font-size: 10px !important;
}
.svc-caps-label {
  font-family: var(--font-mono) !important;
  color: var(--text-muted) !important;
  text-transform: uppercase !important;
  letter-spacing: .06em !important;
  font-size: 11px !important;
}

/* ─── Cards globais (portfolio, site-card, service) ─── */
.site-card, .pf-card, .portfolio-card, .service-page-card {
  background: var(--surface-1) !important;
  border: 1px solid var(--border) !important;
  border-radius: 12px !important;
  transition: background .2s, border-color .2s, transform .2s !important;
}
.site-card:hover, .pf-card:hover, .portfolio-card:hover, .service-page-card:hover {
  background: var(--surface-3) !important;
  border-color: var(--border-hover) !important;
  transform: translateY(-2px) !important;
  box-shadow: none !important;
}

/* ─── Forms ─── */
.form-input, .form-textarea, .form-select {
  background: var(--surface-2) !important;
  border: 1px solid var(--border) !important;
  color: var(--text) !important;
  font-family: var(--font-sans) !important;
  border-radius: 6px !important;
}
.form-input:focus, .form-textarea:focus, .form-select:focus {
  border-color: var(--text-muted) !important;
  outline: none !important;
  background: var(--surface-4) !important;
  box-shadow: none !important;
}
.form-label {
  font-family: var(--font-mono) !important;
  text-transform: uppercase !important;
  letter-spacing: .06em !important;
  font-size: 11px !important;
  color: var(--text-muted) !important;
}

/* ─── Footer ─── */
.footer-link {
  color: var(--text-muted) !important;
  transition: color .15s !important;
  font-size: 13px !important;
}
.footer-link:hover { color: var(--text) !important; }

/* ─── Back-link ─── */
.back-link {
  color: var(--text-muted) !important;
  font-family: var(--font-mono) !important;
  font-size: 12px !important;
  text-transform: uppercase !important;
  letter-spacing: .06em !important;
  text-decoration: none !important;
}
.back-link:hover { color: var(--text) !important; }

/* ─── CTA glow final ─── */
.cta-glow {
  background: var(--surface-1) !important;
  border: 1px solid var(--border) !important;
  border-radius: 16px !important;
}
.cta-glow::before { display: none !important; }

/* ─── Breadcrumbs ─── */
.breadcrumbs {
  font-family: var(--font-mono) !important;
  font-size: 12px !important;
  color: var(--text-muted) !important;
}

/* ─── Pulse rings — manter simpler ─── */
@keyframes pulse-ring-v3 { 0%,100%{transform:scale(1);opacity:1} 50%{transform:scale(1.6);opacity:.4} }

/* ─── Lang dropdown ─── */
.lang-toggle {
  background: transparent !important;
  border: 1px solid var(--border) !important;
  color: var(--text-muted) !important;
  font-family: var(--font-mono) !important;
  font-size: 12px !important;
  border-radius: 6px !important;
}
.lang-toggle:hover { color: var(--text) !important; border-color: var(--border-hover) !important; }
.lang-dropdown-menu {
  background: var(--bg) !important;
  border: 1px solid var(--border) !important;
  border-radius: 8px !important;
}
.lang-dropdown-item { color: var(--text-muted) !important; font-family: var(--font-sans) !important; }
.lang-dropdown-item:hover, .lang-dropdown-item.active {
  color: var(--text) !important;
  background: var(--surface-3) !important;
}

/* ══════════════════════════════════════════════════════════
   v3.1 — LEFT ALIGN global (heros + section headers)
   Heros em <header> e section headers (eyebrow + title + lead)
   passam a alinhados à esquerda. CTA final mantém-se centrado.
   ══════════════════════════════════════════════════════════ */

/* ─── Heros de páginas que usam <header> (about, services, portfolio, contact, blog) ─── */
body header > div[style*="text-align:center"] {
  text-align: left !important;
  max-width: 1200px !important;
}
/* feature-pill dentro do hero: remove auto-center */
body header > div[style*="text-align:center"] .feature-pill,
body header > div[style*="text-align:center"] > div[style*="margin:0 auto"],
body header > div[style*="text-align:center"] > div[style*="margin:24px auto"] {
  margin-left: 0 !important;
  margin-right: 0 !important;
}
/* H1 e parágrafos dentro do hero */
body header > div[style*="text-align:center"] h1,
body header > div[style*="text-align:center"] p,
body header > div[style*="text-align:center"] > div > p {
  margin-left: 0 !important;
  margin-right: 0 !important;
  text-align: left !important;
}
/* Buttons do hero (grupo de CTAs) */
body header > div[style*="text-align:center"] [class*="hero-buttons"],
body header > div[style*="text-align:center"] > div[style*="justify-content:center"] {
  justify-content: flex-start !important;
}

/* ─── Section headers centrados (services, why-us, code showcase) ─── */
/* (v3.1 left-align override removed — section heads now respect their own
   inline text-align:center as defined in the markup) */

/* ─── Stats row: centrado em todo o site ─── */
.stats-row {
  margin-left: auto !important;
  margin-right: auto !important;
  text-align: center !important;
}
.stats-row .stat-item,
.stats-row .stat-value,
.stats-row .stat-label {
  text-align: center !important;
}

/* ─── CTA glow final: MANTÉM centrado (estilístico) ─── */
/* Override qualquer regra v3.1 acima — CTA section continua center */
.cta-glow {
  text-align: center !important;
}
.cta-glow h2,
.cta-glow p,
.cta-glow span {
  text-align: center !important;
  margin-left: auto !important;
  margin-right: auto !important;
}
.cta-glow > div[style*="justify-content:center"] {
  justify-content: center !important;
}

/* ─── Hero-v3 da home já está left-aligned (não afectar) ─── */
.hero-v3 { text-align: left; }

/* ─── Hero-sec (secondary pages: about, services, portfolio, contact, blog) ─── */
.hero-sec { text-align: left; }
@media (max-width: 768px) {
  .hero-sec { padding: 72px 0 48px !important; }
  .hero-sec h1 { font-size: clamp(34px, 8.5vw, 52px) !important; letter-spacing: -.025em !important; }
  .hero-sec p { font-size: 15px !important; }
  .hero-sec .feature-pill { font-size: 11px !important; padding: 5px 10px !important; }
}

/* ════════════════════════════════════════════════════════════
   PORTFOLIO v4 — Engineering-first redesign
   Namespace: .pf-* (everything scoped, no global pollution)
   ════════════════════════════════════════════════════════════ */

/* Reset some inherited rules from the global v3 .fade-section overrides
   that would interfere with our text alignment.
   Hero is centered; other sections are left-aligned but with centered section heads. */
.pf-featured, .pf-grid-section, .pf-network, .pf-cta {
  text-align: left !important;
}
.pf-featured *, .pf-grid-section *, .pf-network *, .pf-cta * {
  text-align: inherit;
}
.pf-hero, .pf-hero * {
  text-align: center !important;
}
.pf-hero-inner {
  text-align: center !important;
}
/* Explicit override for the global "first section" centering — hero is center, that's fine */
main > section.pf-hero,
main > section.pf-hero > .pf-hero-inner,
main > section.pf-hero > .pf-hero-inner > p {
  text-align: center !important;
  margin-left: auto !important;
  margin-right: auto !important;
}

/* ─── HERO ───────────────────────────────────────────────── */
.pf-hero {
  padding: clamp(96px, 14vw, 160px) clamp(20px, 6vw, 80px) clamp(64px, 8vw, 120px);
  position: relative;
  overflow: hidden;
}
.pf-hero::before {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0; height: 100%;
  background-image:
    linear-gradient(var(--grid-line) 1px, transparent 1px),
    linear-gradient(90deg, var(--grid-line) 1px, transparent 1px);
  background-size: 64px 64px;
  mask-image: radial-gradient(ellipse 80% 60% at 30% 20%, #000 0%, transparent 70%);
  -webkit-mask-image: radial-gradient(ellipse 80% 60% at 30% 20%, #000 0%, transparent 70%);
  pointer-events: none;
  opacity: .6;
}
.pf-hero-inner {
  max-width: 1280px;
  margin: 0 auto;
  position: relative;
  z-index: 1;
}

/* Eyebrow with status dot */
.pf-eyebrow {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  font-family: var(--font-mono);
  font-size: 12px;
  font-weight: 500;
  color: var(--text-muted);
  letter-spacing: .02em;
  margin: 0 auto clamp(32px, 4vw, 48px);
  padding: 8px 14px;
  border: 1px solid var(--border);
  border-radius: 100px;
  background: var(--surface-1);
}
.pf-hero-inner > .pf-eyebrow {
  display: flex;
  width: fit-content;
  margin-left: auto;
  margin-right: auto;
}
.pf-status-dot {
  width: 7px;
  height: 7px;
  border-radius: 50%;
  background: #22c55e;
  box-shadow: 0 0 12px rgba(34,197,94,.6);
  animation: pfPulse 2s ease-in-out infinite;
  flex-shrink: 0;
}
@keyframes pfPulse {
  0%, 100% { opacity: 1; transform: scale(1); }
  50% { opacity: .4; transform: scale(.85); }
}
.pf-eyebrow-sep { color: var(--text-faint); }
.pf-eyebrow-live { color: #22c55e; font-weight: 500; }

/* Massive title — oversized typography as primary visual */
.pf-hero-title {
  font-family: var(--font-sans) !important;
  font-size: clamp(44px, 7vw, 96px);
  font-weight: 500 !important;
  line-height: .95;
  letter-spacing: -.04em;
  margin: 0 0 clamp(40px, 6vw, 64px);
  color: var(--text);
  text-align: center !important;
}
.pf-title-line {
  display: block;
  text-align: center !important;
}
.pf-title-accent {
  color: var(--accent);
  font-style: italic;
  font-weight: 400 !important;
}

/* Bottom: description centered, stats below in a horizontal row */
.pf-hero-bottom {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: clamp(40px, 5vw, 64px);
  text-align: center !important;
}
.pf-hero-desc {
  font-size: clamp(15px, 1.5vw, 18px);
  line-height: 1.65;
  color: var(--text-muted);
  max-width: 620px;
  margin: 0 auto;
  text-align: center !important;
}

/* Stats — 1 big number centered, then 3 minis in horizontal row below */
.pf-hero-stats {
  display: flex;
  flex-direction: column;
  gap: 28px;
  align-items: center;
  width: 100%;
}
.pf-stat-big {
  text-align: center;
}
.pf-stat-big-num {
  font-family: var(--font-mono);
  font-size: clamp(64px, 9vw, 120px);
  font-weight: 500;
  line-height: 1;
  color: var(--text);
  letter-spacing: -.04em;
  display: inline-flex;
  align-items: baseline;
}
.pf-stat-big-plus {
  font-size: .55em;
  color: var(--accent);
  margin-left: 2px;
  font-weight: 500;
}
.pf-stat-big-label {
  font-family: var(--font-mono);
  font-size: 11px;
  font-weight: 500;
  color: var(--text-faint);
  text-transform: uppercase;
  letter-spacing: .15em;
  margin-top: 12px;
  text-align: center;
}
.pf-stat-row {
  display: flex;
  gap: clamp(32px, 5vw, 64px);
  padding-top: 28px;
  border-top: 1px solid var(--border);
  width: 100%;
  max-width: 720px;
  justify-content: center;
}
.pf-stat-mini {
  text-align: center;
}
.pf-stat-mini-num {
  font-family: var(--font-mono);
  font-size: clamp(20px, 2vw, 26px);
  font-weight: 500;
  color: var(--text);
  line-height: 1;
}
.pf-stat-mini-label {
  font-family: var(--font-mono);
  font-size: 10px;
  color: var(--text-faint);
  text-transform: uppercase;
  letter-spacing: .12em;
  margin-top: 8px;
}

/* ─── SECTION HEADER (shared) ────────────────────────────── */
.pf-section-head {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 16px;
  margin-bottom: clamp(48px, 6vw, 80px);
  padding-bottom: 32px;
  border-bottom: 1px solid var(--border);
  text-align: center !important;
}
.pf-section-num {
  font-family: var(--font-mono);
  font-size: clamp(32px, 4vw, 48px);
  font-weight: 500;
  color: var(--text-faint);
  line-height: 1;
  letter-spacing: -.02em;
  text-align: center !important;
}
.pf-section-meta {
  max-width: 720px;
  text-align: center !important;
}
.pf-section-meta * {
  text-align: center !important;
}
.pf-section-label {
  font-family: var(--font-mono);
  font-size: 11px;
  font-weight: 500;
  color: var(--accent);
  text-transform: uppercase;
  letter-spacing: .15em;
  margin-bottom: 12px;
}
.pf-section-title {
  font-family: var(--font-sans) !important;
  font-size: clamp(28px, 4vw, 48px);
  font-weight: 500 !important;
  line-height: 1.05;
  letter-spacing: -.03em;
  color: var(--text);
  margin: 0 0 14px;
}
.pf-section-desc {
  font-size: clamp(14px, 1.3vw, 16px);
  line-height: 1.65;
  color: var(--text-muted);
  margin: 0 auto;
  max-width: 580px;
}

/* ─── FEATURED ────────────────────────────────────────────── */
.pf-featured {
  padding: clamp(64px, 8vw, 120px) clamp(20px, 6vw, 80px);
}
.pf-featured-inner {
  max-width: 1280px;
  margin: 0 auto;
}
.pf-featured-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: clamp(24px, 3vw, 48px);
}

/* Featured cards — large, premium hover */
.pf-feat-card {
  position: relative;
  display: flex;
  flex-direction: column;
  text-decoration: none;
  color: var(--text);
  background: var(--surface-1);
  border: 1px solid var(--border);
  border-radius: 16px;
  overflow: hidden;
  transition:
    transform .5s cubic-bezier(.22,1,.36,1),
    border-color .3s ease,
    box-shadow .4s ease;
  isolation: isolate;
}
.pf-feat-card:hover {
  transform: translateY(-6px);
  border-color: var(--card-accent);
  box-shadow: 0 24px 48px -16px rgba(0,0,0,.12), 0 0 0 1px var(--card-accent);
}
[data-theme="light"] .pf-feat-card:hover {
  box-shadow: 0 24px 48px -16px rgba(0,0,0,.10), 0 0 0 1px var(--card-accent);
}

.pf-feat-img-wrap {
  position: relative;
  aspect-ratio: 16/10;
  overflow: hidden;
  background: var(--surface-2);
  margin: 24px 24px 0;
  border-radius: 8px;
}
.pf-feat-img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: top center;
  transition: transform .8s cubic-bezier(.22,1,.36,1);
  display: block;
}
.pf-feat-card:hover .pf-feat-img {
  transform: scale(1.06);
}

/* Hover overlay — slick "VIEW LIVE" */
.pf-feat-overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, transparent 50%, rgba(0,0,0,.75) 100%);
  display: flex;
  align-items: flex-end;
  justify-content: flex-start;
  padding: 24px;
  opacity: 0;
  transition: opacity .4s ease;
}
.pf-feat-card:hover .pf-feat-overlay {
  opacity: 1;
}
.pf-feat-overlay-text {
  font-family: var(--font-mono);
  font-size: 12px;
  font-weight: 500;
  color: #fff;
  letter-spacing: .15em;
  text-transform: uppercase;
  background: var(--card-accent);
  padding: 10px 16px;
  border-radius: 100px;
  transform: translateY(8px);
  transition: transform .4s cubic-bezier(.22,1,.36,1);
}
.pf-feat-card:hover .pf-feat-overlay-text {
  transform: translateY(0);
}

.pf-feat-badge {
  position: absolute;
  top: 12px;
  right: 12px;
  padding: 6px 12px;
  background: var(--card-accent);
  color: #fff;
  font-family: var(--font-mono);
  font-size: 11px;
  font-weight: 500;
  border-radius: 100px;
  letter-spacing: .02em;
  box-shadow: 0 4px 12px rgba(0,0,0,.15);
}

.pf-feat-body {
  padding: 24px;
  flex: 1;
  display: flex;
  flex-direction: column;
}
.pf-feat-name-row {
  display: flex;
  align-items: center;
  gap: 12px;
  margin-bottom: 10px;
}
.pf-feat-name {
  font-family: var(--font-sans) !important;
  font-size: clamp(20px, 2.4vw, 28px);
  font-weight: 500 !important;
  letter-spacing: -.02em;
  margin: 0;
  color: var(--text);
}
.pf-feat-emoji {
  font-size: 22px;
  line-height: 1;
  opacity: .85;
}
.pf-feat-desc {
  font-size: 14px;
  line-height: 1.65;
  color: var(--text-muted);
  margin: 0 0 20px;
  flex: 1;
}
.pf-feat-stack {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 8px;
  padding-top: 16px;
  border-top: 1px solid var(--border);
}
.pf-feat-stack-label {
  font-family: var(--font-mono);
  font-size: 10px;
  color: var(--text-faint);
  text-transform: uppercase;
  letter-spacing: .15em;
  margin-right: 4px;
}
.pf-feat-stack-item {
  font-family: var(--font-mono);
  font-size: 11px;
  font-weight: 500;
  color: var(--text-subtle);
  padding: 4px 10px;
  border: 1px solid var(--border);
  border-radius: 100px;
  background: var(--surface-2);
}

/* ─── GRID SECTION ───────────────────────────────────────── */
.pf-grid-section {
  padding: clamp(64px, 8vw, 120px) clamp(20px, 6vw, 80px);
}
.pf-grid-inner {
  max-width: 1280px;
  margin: 0 auto;
}

/* Filters bar */
.pf-filters {
  display: flex;
  justify-content: center;
  align-items: center;
  flex-wrap: wrap;
  gap: 24px;
  margin-bottom: clamp(32px, 4vw, 56px);
  padding-bottom: 24px;
  border-bottom: 1px solid var(--border);
}
.pf-filter-group {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  justify-content: center;
}
.pf-pill {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 9px 16px;
  background: transparent;
  border: 1px solid var(--border);
  border-radius: 100px;
  font-family: var(--font-sans);
  font-size: 13px;
  font-weight: 500;
  color: var(--text-muted);
  cursor: pointer;
  transition: all .25s ease;
  letter-spacing: -.01em;
}
.pf-pill:hover {
  border-color: var(--border-hover);
  color: var(--text);
}
.pf-pill.active {
  background: var(--text);
  color: var(--bg);
  border-color: var(--text);
}
.pf-pill-count {
  font-family: var(--font-mono);
  font-size: 10px;
  color: inherit;
  opacity: .55;
  font-weight: 500;
}
.pf-pill.active .pf-pill-count { opacity: .7; }

/* The grid itself */
.pf-cards {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: clamp(20px, 2.5vw, 32px);
}
.pf-card {
  position: relative;
  display: flex;
  flex-direction: column;
  text-decoration: none;
  color: var(--text);
  background: var(--surface-1);
  border: 1px solid var(--border);
  border-radius: 14px;
  overflow: hidden;
  transition:
    transform .4s cubic-bezier(.22,1,.36,1),
    border-color .3s ease,
    box-shadow .35s ease;
}
.pf-card:hover {
  transform: translateY(-4px);
  border-color: var(--card-accent);
  box-shadow: 0 16px 36px -12px rgba(0,0,0,.10);
}
.pf-card.pf-hidden {
  display: none;
}

.pf-card-img-wrap {
  position: relative;
  aspect-ratio: 16/10;
  overflow: hidden;
  background: var(--surface-2);
}
.pf-card-img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: top center;
  transition: transform .6s cubic-bezier(.22,1,.36,1);
  display: block;
}
.pf-card:hover .pf-card-img {
  transform: scale(1.05);
}
.pf-card-overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, transparent 60%, rgba(0,0,0,.7) 100%);
  display: flex;
  align-items: flex-end;
  padding: 16px;
  opacity: 0;
  transition: opacity .35s ease;
}
.pf-card:hover .pf-card-overlay {
  opacity: 1;
}
.pf-card-overlay-text {
  font-family: var(--font-mono);
  font-size: 11px;
  color: #fff;
  letter-spacing: .12em;
  text-transform: uppercase;
  background: var(--card-accent);
  padding: 7px 12px;
  border-radius: 100px;
  font-weight: 500;
}

.pf-card-body {
  padding: 18px 20px 20px;
  flex: 1;
  display: flex;
  flex-direction: column;
}
.pf-card-name-row {
  display: flex;
  align-items: center;
  gap: 8px;
  margin-bottom: 8px;
}
.pf-card-name {
  font-family: var(--font-sans) !important;
  font-size: 17px;
  font-weight: 500 !important;
  letter-spacing: -.015em;
  margin: 0;
  color: var(--text);
}
.pf-card-desc {
  font-size: 13px;
  line-height: 1.6;
  color: var(--text-muted);
  margin: 0 0 14px;
  flex: 1;
}
.pf-card-stack {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
}
.pf-card-stack-item {
  font-family: var(--font-mono);
  font-size: 10px;
  font-weight: 500;
  color: var(--text-subtle);
  padding: 3px 8px;
  border: 1px solid var(--border);
  border-radius: 100px;
}

/* Empty state */
.pf-empty {
  display: none;
  flex-direction: column;
  align-items: center;
  gap: 16px;
  padding: 80px 20px;
}
.pf-empty-msg {
  font-size: 16px;
  color: var(--text-muted);
  margin: 0;
}
.pf-empty-btn {
  font-family: var(--font-mono);
  font-size: 12px;
  letter-spacing: .12em;
  text-transform: uppercase;
  padding: 10px 20px;
  border: 1px solid var(--border);
  background: transparent;
  color: var(--text);
  border-radius: 100px;
  cursor: pointer;
  transition: all .25s;
}
.pf-empty-btn:hover {
  border-color: var(--accent);
  color: var(--accent);
}

/* ─── NETWORK — HORIZONTAL SCROLL ────────────────────────── */
.pf-network {
  padding: clamp(64px, 8vw, 120px) 0 clamp(48px, 6vw, 80px);
  overflow: hidden;
}
.pf-network-inner {
  max-width: 1280px;
  margin: 0 auto;
  padding: 0 clamp(20px, 6vw, 80px);
}
/* ─── MARQUEE — infinite auto-scroll ──────────────────────── */
.pf-marquee {
  position: relative;
  width: 100%;
  overflow: hidden;
  padding: 8px 0 24px;
  /* Soft fade on edges so cards don't pop into view abruptly */
  mask-image: linear-gradient(90deg, transparent 0, #000 6%, #000 94%, transparent 100%);
  -webkit-mask-image: linear-gradient(90deg, transparent 0, #000 6%, #000 94%, transparent 100%);
}
.pf-marquee-track {
  display: flex;
  gap: 20px;
  width: max-content;
  /* Animate the duplicated track. We move by 50% (one full set of originals)
     so the loop repeats seamlessly because items are duplicated 2x in PHP. */
  animation: pfMarquee 40s linear infinite;
  will-change: transform;
}
.pf-marquee:hover .pf-marquee-track {
  animation-play-state: paused;
}
@keyframes pfMarquee {
  from { transform: translateX(0); }
  to   { transform: translateX(-50%); }
}
@media (prefers-reduced-motion: reduce) {
  .pf-marquee-track { animation: none; }
  .pf-marquee {
    overflow-x: auto;
    scrollbar-width: none;
  }
  .pf-marquee::-webkit-scrollbar { display: none; }
}

.pf-net-card {
  flex: 0 0 clamp(280px, 32vw, 380px);
  text-decoration: none;
  color: var(--text);
  background: var(--surface-1);
  border: 1px solid var(--border);
  border-radius: 14px;
  overflow: hidden;
  transition: transform .4s cubic-bezier(.22,1,.36,1), border-color .3s;
}
.pf-net-card:hover {
  transform: translateY(-4px);
  border-color: var(--card-accent);
}
.pf-net-img-wrap {
  aspect-ratio: 16/10;
  overflow: hidden;
  background: var(--surface-2);
}
.pf-net-img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: top center;
  transition: transform .6s cubic-bezier(.22,1,.36,1);
  display: block;
}
.pf-net-card:hover .pf-net-img {
  transform: scale(1.05);
}
.pf-net-body {
  padding: 18px 20px;
}
.pf-net-tag {
  font-family: var(--font-mono);
  font-size: 10px;
  color: var(--card-accent);
  text-transform: uppercase;
  letter-spacing: .15em;
  margin-bottom: 6px;
  font-weight: 500;
}
.pf-net-name {
  font-family: var(--font-sans) !important;
  font-size: 16px;
  font-weight: 500;
  letter-spacing: -.015em;
  color: var(--text);
}

/* ─── CTA ─────────────────────────────────────────────────── */
.pf-cta {
  padding: clamp(80px, 10vw, 140px) clamp(20px, 6vw, 80px);
  position: relative;
}
.pf-cta::before {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0; bottom: 0;
  background-image:
    linear-gradient(var(--grid-line) 1px, transparent 1px),
    linear-gradient(90deg, var(--grid-line) 1px, transparent 1px);
  background-size: 64px 64px;
  mask-image: radial-gradient(ellipse 60% 80% at 50% 50%, #000 0%, transparent 70%);
  -webkit-mask-image: radial-gradient(ellipse 60% 80% at 50% 50%, #000 0%, transparent 70%);
  pointer-events: none;
  opacity: .5;
}
.pf-cta-inner {
  max-width: 900px;
  margin: 0 auto;
  text-align: center !important;
  position: relative;
  z-index: 1;
}
.pf-cta-inner * { text-align: center !important; }

.pf-cta-pre {
  display: inline-block;
  font-family: var(--font-mono);
  font-size: 11px;
  color: var(--accent);
  text-transform: uppercase;
  letter-spacing: .2em;
  padding: 6px 14px;
  border: 1px solid var(--pill-border);
  background: var(--pill-bg);
  border-radius: 100px;
  margin-bottom: 28px;
}
.pf-cta-title {
  font-family: var(--font-sans) !important;
  font-size: clamp(40px, 7vw, 88px);
  font-weight: 500 !important;
  line-height: .95;
  letter-spacing: -.04em;
  margin: 0 0 24px;
  color: var(--text);
}
.pf-cta-accent {
  color: var(--accent);
  font-style: italic;
  font-weight: 400 !important;
}
.pf-cta-desc {
  font-size: clamp(15px, 1.5vw, 18px);
  line-height: 1.65;
  color: var(--text-muted);
  margin: 0 auto 36px;
  max-width: 480px;
}
.pf-cta-btn {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  padding: 14px 28px;
  background: var(--text);
  color: var(--bg);
  border-radius: 100px;
  font-family: var(--font-sans);
  font-size: 14px;
  font-weight: 500;
  letter-spacing: -.01em;
  text-decoration: none;
  border: 1px solid var(--text);
  transition: all .25s;
}
.pf-cta-btn:hover {
  transform: translateY(-2px);
  box-shadow: 0 12px 28px -8px rgba(0,0,0,.2);
}
.pf-cta-btn svg {
  transition: transform .3s ease;
}
.pf-cta-btn:hover svg {
  transform: translateX(4px);
}

/* ─── RESPONSIVE ─────────────────────────────────────────── */
@media (max-width: 980px) {
  .pf-featured-grid {
    grid-template-columns: 1fr;
  }
  .pf-cards {
    grid-template-columns: repeat(2, 1fr);
  }
  .pf-hero-bottom {
    grid-template-columns: 1fr;
  }
  .pf-hero-stats {
    align-items: flex-start;
  }
  .pf-stat-big, .pf-stat-mini {
    text-align: left;
  }
  .pf-stat-row {
    justify-content: flex-start;
  }
  .pf-section-head {
    grid-template-columns: 1fr;
    gap: 16px;
  }
}
@media (max-width: 640px) {
  .pf-cards {
    grid-template-columns: 1fr;
  }
  .pf-filters {
    flex-direction: column;
    align-items: center;
  }
  .pf-pill {
    font-size: 12px;
    padding: 8px 14px;
  }
  .pf-feat-img-wrap {
    margin: 0 16px;
  }
  .pf-feat-body {
    padding-left: 16px;
    padding-right: 16px;
  }
  .pf-stat-row {
    flex-wrap: wrap;
    gap: 16px 24px;
  }
}

/* ════════════════════════════════════════════════════════════
   PORTFOLIO GALLERY — manual navigation via arrows + dots
   ════════════════════════════════════════════════════════════ */
.pf-gallery {
  position: relative;
}
/* All gallery images stack on top of each other */
.pf-gallery .pf-gallery-img {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: top center;
  display: block;
  opacity: 0;
  transition: opacity .6s cubic-bezier(.22,1,.36,1);
  pointer-events: none;
}
/* The first image keeps its place in the layout flow so the wrap stays sized */
.pf-gallery > .pf-gallery-img:first-of-type {
  position: relative;
}
/* Active slide is visible */
.pf-gallery .pf-gallery-img--active {
  opacity: 1;
}
/* Failed-to-load slides are skipped */
.pf-gallery .pf-gallery-img--failed {
  display: none !important;
}
/* Hover zoom on the active slide */
.pf-feat-card:hover .pf-gallery .pf-gallery-img--active,
.pf-card:hover .pf-gallery .pf-gallery-img--active {
  transform: scale(1.04);
  transition: opacity .6s cubic-bezier(.22,1,.36,1), transform .8s cubic-bezier(.22,1,.36,1);
}

/* ─── Arrows ───────────────────────────────────────────────── */
.pf-gallery-arrow {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  z-index: 4;
  width: 36px;
  height: 36px;
  border-radius: 50%;
  border: none;
  background: rgba(0, 0, 0, .5);
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
  color: #fff;
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  opacity: 0;
  transition: opacity .25s ease, background .2s ease, transform .25s ease;
  padding: 0;
}
.pf-gallery-arrow--prev { left: 12px; }
.pf-gallery-arrow--next { right: 12px; }
.pf-gallery-arrow:hover {
  background: var(--card-accent);
  color: #fff;
}
/* Show arrows on card hover (or always on touch devices) */
.pf-feat-card:hover .pf-gallery-arrow,
.pf-card:hover .pf-gallery-arrow {
  opacity: 1;
}
.pf-gallery-arrow:focus-visible {
  opacity: 1;
  outline: 2px solid var(--accent);
  outline-offset: 2px;
}
@media (hover: none) {
  /* Touch devices: arrows always visible since there's no hover */
  .pf-gallery-arrow { opacity: .85; }
}

/* ─── Dots ─────────────────────────────────────────────────── */
.pf-gallery-dots {
  position: absolute;
  bottom: 10px;
  left: 50%;
  transform: translateX(-50%);
  z-index: 3;
  display: flex;
  gap: 6px;
  padding: 5px 9px;
  background: rgba(0, 0, 0, .45);
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
  border-radius: 100px;
  opacity: 0;
  transition: opacity .25s ease;
  pointer-events: none;
}
.pf-feat-card:hover .pf-gallery-dots,
.pf-card:hover .pf-gallery-dots {
  opacity: 1;
}
@media (hover: none) {
  .pf-gallery-dots { opacity: .9; }
}
.pf-gallery-dot {
  width: 5px;
  height: 5px;
  border-radius: 50%;
  background: rgba(255, 255, 255, .45);
  transition: background .25s ease, transform .25s ease;
}
.pf-gallery-dot--active {
  background: #fff;
  transform: scale(1.3);
}

/* Featured cards have larger arrows */
.pf-feat-card .pf-gallery-arrow {
  width: 44px;
  height: 44px;
}

/* Reduced motion: keep navigation but instant transitions */
@media (prefers-reduced-motion: reduce) {
  .pf-gallery .pf-gallery-img { transition: none; }
  .pf-gallery-arrow,
  .pf-gallery-dots,
  .pf-gallery-dot { transition: none; }
}

/* Mobile: smaller controls */
@media (max-width: 640px) {
  .pf-gallery-arrow {
    width: 32px;
    height: 32px;
  }
  .pf-feat-card .pf-gallery-arrow {
    width: 36px;
    height: 36px;
  }
  .pf-gallery-arrow--prev { left: 8px; }
  .pf-gallery-arrow--next { right: 8px; }
}

/* ════════════════════════════════════════════════════════════
   PORTFOLIO PLACEHOLDERS — when local screenshot file is absent
   Shows a clean branded card instead of broken image.
   ════════════════════════════════════════════════════════════ */
.pf-placeholder {
  background: linear-gradient(135deg,
    var(--card-accent, var(--accent)) 0%,
    color-mix(in srgb, var(--card-accent, var(--accent)) 60%, #000) 100%);
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
}
.pf-placeholder-inner {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 16px;
  padding: 32px;
  text-align: center;
  width: 100%;
  height: 100%;
}
.pf-placeholder-emoji {
  font-size: clamp(48px, 8vw, 88px);
  line-height: 1;
  filter: drop-shadow(0 4px 12px rgba(0,0,0,.25));
}
.pf-placeholder-name {
  font-family: var(--font-sans);
  font-size: clamp(16px, 2vw, 22px);
  font-weight: 600;
  color: #fff;
  letter-spacing: -.02em;
  text-shadow: 0 2px 8px rgba(0,0,0,.3);
}

/* ════════════════════════════════════════════════════════════
   24H DRAFT — Nav button + page styles
   ════════════════════════════════════════════════════════════ */

/* ─── NAV CTA BUTTON (desktop) ────────────────────────────── */
.nav-cta-24h {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 8px 16px 8px 14px;
  margin-right: 6px;
  background: linear-gradient(135deg, #ff6b35 0%, #f7931e 100%);
  color: #fff !important;
  border-radius: 100px;
  font-size: 13px;
  font-weight: 600;
  letter-spacing: -.005em;
  font-family: var(--font-sans);
  text-decoration: none;
  position: relative;
  transition: transform .2s cubic-bezier(.22,1,.36,1), box-shadow .25s ease, filter .2s ease;
  box-shadow:
    0 1px 0 rgba(255,255,255,.2) inset,
    0 0 0 1px rgba(255,107,53,.4),
    0 4px 14px rgba(255,107,53,.35);
  white-space: nowrap;
  overflow: hidden;
}
.nav-cta-24h::before {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(120deg, transparent 30%, rgba(255,255,255,.25) 50%, transparent 70%);
  transform: translateX(-100%);
  transition: transform .6s ease;
}
.nav-cta-24h:hover {
  transform: translateY(-1px);
  filter: brightness(1.05);
  box-shadow:
    0 1px 0 rgba(255,255,255,.3) inset,
    0 0 0 1px rgba(255,107,53,.6),
    0 8px 22px rgba(255,107,53,.45);
}
.nav-cta-24h:hover::before { transform: translateX(100%); }
.nav-cta-24h:active { transform: translateY(0); }
.nav-cta-24h.active {
  filter: brightness(1.05);
  box-shadow:
    0 1px 0 rgba(255,255,255,.3) inset,
    0 0 0 2px rgba(255,107,53,.55),
    0 6px 20px rgba(255,107,53,.45);
}
.nav-cta-24h-dot {
  width: 7px;
  height: 7px;
  border-radius: 50%;
  background: #fff;
  position: relative;
  flex-shrink: 0;
  box-shadow: 0 0 0 0 rgba(255,255,255,.7);
  animation: ctaPulse 1.8s cubic-bezier(.22,1,.36,1) infinite;
}
@keyframes ctaPulse {
  0%   { box-shadow: 0 0 0 0 rgba(255,255,255,.7); }
  70%  { box-shadow: 0 0 0 8px rgba(255,255,255,0); }
  100% { box-shadow: 0 0 0 0 rgba(255,255,255,0); }
}
.nav-cta-24h-label {
  font-family: var(--font-sans);
  letter-spacing: -.005em;
}
@media (prefers-reduced-motion: reduce) {
  .nav-cta-24h-dot { animation: none; }
  .nav-cta-24h::before { display: none; }
}

/* Mobile menu CTA */
.mobile-cta-24h {
  display: inline-flex !important;
  align-items: center;
  gap: 10px;
  background: linear-gradient(135deg, #ff6b35 0%, #f7931e 100%);
  color: #fff !important;
  padding: 12px 20px !important;
  border-radius: 100px;
  font-weight: 600 !important;
  width: fit-content;
  box-shadow: 0 4px 14px rgba(255,107,53,.4);
}

/* ════════════════════════════════════════════════════════════
   24H DRAFT PAGE — Hero
   ════════════════════════════════════════════════════════════ */
.draft-hero {
  position: relative;
  padding: 120px 0 100px;
  overflow: hidden;
  isolation: isolate;
}
.draft-hero-bg {
  position: absolute;
  inset: 0;
  z-index: -1;
  pointer-events: none;
}
.draft-hero-grid {
  position: absolute;
  inset: 0;
  background-image:
    linear-gradient(var(--grid-line, rgba(0,0,0,.06)) 1px, transparent 1px),
    linear-gradient(90deg, var(--grid-line, rgba(0,0,0,.06)) 1px, transparent 1px);
  background-size: 56px 56px;
  mask-image: radial-gradient(ellipse 80% 70% at 50% 35%, #000 30%, transparent 75%);
  -webkit-mask-image: radial-gradient(ellipse 80% 70% at 50% 35%, #000 30%, transparent 75%);
}
.draft-hero-glow {
  position: absolute;
  top: 10%;
  left: 50%;
  transform: translateX(-50%);
  width: 720px;
  height: 720px;
  background: radial-gradient(circle, rgba(255,107,53,.18) 0%, rgba(247,147,30,.08) 30%, transparent 65%);
  filter: blur(60px);
  pointer-events: none;
}

.draft-hero-inner {
  max-width: 1100px;
  margin: 0 auto;
  padding: 0 24px;
  text-align: center;
  position: relative;
}

.draft-pill {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  padding: 8px 16px;
  background: var(--surface-1, rgba(0,0,0,.04));
  border: 1px solid var(--border, rgba(0,0,0,.08));
  border-radius: 100px;
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: .04em;
  text-transform: uppercase;
  color: var(--text-muted, #666);
  margin-bottom: 32px;
}
.draft-pill-dot {
  width: 7px;
  height: 7px;
  border-radius: 50%;
  background: #22c55e;
  box-shadow: 0 0 0 0 rgba(34,197,94,.5);
  animation: ctaPulse 1.8s cubic-bezier(.22,1,.36,1) infinite;
}
.draft-pill-text { color: #22c55e; font-weight: 600; }
.draft-pill-sep { opacity: .4; }
.draft-pill-meta { font-weight: 500; }

.draft-hero-title {
  font-family: var(--font-sans);
  font-size: clamp(40px, 8vw, 88px);
  font-weight: 600;
  line-height: 1;
  letter-spacing: -.045em;
  margin: 0 0 28px;
  color: var(--text);
}
.draft-title-line {
  display: block;
}
.draft-title-accent {
  background: linear-gradient(135deg, #ff6b35 0%, #f7931e 60%, #facc15 100%);
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
  color: transparent;
}

.draft-hero-desc {
  max-width: 620px;
  margin: 0 auto 12px;
  font-size: clamp(16px, 1.4vw, 19px);
  line-height: 1.6;
  color: var(--text-muted, #666);
  letter-spacing: -.005em;
}
.draft-hero-desc--strong {
  margin-bottom: 40px;
  color: var(--text);
  font-weight: 500;
}
.draft-hero-desc + .draft-hero-desc { margin-top: 0; }

.draft-hero-ctas {
  display: flex;
  gap: 12px;
  justify-content: center;
  flex-wrap: wrap;
  margin-bottom: 64px;
}

/* Buttons */
.draft-btn-primary,
.draft-btn-secondary,
.draft-btn-back {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  padding: 14px 24px;
  font-family: var(--font-sans);
  font-size: 15px;
  font-weight: 600;
  letter-spacing: -.005em;
  border-radius: 100px;
  text-decoration: none;
  cursor: pointer;
  border: none;
  transition: transform .2s ease, box-shadow .25s ease, filter .2s ease, background .2s ease;
  white-space: nowrap;
}
.draft-btn-primary {
  background: linear-gradient(135deg, #ff6b35 0%, #f7931e 100%);
  color: #fff;
  box-shadow: 0 4px 14px rgba(255,107,53,.35), 0 0 0 1px rgba(255,107,53,.4);
}
.draft-btn-primary:hover {
  transform: translateY(-1px);
  filter: brightness(1.05);
  box-shadow: 0 8px 22px rgba(255,107,53,.45), 0 0 0 1px rgba(255,107,53,.6);
}
.draft-btn-primary:disabled {
  opacity: .6;
  cursor: not-allowed;
  transform: none;
}
.draft-btn-secondary {
  background: var(--surface-1, rgba(0,0,0,.04));
  color: var(--text);
  border: 1px solid var(--border, rgba(0,0,0,.1));
}
.draft-btn-secondary:hover {
  background: var(--surface-2, rgba(0,0,0,.06));
  border-color: var(--border-strong, rgba(0,0,0,.16));
}
.draft-btn-back {
  background: transparent;
  color: var(--text-muted, #666);
  border: 1px solid transparent;
  padding: 14px 18px;
}
.draft-btn-back:hover {
  background: var(--surface-1, rgba(0,0,0,.04));
  color: var(--text);
}

/* Stats */
.draft-hero-stats {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 32px;
  flex-wrap: wrap;
  padding: 32px;
  background: var(--surface-1, rgba(0,0,0,.03));
  border: 1px solid var(--border, rgba(0,0,0,.08));
  border-radius: 16px;
  max-width: 720px;
  margin: 0 auto;
}
.draft-stat {
  text-align: center;
  flex: 1;
  min-width: 140px;
}
.draft-stat-num {
  font-family: var(--font-sans);
  font-size: clamp(38px, 5vw, 52px);
  font-weight: 600;
  line-height: 1;
  letter-spacing: -.04em;
  color: var(--text);
  margin-bottom: 8px;
}
.draft-stat-unit {
  font-size: .55em;
  font-weight: 500;
  color: var(--text-muted, #999);
  margin-left: 2px;
}
.draft-stat-label {
  font-family: var(--font-mono);
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: .05em;
  color: var(--text-muted, #888);
}
.draft-stat-divider {
  width: 1px;
  height: 40px;
  background: var(--border, rgba(0,0,0,.1));
}
@media (max-width: 720px) {
  .draft-stat-divider { display: none; }
  .draft-hero-stats { gap: 16px; padding: 20px; }
}

/* ════════════════════════════════════════════════════════════
   Section heads (shared across timeline, hiw, form sections)
   ════════════════════════════════════════════════════════════ */
.draft-timeline,
.draft-hiw,
.draft-form-section {
  padding: 100px 0;
  border-top: 1px solid var(--border, rgba(0,0,0,.06));
}
.draft-section-inner {
  max-width: 1100px;
  margin: 0 auto;
  padding: 0 24px;
}
.draft-section-head {
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  gap: 12px;
  margin: 0 auto 64px;
  max-width: 720px;
}
.draft-section-num {
  font-family: var(--font-mono);
  font-size: 12px;
  color: var(--text-muted, #888);
  letter-spacing: .12em;
  font-weight: 500;
  padding-top: 8px;
  border-top: 2px solid var(--accent, #ff6b35);
  width: fit-content;
  margin-bottom: 8px;
}
.draft-section-meta {
  width: 100%;
}
.draft-section-label {
  font-family: var(--font-mono);
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: .08em;
  color: var(--text-muted, #888);
  margin-bottom: 12px;
}
.draft-section-title {
  font-family: var(--font-sans);
  font-size: clamp(28px, 3.5vw, 44px);
  font-weight: 600;
  letter-spacing: -.035em;
  line-height: 1.1;
  color: var(--text);
  margin: 0 0 16px;
}
.draft-section-desc {
  font-size: 17px;
  line-height: 1.6;
  color: var(--text-muted, #666);
  margin: 0 auto;
  letter-spacing: -.005em;
  max-width: 560px;
}
@media (max-width: 720px) {
  .draft-section-head { gap: 10px; margin-bottom: 48px; }
}

/* ════════════════════════════════════════════════════════════
   TIMELINE
   ════════════════════════════════════════════════════════════ */
.draft-tl-track {
  position: relative;
  display: flex;
  flex-direction: column;
  gap: 0;
}
.draft-tl-step {
  display: grid;
  grid-template-columns: 64px 80px 1fr;
  gap: 24px;
  padding: 24px 0;
  align-items: start;
  position: relative;
}
.draft-tl-marker {
  position: relative;
  display: flex;
  flex-direction: column;
  align-items: center;
  height: 100%;
  min-height: 80px;
}
.draft-tl-dot {
  width: 14px;
  height: 14px;
  border-radius: 50%;
  background: var(--surface-2, #fff);
  border: 2px solid var(--border-strong, #888);
  position: relative;
  z-index: 2;
  margin-top: 6px;
  flex-shrink: 0;
}
.draft-tl-line {
  width: 2px;
  flex: 1;
  background: var(--border, rgba(0,0,0,.1));
  margin-top: 4px;
}
.draft-tl-step:last-child .draft-tl-line { display: none; }
.draft-tl-step--highlight .draft-tl-dot {
  background: linear-gradient(135deg, #ff6b35 0%, #f7931e 100%);
  border-color: #ff6b35;
  box-shadow: 0 0 0 4px rgba(255,107,53,.15), 0 0 20px rgba(255,107,53,.3);
}
.draft-tl-step--highlight .draft-tl-step-title {
  color: #ff6b35;
}
.draft-tl-time {
  font-family: var(--font-mono);
  font-size: 13px;
  font-weight: 600;
  color: var(--text-muted, #888);
  letter-spacing: .02em;
  padding-top: 4px;
}
.draft-tl-step--highlight .draft-tl-time {
  color: #ff6b35;
  font-weight: 700;
}
.draft-tl-step-title {
  font-family: var(--font-sans);
  font-size: 19px;
  font-weight: 600;
  letter-spacing: -.02em;
  margin: 0 0 6px;
  color: var(--text);
}
.draft-tl-step-desc {
  font-size: 15px;
  line-height: 1.55;
  color: var(--text-muted, #666);
  margin: 0;
  letter-spacing: -.003em;
}
@media (max-width: 720px) {
  .draft-tl-step { grid-template-columns: 32px 60px 1fr; gap: 12px; }
  .draft-tl-step-title { font-size: 16px; }
  .draft-tl-step-desc { font-size: 14px; }
}

/* ════════════════════════════════════════════════════════════
   HOW IT WORKS — Tech spec sheet aesthetic
   ════════════════════════════════════════════════════════════ */
.draft-hiw-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 1px;
  background: var(--border, rgba(0,0,0,.08));
  border: 1px solid var(--border, rgba(0,0,0,.08));
  border-radius: 14px;
  overflow: hidden;
}
.draft-hiw-card {
  position: relative;
  padding: 32px;
  background: var(--bg, #fff);
  display: flex;
  flex-direction: column;
  transition: background .2s ease;
  overflow: hidden;
}
.draft-hiw-card::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 2px;
  background: linear-gradient(90deg, transparent 0%, var(--accent, #ff6b35) 30%, var(--accent, #ff6b35) 70%, transparent 100%);
  opacity: 0;
  transform: translateY(-2px);
  transition: opacity .25s ease, transform .25s ease;
}
.draft-hiw-card:hover {
  background: var(--surface-1, rgba(0,0,0,.015));
}
.draft-hiw-card:hover::before {
  opacity: 1;
  transform: translateY(0);
}

/* Header row: tag + icon */
.draft-hiw-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 28px;
  padding-bottom: 16px;
  border-bottom: 1px dashed var(--border, rgba(0,0,0,.1));
}
.draft-hiw-tag {
  display: inline-flex;
  align-items: baseline;
  gap: 4px;
  font-family: var(--font-mono);
  font-size: 11px;
  font-weight: 500;
  color: var(--text-muted, #888);
  letter-spacing: .02em;
}
.draft-hiw-tag-num {
  color: var(--text);
  font-weight: 600;
  font-size: 12px;
  letter-spacing: .03em;
}
.draft-hiw-tag-sep {
  color: var(--text-muted, #ccc);
  margin: 0 1px;
}
.draft-hiw-tag-tot {
  color: var(--text-muted, #aaa);
  font-size: 11px;
}
.draft-hiw-tag-label {
  margin-left: 10px;
  padding-left: 10px;
  border-left: 1px solid var(--border, rgba(0,0,0,.12));
  color: var(--text-muted, #888);
  font-size: 10.5px;
  letter-spacing: .04em;
  text-transform: lowercase;
}
.draft-hiw-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 28px;
  height: 28px;
  color: var(--text-muted, #888);
  background: transparent;
  border: 1px solid var(--border, rgba(0,0,0,.12));
  border-radius: 6px;
  flex-shrink: 0;
  transition: color .25s ease, border-color .25s ease;
}
.draft-hiw-card:hover .draft-hiw-icon {
  color: #ff6b35;
  border-color: rgba(255,107,53,.4);
}

/* Title + desc */
.draft-hiw-title {
  font-family: var(--font-sans);
  font-size: 18px;
  font-weight: 600;
  letter-spacing: -.018em;
  margin: 0 0 10px;
  color: var(--text);
  line-height: 1.25;
}
.draft-hiw-desc {
  font-size: 14.5px;
  line-height: 1.6;
  color: var(--text-muted, #666);
  margin: 0 0 28px;
  letter-spacing: -.003em;
}

/* Spec sheet at the bottom */
.draft-hiw-spec {
  margin-top: auto;
  padding-top: 16px;
  border-top: 1px dashed var(--border, rgba(0,0,0,.1));
  display: flex;
  flex-direction: column;
  gap: 6px;
}
.draft-hiw-spec-item {
  display: flex;
  align-items: baseline;
  gap: 12px;
  font-family: var(--font-mono);
  font-size: 11.5px;
  letter-spacing: .01em;
}
.draft-hiw-spec-key {
  color: var(--text-muted, #aaa);
  text-transform: uppercase;
  font-size: 10.5px;
  letter-spacing: .08em;
  flex-shrink: 0;
  min-width: 70px;
  position: relative;
}
.draft-hiw-spec-key::after {
  content: '';
  position: absolute;
  left: 100%;
  top: 50%;
  margin-left: 6px;
  width: calc(100% - 70px);
  border-top: 1px dotted var(--border, rgba(0,0,0,.15));
  display: none;
}
.draft-hiw-spec-val {
  color: var(--text);
  font-weight: 500;
  letter-spacing: -.005em;
  font-size: 12px;
  font-family: var(--font-sans);
}

@media (max-width: 720px) {
  .draft-hiw-grid { grid-template-columns: 1fr; }
}
@media (max-width: 480px) {
  .draft-hiw-card { padding: 24px; }
  .draft-hiw-tag-label { display: none; }
}

/* ════════════════════════════════════════════════════════════
   FORM (multi-step)
   ════════════════════════════════════════════════════════════ */
.draft-form-section {
  background: var(--surface-1, rgba(0,0,0,.015));
}
.draft-form-wrap {
  max-width: 760px;
  margin: 0 auto;
  background: var(--bg, #fff);
  border: 1px solid var(--border, rgba(0,0,0,.08));
  border-radius: 16px;
  padding: 40px;
  box-shadow: 0 1px 0 rgba(255,255,255,.02) inset, 0 12px 40px rgba(0,0,0,.04);
}

/* Progress */
.draft-progress {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 8px;
  position: relative;
  margin-bottom: 36px;
  padding-bottom: 20px;
  border-bottom: 1px solid var(--border, rgba(0,0,0,.06));
}
.draft-progress-step {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 8px;
  position: relative;
  z-index: 2;
}
.draft-progress-num {
  width: 32px;
  height: 32px;
  border-radius: 50%;
  background: var(--surface-2, rgba(0,0,0,.05));
  border: 2px solid var(--border, rgba(0,0,0,.1));
  color: var(--text-muted, #888);
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: var(--font-mono);
  font-size: 13px;
  font-weight: 600;
  transition: all .25s ease;
}
.draft-progress-label {
  font-family: var(--font-mono);
  font-size: 10.5px;
  text-transform: uppercase;
  letter-spacing: .04em;
  color: var(--text-muted, #888);
  text-align: center;
  font-weight: 500;
  transition: color .2s ease;
}
.draft-progress-step.active .draft-progress-num {
  background: linear-gradient(135deg, #ff6b35 0%, #f7931e 100%);
  border-color: #ff6b35;
  color: #fff;
  box-shadow: 0 0 0 4px rgba(255,107,53,.12);
}
.draft-progress-step.active .draft-progress-label {
  color: var(--text);
  font-weight: 600;
}
.draft-progress-step.done .draft-progress-num {
  background: var(--surface-2, rgba(0,0,0,.06));
  border-color: var(--accent, #ff6b35);
  color: var(--accent, #ff6b35);
}
.draft-progress-bar {
  position: absolute;
  bottom: -1px;
  left: 0;
  right: 0;
  height: 2px;
  background: var(--border, rgba(0,0,0,.06));
}
.draft-progress-fill {
  height: 100%;
  background: linear-gradient(90deg, #ff6b35, #f7931e);
  width: 0%;
  transition: width .35s cubic-bezier(.22,1,.36,1);
}
@media (max-width: 600px) {
  .draft-progress-label { display: none; }
}

/* Steps */
.draft-step {
  display: none;
  animation: draftFadeIn .35s cubic-bezier(.22,1,.36,1);
}
.draft-step.active { display: block; }
@keyframes draftFadeIn {
  from { opacity: 0; transform: translateY(8px); }
  to   { opacity: 1; transform: translateY(0); }
}
.draft-step-intro {
  font-size: 14px;
  color: var(--text-muted, #888);
  margin: 0 0 24px;
  padding: 12px 16px;
  background: var(--surface-1, rgba(255,107,53,.04));
  border-left: 3px solid #ff6b35;
  border-radius: 4px;
}

/* Fields */
.draft-field {
  margin-bottom: 20px;
}
.draft-field-row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 16px;
  margin-bottom: 0;
}
.draft-field-row .draft-field { margin-bottom: 20px; }
@media (max-width: 600px) {
  .draft-field-row { grid-template-columns: 1fr; gap: 0; }
}
.draft-label {
  display: block;
  font-family: var(--font-sans);
  font-size: 14px;
  font-weight: 500;
  color: var(--text);
  margin-bottom: 8px;
  letter-spacing: -.005em;
}
.draft-label-note {
  color: var(--text-muted, #999);
  font-weight: 400;
  font-size: 13px;
}
.draft-input,
.draft-textarea {
  width: 100%;
  padding: 12px 14px;
  font-family: var(--font-sans);
  font-size: 15px;
  background: var(--bg, #fff);
  border: 1px solid var(--border, rgba(0,0,0,.12));
  border-radius: 8px;
  color: var(--text);
  transition: border-color .15s ease, box-shadow .15s ease;
  letter-spacing: -.005em;
}
.draft-textarea {
  min-height: 96px;
  resize: vertical;
  font-family: var(--font-sans);
  line-height: 1.5;
}
.draft-input:focus,
.draft-textarea:focus {
  outline: none;
  border-color: #ff6b35;
  box-shadow: 0 0 0 3px rgba(255,107,53,.1);
}
.draft-input::placeholder,
.draft-textarea::placeholder {
  color: var(--text-muted, #aaa);
}

/* Radio grid */
.draft-radio-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 8px;
}
@media (max-width: 600px) {
  .draft-radio-grid { grid-template-columns: 1fr; }
}
.draft-radio {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 12px 14px;
  background: var(--surface-1, rgba(0,0,0,.02));
  border: 1px solid var(--border, rgba(0,0,0,.08));
  border-radius: 8px;
  cursor: pointer;
  transition: all .15s ease;
}
.draft-radio:hover {
  border-color: var(--border-strong, rgba(0,0,0,.16));
  background: var(--surface-2, rgba(0,0,0,.04));
}
.draft-radio input[type="radio"] {
  width: 16px;
  height: 16px;
  accent-color: #ff6b35;
  flex-shrink: 0;
  cursor: pointer;
}
.draft-radio:has(input:checked) {
  border-color: #ff6b35;
  background: rgba(255,107,53,.06);
  box-shadow: 0 0 0 1px #ff6b35 inset;
}
.draft-radio-label {
  font-size: 14px;
  color: var(--text);
  font-weight: 500;
}

/* Dropzone */
.draft-dropzone {
  border: 2px dashed var(--border, rgba(0,0,0,.18));
  border-radius: 10px;
  padding: 28px;
  text-align: center;
  background: var(--surface-1, rgba(0,0,0,.02));
  transition: all .2s ease;
}
.draft-dropzone--active {
  border-color: #ff6b35;
  background: rgba(255,107,53,.05);
}
.draft-dropzone-prompt {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 12px;
  color: var(--text-muted, #888);
}
.draft-dropzone-prompt svg { color: var(--text-muted, #aaa); }
.draft-dropzone-text {
  font-size: 13.5px;
  margin: 0;
  color: var(--text-muted, #888);
}
.draft-dropzone-list {
  margin-top: 16px;
  display: flex;
  flex-direction: column;
  gap: 6px;
}
.draft-file-item {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 8px 12px;
  background: var(--bg, #fff);
  border: 1px solid var(--border, rgba(0,0,0,.08));
  border-radius: 6px;
  font-size: 13px;
  text-align: left;
}
.draft-file-item svg { color: var(--text-muted, #888); flex-shrink: 0; }
.draft-file-item span { flex: 1; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; color: var(--text); }
.draft-file-item em {
  font-style: normal;
  font-family: var(--font-mono);
  font-size: 11px;
  color: var(--text-muted, #999);
}

/* Consent */
.draft-consent {
  display: flex;
  gap: 10px;
  align-items: flex-start;
  padding: 14px;
  background: var(--surface-1, rgba(0,0,0,.02));
  border: 1px solid var(--border, rgba(0,0,0,.08));
  border-radius: 8px;
  margin: 24px 0 8px;
  font-size: 13.5px;
  line-height: 1.5;
  color: var(--text-muted, #555);
  cursor: pointer;
}
.draft-consent input { margin-top: 2px; flex-shrink: 0; accent-color: #ff6b35; }
.draft-consent a { color: var(--accent, #ff6b35); text-decoration: underline; text-underline-offset: 2px; }

.draft-required-note {
  font-family: var(--font-mono);
  font-size: 11px;
  color: var(--text-muted, #999);
  margin: 12px 0 0;
  text-align: right;
}

/* Step actions */
.draft-step-actions {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-top: 32px;
  padding-top: 20px;
  border-top: 1px solid var(--border, rgba(0,0,0,.06));
  gap: 12px;
}

/* Error */
.draft-form-error {
  padding: 12px 16px;
  background: rgba(239,68,68,.08);
  border: 1px solid rgba(239,68,68,.25);
  border-radius: 8px;
  color: #ef4444;
  font-size: 14px;
  margin-bottom: 24px;
}

/* Success */
.draft-form-success {
  text-align: center;
  padding: 40px 20px;
  animation: draftFadeIn .4s cubic-bezier(.22,1,.36,1);
}
.draft-success-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 72px;
  height: 72px;
  background: linear-gradient(135deg, rgba(34,197,94,.12) 0%, rgba(34,197,94,.04) 100%);
  border: 2px solid rgba(34,197,94,.3);
  color: #22c55e;
  border-radius: 50%;
  margin-bottom: 24px;
}
.draft-success-title {
  font-family: var(--font-sans);
  font-size: 28px;
  font-weight: 600;
  letter-spacing: -.025em;
  margin: 0 0 12px;
  color: var(--text);
}
.draft-success-desc {
  font-size: 15.5px;
  line-height: 1.6;
  color: var(--text-muted, #666);
  margin: 0 auto;
  max-width: 480px;
}

/* Spin animation for sending state */
@keyframes spin { to { transform: rotate(360deg); } }

/* Mobile form padding */
@media (max-width: 600px) {
  .draft-form-wrap { padding: 24px 20px; }
  .draft-hero { padding: 80px 0 60px; }
  .draft-timeline,
  .draft-hiw,
  .draft-form-section { padding: 60px 0; }
}

/* ════════════════════════════════════════════════════════════
   24H DRAFT — Explore section (final navigation cards)
   ════════════════════════════════════════════════════════════ */
.draft-explore {
  padding: 100px 0 120px;
  border-top: 1px solid var(--border, rgba(0,0,0,.06));
}

.draft-explore-top {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 16px;
  margin-bottom: 16px;
}
@media (max-width: 720px) {
  .draft-explore-top { grid-template-columns: 1fr; }
}

/* Shared card base */
.draft-explore-card {
  position: relative;
  display: flex;
  flex-direction: column;
  padding: 36px 32px 32px;
  border-radius: 18px;
  text-decoration: none;
  color: #fff;
  overflow: hidden;
  isolation: isolate;
  min-height: 380px;
  transition: transform .3s cubic-bezier(.22,1,.36,1), box-shadow .3s ease;
}
.draft-explore-card:hover {
  transform: translateY(-4px);
}

/* Background art (illustration) */
.draft-explore-bg {
  position: absolute;
  top: 0;
  right: 0;
  width: 55%;
  height: 60%;
  z-index: -1;
  pointer-events: none;
  display: flex;
  align-items: flex-start;
  justify-content: flex-end;
  padding: 24px 24px 0 0;
}
.draft-explore-art {
  width: 100%;
  height: auto;
  max-height: 200px;
  opacity: .9;
}

/* Portfolio variant — emerald/teal */
.draft-explore-card--portfolio {
  background: linear-gradient(135deg, #059669 0%, #047857 50%, #065f46 100%);
  box-shadow: 0 1px 0 rgba(255,255,255,.12) inset, 0 8px 24px rgba(5,150,105,.18);
}
.draft-explore-card--portfolio:hover {
  box-shadow: 0 1px 0 rgba(255,255,255,.18) inset, 0 16px 40px rgba(5,150,105,.32);
}

/* Services variant — indigo/violet */
.draft-explore-card--services {
  background: linear-gradient(135deg, #6366f1 0%, #5b21b6 60%, #4c1d95 100%);
  box-shadow: 0 1px 0 rgba(255,255,255,.12) inset, 0 8px 24px rgba(99,102,241,.18);
}
.draft-explore-card--services:hover {
  box-shadow: 0 1px 0 rgba(255,255,255,.18) inset, 0 16px 40px rgba(99,102,241,.32);
}

.draft-explore-eyebrow {
  font-family: var(--font-mono);
  font-size: 11px;
  font-weight: 600;
  letter-spacing: .12em;
  color: rgba(255,255,255,.75);
  margin-bottom: 14px;
}
.draft-explore-title {
  font-family: var(--font-sans);
  font-size: clamp(28px, 3vw, 38px);
  font-weight: 600;
  letter-spacing: -.03em;
  line-height: 1.1;
  margin: 0 0 14px;
  color: #fff;
  max-width: 60%;
}
.draft-explore-desc {
  font-size: 15px;
  line-height: 1.55;
  color: rgba(255,255,255,.85);
  margin: 0 0 20px;
  max-width: 90%;
  letter-spacing: -.005em;
}
.draft-explore-chips {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  margin-bottom: auto;
  padding-bottom: 24px;
}
.draft-explore-chip {
  display: inline-flex;
  align-items: center;
  padding: 5px 11px;
  font-family: var(--font-mono);
  font-size: 11px;
  font-weight: 500;
  letter-spacing: .02em;
  background: rgba(255,255,255,.16);
  border: 1px solid rgba(255,255,255,.18);
  border-radius: 100px;
  color: #fff;
  backdrop-filter: blur(6px);
  -webkit-backdrop-filter: blur(6px);
}
.draft-explore-cta {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-family: var(--font-sans);
  font-size: 14px;
  font-weight: 600;
  color: #fff;
  letter-spacing: -.005em;
  transition: transform .2s ease;
  margin-top: auto;
}
.draft-explore-card:hover .draft-explore-cta {
  transform: translateX(4px);
}

/* ─── Wide bottom card (Contact) ──────────────────────────── */
.draft-explore-wide {
  position: relative;
  display: grid;
  grid-template-columns: 1.4fr 1fr;
  gap: 32px;
  padding: 48px 40px;
  border-radius: 18px;
  background: linear-gradient(135deg, #0a0a0a 0%, #1a1a1a 50%, #18120c 100%);
  text-decoration: none;
  color: #fff;
  overflow: hidden;
  isolation: isolate;
  border: 1px solid rgba(255,255,255,.06);
  transition: transform .3s cubic-bezier(.22,1,.36,1), border-color .25s ease;
  min-height: 240px;
  align-items: center;
}
.draft-explore-wide:hover {
  transform: translateY(-3px);
  border-color: rgba(255,107,53,.35);
}
.draft-explore-wide-bg {
  position: absolute;
  inset: 0;
  z-index: -1;
  pointer-events: none;
  overflow: hidden;
}
.draft-explore-wide-glow {
  position: absolute;
  bottom: -20%;
  right: -10%;
  width: 60%;
  height: 140%;
  background: radial-gradient(circle, rgba(255,107,53,.4) 0%, rgba(247,147,30,.12) 35%, transparent 65%);
  filter: blur(60px);
  pointer-events: none;
}
@media (max-width: 800px) {
  .draft-explore-wide { grid-template-columns: 1fr; gap: 24px; padding: 36px 28px; }
}

.draft-explore-wide-eyebrow {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-family: var(--font-mono);
  font-size: 11px;
  font-weight: 600;
  letter-spacing: .12em;
  color: #ff8c5a;
  margin-bottom: 14px;
}
.draft-explore-wide-dot {
  width: 7px;
  height: 7px;
  border-radius: 50%;
  background: #ff6b35;
  box-shadow: 0 0 12px rgba(255,107,53,.7);
  animation: ctaPulse 1.8s cubic-bezier(.22,1,.36,1) infinite;
}
.draft-explore-wide-title {
  font-family: var(--font-sans);
  font-size: clamp(26px, 3vw, 38px);
  font-weight: 600;
  letter-spacing: -.03em;
  line-height: 1.1;
  margin: 0 0 14px;
  color: #fff;
}
.draft-explore-wide-accent {
  background: linear-gradient(135deg, #ff6b35 0%, #f7931e 60%, #facc15 100%);
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
  color: transparent;
}
.draft-explore-wide-desc {
  font-size: 15.5px;
  line-height: 1.55;
  color: rgba(255,255,255,.7);
  margin: 0 0 22px;
  letter-spacing: -.005em;
  max-width: 90%;
}
.draft-explore-wide-cta {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  padding: 12px 22px;
  background: linear-gradient(135deg, #ff6b35 0%, #f7931e 100%);
  color: #fff;
  border-radius: 100px;
  font-family: var(--font-sans);
  font-size: 14px;
  font-weight: 600;
  letter-spacing: -.005em;
  box-shadow: 0 4px 14px rgba(255,107,53,.35);
  transition: transform .2s ease, filter .2s ease;
  width: fit-content;
}
.draft-explore-wide:hover .draft-explore-wide-cta {
  filter: brightness(1.05);
  transform: translateX(2px);
}

.draft-explore-wide-channels {
  display: flex;
  flex-direction: column;
  gap: 8px;
}
.draft-explore-channel {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 12px 14px;
  background: rgba(255,255,255,.04);
  border: 1px solid rgba(255,255,255,.08);
  border-radius: 10px;
  transition: background .2s ease, border-color .2s ease;
}
.draft-explore-wide:hover .draft-explore-channel {
  background: rgba(255,255,255,.06);
  border-color: rgba(255,255,255,.12);
}
.draft-explore-channel-icon {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 32px;
  height: 32px;
  border-radius: 8px;
  background: rgba(255,107,53,.12);
  color: #ff8c5a;
  flex-shrink: 0;
}
.draft-explore-channel-meta { flex: 1; min-width: 0; }
.draft-explore-channel-label {
  font-family: var(--font-mono);
  font-size: 10px;
  text-transform: uppercase;
  letter-spacing: .08em;
  color: rgba(255,255,255,.5);
  margin-bottom: 2px;
}
.draft-explore-channel-value {
  font-family: var(--font-sans);
  font-size: 13.5px;
  font-weight: 500;
  color: #fff;
  letter-spacing: -.005em;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

@media (max-width: 600px) {
  .draft-explore-card { padding: 28px 24px 24px; min-height: 320px; }
  .draft-explore-bg { width: 50%; height: 50%; }
  .draft-explore-title { max-width: 100%; }
  .draft-explore-channel-value { white-space: normal; }
}

/* ════════════════════════════════════════════════════════════
   HOME — Explore section (final navigation cards)
   ════════════════════════════════════════════════════════════ */
.home-explore {
  padding: 100px clamp(20px,6vw,80px) 120px;
  border-top: 1px solid var(--border, rgba(0,0,0,.06));
}
.home-explore-inner {
  max-width: 1200px;
  margin: 0 auto;
}

/* Section head — centered like the others */
.home-explore-head {
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  gap: 12px;
  margin: 0 auto 56px;
  max-width: 720px;
}
.home-explore-num {
  font-family: var(--font-mono);
  font-size: 12px;
  color: var(--text-muted, #888);
  letter-spacing: .12em;
  font-weight: 500;
  padding-top: 8px;
  border-top: 2px solid var(--accent, #ff6b35);
  width: fit-content;
  margin-bottom: 8px;
}
.home-explore-meta { width: 100%; }
.home-explore-label {
  font-family: var(--font-mono);
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: .08em;
  color: var(--text-muted, #888);
  margin-bottom: 12px;
}
.home-explore-title {
  font-family: var(--font-sans);
  font-size: clamp(28px, 3.5vw, 44px);
  font-weight: 600;
  letter-spacing: -.035em;
  line-height: 1.1;
  color: var(--text);
  margin: 0 0 16px;
}
.home-explore-desc {
  font-size: 17px;
  line-height: 1.6;
  color: var(--text-muted, #666);
  margin: 0 auto;
  letter-spacing: -.005em;
  max-width: 600px;
}

/* ─── Hero card: 24h Draft (full width, dark + orange glow) ─── */
.home-explore-wide {
  position: relative;
  display: grid;
  grid-template-columns: 1.5fr 1fr;
  gap: 32px;
  padding: 48px 40px;
  border-radius: 18px;
  background: linear-gradient(135deg, #0a0a0a 0%, #1a1a1a 50%, #18120c 100%);
  text-decoration: none;
  color: #fff;
  overflow: hidden;
  isolation: isolate;
  border: 1px solid rgba(255,255,255,.06);
  transition: transform .3s cubic-bezier(.22,1,.36,1), border-color .25s ease;
  align-items: center;
  margin-bottom: 16px;
  min-height: 240px;
}
.home-explore-wide:hover {
  transform: translateY(-3px);
  border-color: rgba(255,107,53,.35);
}
.home-explore-wide-bg {
  position: absolute;
  inset: 0;
  z-index: -1;
  pointer-events: none;
  overflow: hidden;
}
.home-explore-wide-glow {
  position: absolute;
  bottom: -20%;
  right: -10%;
  width: 60%;
  height: 140%;
  background: radial-gradient(circle, rgba(255,107,53,.4) 0%, rgba(247,147,30,.12) 35%, transparent 65%);
  filter: blur(60px);
  pointer-events: none;
}
@media (max-width: 800px) {
  .home-explore-wide { grid-template-columns: 1fr; gap: 24px; padding: 36px 28px; }
}
.home-explore-wide-eyebrow {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-family: var(--font-mono);
  font-size: 11px;
  font-weight: 600;
  letter-spacing: .12em;
  color: #ff8c5a;
  margin-bottom: 14px;
}
.home-explore-wide-dot {
  width: 7px;
  height: 7px;
  border-radius: 50%;
  background: #ff6b35;
  box-shadow: 0 0 12px rgba(255,107,53,.7);
  animation: ctaPulse 1.8s cubic-bezier(.22,1,.36,1) infinite;
}
.home-explore-wide-title {
  font-family: var(--font-sans);
  font-size: clamp(26px, 3vw, 38px);
  font-weight: 600;
  letter-spacing: -.03em;
  line-height: 1.1;
  margin: 0 0 14px;
  color: #fff;
}
.home-explore-wide-accent {
  background: linear-gradient(135deg, #ff6b35 0%, #f7931e 60%, #facc15 100%);
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
  color: transparent;
}
.home-explore-wide-desc {
  font-size: 15.5px;
  line-height: 1.55;
  color: rgba(255,255,255,.7);
  margin: 0 0 22px;
  letter-spacing: -.005em;
  max-width: 90%;
}
.home-explore-wide-cta {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  padding: 12px 22px;
  background: linear-gradient(135deg, #ff6b35 0%, #f7931e 100%);
  color: #fff;
  border-radius: 100px;
  font-family: var(--font-sans);
  font-size: 14px;
  font-weight: 600;
  letter-spacing: -.005em;
  box-shadow: 0 4px 14px rgba(255,107,53,.35);
  transition: transform .2s ease, filter .2s ease;
  width: fit-content;
}
.home-explore-wide:hover .home-explore-wide-cta {
  filter: brightness(1.05);
  transform: translateX(2px);
}

/* Stats column on the right */
.home-explore-wide-stats {
  display: flex;
  align-items: center;
  gap: 20px;
  padding: 24px;
  background: rgba(255,255,255,.03);
  border: 1px solid rgba(255,255,255,.07);
  border-radius: 14px;
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
}
.home-explore-wide-stat {
  text-align: center;
  flex: 1;
}
.home-explore-wide-stat-num {
  font-family: var(--font-sans);
  font-size: clamp(36px, 5vw, 52px);
  font-weight: 600;
  line-height: 1;
  letter-spacing: -.04em;
  color: #fff;
  margin-bottom: 6px;
}
.home-explore-wide-stat-num span {
  font-size: .55em;
  font-weight: 500;
  color: rgba(255,255,255,.6);
  margin-left: 2px;
}
.home-explore-wide-stat-label {
  font-family: var(--font-mono);
  font-size: 10.5px;
  text-transform: uppercase;
  letter-spacing: .06em;
  color: rgba(255,255,255,.55);
}
.home-explore-wide-stat-divider {
  width: 1px;
  height: 36px;
  background: rgba(255,255,255,.1);
}

/* ─── Bottom row: 2 colored cards (Portfolio + Services) ─── */
.home-explore-top {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 16px;
}
@media (max-width: 720px) {
  .home-explore-top { grid-template-columns: 1fr; }
}

.home-explore-card {
  position: relative;
  display: flex;
  flex-direction: column;
  padding: 36px 32px 32px;
  border-radius: 18px;
  text-decoration: none;
  color: #fff;
  overflow: hidden;
  isolation: isolate;
  min-height: 360px;
  transition: transform .3s cubic-bezier(.22,1,.36,1), box-shadow .3s ease;
}
.home-explore-card:hover {
  transform: translateY(-4px);
}
.home-explore-bg {
  position: absolute;
  top: 0;
  right: 0;
  width: 55%;
  height: 60%;
  z-index: -1;
  pointer-events: none;
  display: flex;
  align-items: flex-start;
  justify-content: flex-end;
  padding: 24px 24px 0 0;
}
.home-explore-art {
  width: 100%;
  height: auto;
  max-height: 200px;
  opacity: .9;
}
.home-explore-card--portfolio {
  background: linear-gradient(135deg, #059669 0%, #047857 50%, #065f46 100%);
  box-shadow: 0 1px 0 rgba(255,255,255,.12) inset, 0 8px 24px rgba(5,150,105,.18);
}
.home-explore-card--portfolio:hover {
  box-shadow: 0 1px 0 rgba(255,255,255,.18) inset, 0 16px 40px rgba(5,150,105,.32);
}
.home-explore-card--services {
  background: linear-gradient(135deg, #6366f1 0%, #5b21b6 60%, #4c1d95 100%);
  box-shadow: 0 1px 0 rgba(255,255,255,.12) inset, 0 8px 24px rgba(99,102,241,.18);
}
.home-explore-card--services:hover {
  box-shadow: 0 1px 0 rgba(255,255,255,.18) inset, 0 16px 40px rgba(99,102,241,.32);
}
.home-explore-card--blog {
  background: linear-gradient(135deg, #b45309 0%, #92400e 55%, #78350f 100%);
  box-shadow: 0 1px 0 rgba(255,255,255,.12) inset, 0 8px 24px rgba(180,83,9,.18);
}
.home-explore-card--blog:hover {
  box-shadow: 0 1px 0 rgba(255,255,255,.18) inset, 0 16px 40px rgba(180,83,9,.32);
}

.home-explore-eyebrow {
  font-family: var(--font-mono);
  font-size: 11px;
  font-weight: 600;
  letter-spacing: .12em;
  color: rgba(255,255,255,.75);
  margin-bottom: 14px;
}
.home-explore-card-title {
  font-family: var(--font-sans);
  font-size: clamp(28px, 3vw, 38px);
  font-weight: 600;
  letter-spacing: -.03em;
  line-height: 1.1;
  margin: 0 0 14px;
  color: #fff;
  max-width: 60%;
}
.home-explore-card-desc {
  font-size: 15px;
  line-height: 1.55;
  color: rgba(255,255,255,.85);
  margin: 0 0 20px;
  max-width: 90%;
  letter-spacing: -.005em;
}
.home-explore-chips {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  margin-bottom: auto;
  padding-bottom: 24px;
}
.home-explore-chip {
  display: inline-flex;
  align-items: center;
  padding: 5px 11px;
  font-family: var(--font-mono);
  font-size: 11px;
  font-weight: 500;
  letter-spacing: .02em;
  background: rgba(255,255,255,.16);
  border: 1px solid rgba(255,255,255,.18);
  border-radius: 100px;
  color: #fff;
  backdrop-filter: blur(6px);
  -webkit-backdrop-filter: blur(6px);
}
.home-explore-cta {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-family: var(--font-sans);
  font-size: 14px;
  font-weight: 600;
  color: #fff;
  letter-spacing: -.005em;
  transition: transform .2s ease;
  margin-top: auto;
}
.home-explore-card:hover .home-explore-cta {
  transform: translateX(4px);
}

@media (max-width: 600px) {
  .home-explore-card { padding: 28px 24px 24px; min-height: 320px; }
  .home-explore-bg { width: 50%; height: 50%; }
  .home-explore-card-title { max-width: 100%; }
  .home-explore-wide-stats { width: 100%; }
}

/* ════════════════════════════════════════════════════════════
   HOME — Why us (spec sheet aesthetic, 6 cards)
   ════════════════════════════════════════════════════════════ */
.why-spec-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1px;
  background: var(--border, rgba(0,0,0,.08));
  border: 1px solid var(--border, rgba(0,0,0,.08));
  border-radius: 14px;
  overflow: hidden;
}
.why-spec-card {
  position: relative;
  padding: 32px;
  background: var(--bg, #fff);
  display: flex;
  flex-direction: column;
  transition: background .2s ease;
  overflow: hidden;
}
.why-spec-card::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 2px;
  background: linear-gradient(90deg, transparent 0%, var(--accent, #ff6b35) 30%, var(--accent, #ff6b35) 70%, transparent 100%);
  opacity: 0;
  transform: translateY(-2px);
  transition: opacity .25s ease, transform .25s ease;
}
.why-spec-card:hover {
  background: var(--surface-1, rgba(0,0,0,.015));
}
.why-spec-card:hover::before {
  opacity: 1;
  transform: translateY(0);
}

/* Header row: tag + icon */
.why-spec-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 28px;
  padding-bottom: 16px;
  border-bottom: 1px dashed var(--border, rgba(0,0,0,.1));
}
.why-spec-tag {
  display: inline-flex;
  align-items: baseline;
  gap: 4px;
  font-family: var(--font-mono);
  font-size: 11px;
  font-weight: 500;
  color: var(--text-muted, #888);
  letter-spacing: .02em;
}
.why-spec-tag-num {
  color: var(--text);
  font-weight: 600;
  font-size: 12px;
  letter-spacing: .03em;
}
.why-spec-tag-sep {
  color: var(--text-muted, #ccc);
  margin: 0 1px;
}
.why-spec-tag-tot {
  color: var(--text-muted, #aaa);
  font-size: 11px;
}
.why-spec-tag-label {
  margin-left: 10px;
  padding-left: 10px;
  border-left: 1px solid var(--border, rgba(0,0,0,.12));
  color: var(--text-muted, #888);
  font-size: 10.5px;
  letter-spacing: .04em;
  text-transform: lowercase;
}
.why-spec-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 28px;
  height: 28px;
  color: var(--text-muted, #888);
  background: transparent;
  border: 1px solid var(--border, rgba(0,0,0,.12));
  border-radius: 6px;
  flex-shrink: 0;
  transition: color .25s ease, border-color .25s ease;
}
.why-spec-card:hover .why-spec-icon {
  color: #ff6b35;
  border-color: rgba(255,107,53,.4);
}

.why-spec-title {
  font-family: var(--font-sans) !important;
  font-size: 18px !important;
  font-weight: 600 !important;
  letter-spacing: -.018em !important;
  margin: 0 0 10px !important;
  color: var(--text);
  line-height: 1.25;
}
.why-spec-desc {
  font-size: 14.5px;
  line-height: 1.6;
  color: var(--text-muted, #666);
  margin: 0 0 28px;
  letter-spacing: -.003em;
}

/* Spec metadata at the bottom */
.why-spec-meta {
  margin-top: auto;
  padding-top: 16px;
  border-top: 1px dashed var(--border, rgba(0,0,0,.1));
  display: flex;
  flex-direction: column;
  gap: 6px;
}
.why-spec-meta-item {
  display: flex;
  align-items: baseline;
  gap: 12px;
  font-family: var(--font-mono);
  font-size: 11.5px;
  letter-spacing: .01em;
}
.why-spec-meta-key {
  color: var(--text-muted, #aaa);
  text-transform: uppercase;
  font-size: 10.5px;
  letter-spacing: .08em;
  flex-shrink: 0;
  min-width: 80px;
}
.why-spec-meta-val {
  color: var(--text);
  font-weight: 500;
  letter-spacing: -.005em;
  font-size: 12px;
  font-family: var(--font-sans);
}

@media (max-width: 960px) {
  .why-spec-grid { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 600px) {
  .why-spec-grid { grid-template-columns: 1fr; }
  .why-spec-card { padding: 24px; }
  .why-spec-tag-label { display: none; }
}

/* ════════════════════════════════════════════════════════════
   SERVICES — Pillars (tech spec aesthetic, 3 large cards)
   ════════════════════════════════════════════════════════════ */
.svc-pillar-card {
  position: relative;
  margin-bottom: 24px;
  padding: 36px 36px 32px;
  background: var(--bg, #fff);
  border: 1px solid var(--border, rgba(0,0,0,.08));
  border-radius: 16px;
  transition: border-color .25s ease, box-shadow .25s ease;
  overflow: hidden;
}
.svc-pillar-card:last-child { margin-bottom: 0; }
.svc-pillar-card::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 2px;
  background: linear-gradient(90deg, transparent 0%, var(--accent, #ff6b35) 30%, var(--accent, #ff6b35) 70%, transparent 100%);
  opacity: 0;
  transform: translateY(-2px);
  transition: opacity .25s ease, transform .25s ease;
}
.svc-pillar-card:hover {
  border-color: var(--border-strong, rgba(0,0,0,.16));
  box-shadow: 0 8px 32px rgba(0,0,0,.04);
}
.svc-pillar-card:hover::before {
  opacity: 1;
  transform: translateY(0);
}

/* Header row: tag + explore link */
.svc-pillar-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 24px;
  padding-bottom: 16px;
  border-bottom: 1px dashed var(--border, rgba(0,0,0,.1));
}
.svc-pillar-tag {
  display: inline-flex;
  align-items: baseline;
  gap: 4px;
  font-family: var(--font-mono);
  font-size: 11px;
  font-weight: 500;
  color: var(--text-muted, #888);
  letter-spacing: .02em;
}
.svc-pillar-tag-num {
  color: var(--text);
  font-weight: 600;
  font-size: 12px;
  letter-spacing: .03em;
}
.svc-pillar-tag-sep { color: var(--text-muted, #ccc); margin: 0 1px; }
.svc-pillar-tag-tot { color: var(--text-muted, #aaa); font-size: 11px; }
.svc-pillar-tag-label {
  margin-left: 10px;
  padding-left: 10px;
  border-left: 1px solid var(--border, rgba(0,0,0,.12));
  color: var(--text-muted, #888);
  font-size: 10.5px;
  letter-spacing: .04em;
  text-transform: lowercase;
}
.svc-pillar-link {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-family: var(--font-sans);
  font-size: 13px;
  font-weight: 500;
  color: var(--text-muted, #666);
  text-decoration: none;
  letter-spacing: -.005em;
  padding: 6px 12px;
  border: 1px solid var(--border, rgba(0,0,0,.12));
  border-radius: 100px;
  transition: all .2s ease;
}
.svc-pillar-link:hover {
  color: #ff6b35;
  border-color: rgba(255,107,53,.4);
  background: rgba(255,107,53,.04);
}

/* Title row: icon + title */
.svc-pillar-title-row {
  display: flex;
  align-items: center;
  gap: 14px;
  margin-bottom: 12px;
}
.svc-pillar-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 36px;
  height: 36px;
  color: var(--text);
  background: var(--surface-1, rgba(0,0,0,.04));
  border: 1px solid var(--border, rgba(0,0,0,.1));
  border-radius: 8px;
  flex-shrink: 0;
  transition: color .2s ease, border-color .2s ease;
}
.svc-pillar-card:hover .svc-pillar-icon {
  color: #ff6b35;
  border-color: rgba(255,107,53,.4);
}
.svc-pillar-title {
  font-family: var(--font-sans) !important;
  font-size: clamp(22px, 2.5vw, 28px) !important;
  font-weight: 600 !important;
  letter-spacing: -.025em !important;
  line-height: 1.15 !important;
  margin: 0 !important;
  color: var(--text);
}
.svc-pillar-desc {
  font-size: 15.5px;
  line-height: 1.6;
  color: var(--text-muted, #666);
  margin: 0 0 24px;
  letter-spacing: -.005em;
  max-width: 720px;
}

/* Capability rows (replaces emoji-cards) */
.svc-pillar-caps {
  display: flex;
  flex-direction: column;
  gap: 1px;
  background: var(--border, rgba(0,0,0,.08));
  border: 1px solid var(--border, rgba(0,0,0,.08));
  border-radius: 10px;
  overflow: hidden;
}
.svc-cap-row {
  display: grid;
  grid-template-columns: 90px 1fr 2fr auto;
  align-items: center;
  gap: 16px;
  padding: 14px 18px;
  background: var(--bg, #fff);
  text-decoration: none;
  color: var(--text);
  transition: background .15s ease;
}
.svc-cap-row:hover {
  background: var(--surface-1, rgba(0,0,0,.02));
}
.svc-cap-code {
  font-family: var(--font-mono);
  font-size: 11px;
  font-weight: 600;
  letter-spacing: .04em;
  color: var(--text-muted, #888);
}
.svc-cap-name {
  font-family: var(--font-sans);
  font-size: 14.5px;
  font-weight: 500;
  letter-spacing: -.005em;
  color: var(--text);
}
.svc-cap-desc {
  font-family: var(--font-sans);
  font-size: 13.5px;
  color: var(--text-muted, #777);
  letter-spacing: -.003em;
  line-height: 1.5;
}
.svc-cap-arrow {
  color: var(--text-muted, #aaa);
  font-size: 16px;
  font-family: var(--font-mono);
  transition: color .2s ease, transform .2s ease;
  font-weight: 300;
}
.svc-cap-row:hover .svc-cap-arrow {
  color: #ff6b35;
  transform: translateX(3px);
}
@media (max-width: 720px) {
  .svc-pillar-card { padding: 28px 24px 24px; }
  .svc-pillar-header { flex-wrap: wrap; gap: 12px; }
  .svc-cap-row {
    grid-template-columns: 1fr auto;
    gap: 8px;
    padding: 14px 16px;
  }
  .svc-cap-code { grid-column: 1 / -1; font-size: 10px; }
  .svc-cap-name { grid-column: 1; font-size: 14px; }
  .svc-cap-arrow { grid-column: 2; grid-row: 2; }
  .svc-cap-desc { grid-column: 1 / -1; font-size: 13px; }
}

/* ════════════════════════════════════════════════════════════
   SERVICES — Process (6 cards, tech spec sheet aesthetic)
   ════════════════════════════════════════════════════════════ */
.svc-process-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1px;
  background: var(--border, rgba(0,0,0,.08));
  border: 1px solid var(--border, rgba(0,0,0,.08));
  border-radius: 14px;
  overflow: hidden;
}
.svc-process-card {
  position: relative;
  padding: 28px 26px;
  background: var(--bg, #fff);
  display: flex;
  flex-direction: column;
  transition: background .2s ease;
  overflow: hidden;
}
.svc-process-card::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 2px;
  background: linear-gradient(90deg, transparent 0%, var(--accent, #ff6b35) 30%, var(--accent, #ff6b35) 70%, transparent 100%);
  opacity: 0;
  transform: translateY(-2px);
  transition: opacity .25s ease, transform .25s ease;
}
.svc-process-card:hover {
  background: var(--surface-1, rgba(0,0,0,.015));
}
.svc-process-card:hover::before {
  opacity: 1;
  transform: translateY(0);
}

.svc-process-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 20px;
  padding-bottom: 14px;
  border-bottom: 1px dashed var(--border, rgba(0,0,0,.1));
}
.svc-process-tag {
  display: inline-flex;
  align-items: baseline;
  gap: 4px;
  font-family: var(--font-mono);
  font-size: 11px;
  font-weight: 500;
  color: var(--text-muted, #888);
  letter-spacing: .02em;
}
.svc-process-tag-num {
  color: var(--text);
  font-weight: 600;
  font-size: 12px;
  letter-spacing: .03em;
}
.svc-process-tag-sep { color: var(--text-muted, #ccc); margin: 0 1px; }
.svc-process-tag-tot { color: var(--text-muted, #aaa); font-size: 11px; }
.svc-process-tag-label {
  margin-left: 10px;
  padding-left: 10px;
  border-left: 1px solid var(--border, rgba(0,0,0,.12));
  color: var(--text-muted, #888);
  font-size: 10.5px;
  letter-spacing: .04em;
  text-transform: lowercase;
}
.svc-process-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 28px;
  height: 28px;
  color: var(--text-muted, #888);
  background: transparent;
  border: 1px solid var(--border, rgba(0,0,0,.12));
  border-radius: 6px;
  flex-shrink: 0;
  transition: color .25s ease, border-color .25s ease;
}
.svc-process-card:hover .svc-process-icon {
  color: #ff6b35;
  border-color: rgba(255,107,53,.4);
}
.svc-process-title {
  font-family: var(--font-sans) !important;
  font-size: 17px !important;
  font-weight: 600 !important;
  letter-spacing: -.018em !important;
  margin: 0 0 8px !important;
  color: var(--text);
  line-height: 1.25 !important;
}
.svc-process-desc {
  font-size: 14px;
  line-height: 1.55;
  color: var(--text-muted, #666);
  margin: 0 0 24px;
  letter-spacing: -.003em;
}
.svc-process-meta {
  margin-top: auto;
  padding-top: 14px;
  border-top: 1px dashed var(--border, rgba(0,0,0,.1));
  display: flex;
  flex-direction: column;
  gap: 6px;
}
.svc-process-meta-item {
  display: flex;
  align-items: baseline;
  gap: 12px;
}
.svc-process-meta-key {
  color: var(--text-muted, #aaa);
  text-transform: uppercase;
  font-size: 10px;
  letter-spacing: .08em;
  flex-shrink: 0;
  min-width: 70px;
  font-family: var(--font-mono);
}
.svc-process-meta-val {
  color: var(--text);
  font-weight: 500;
  letter-spacing: -.005em;
  font-size: 12px;
  font-family: var(--font-sans);
}

@media (max-width: 960px) {
  .svc-process-grid { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 600px) {
  .svc-process-grid { grid-template-columns: 1fr; }
  .svc-process-card { padding: 24px; }
  .svc-process-tag-label { display: none; }
}

/* ═══════════════════════════════════════════════════════════
   ABOUT PAGE — spec sheet variants (v6.2)
   ═══════════════════════════════════════════════════════════ */

/* ─── Industries (anexo 4 reformulado) ───────────────────── */
.about-ind-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 1px;
  background: var(--border);
  border: 1px solid var(--border);
  border-radius: 16px;
  overflow: hidden;
  max-width: 1200px;
  margin: 0 auto;
}
.about-ind-card {
  background: var(--bg);
  padding: 24px 22px;
  display: flex;
  flex-direction: column;
  gap: 14px;
  position: relative;
  transition: background .2s ease;
}
.about-ind-card::before {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 2px;
  background: linear-gradient(90deg, transparent, #ff6b35, transparent);
  opacity: 0;
  transition: opacity .25s ease;
}
.about-ind-card:hover { background: var(--surface-1); }
.about-ind-card:hover::before { opacity: 1; }
.about-ind-head {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding-bottom: 14px;
  border-bottom: 1px dashed var(--border);
}
.about-ind-code {
  font-family: var(--font-mono);
  font-size: 11px;
  font-weight: 500;
  color: var(--text-muted);
  text-transform: uppercase;
  letter-spacing: .08em;
}
.about-ind-icon {
  width: 28px;
  height: 28px;
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--text-muted);
  transition: color .25s ease;
}
.about-ind-card:hover .about-ind-icon { color: #ff6b35; }
.about-ind-name {
  font-family: var(--font-sans);
  font-size: 15px;
  font-weight: 500;
  color: var(--text);
  letter-spacing: -.01em;
}
.about-ind-desc {
  font-family: var(--font-sans);
  font-size: 12px;
  color: var(--text-muted);
  line-height: 1.5;
}
@media (max-width: 1024px) { .about-ind-grid { grid-template-columns: repeat(3, 1fr); } }
@media (max-width: 768px)  { .about-ind-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 480px)  { .about-ind-grid { grid-template-columns: 1fr; } }

/* ─── Numbers grid (anexo 5 reformulado) ─────────────────── */
.about-num-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 1px;
  background: var(--border);
  border: 1px solid var(--border);
  border-radius: 16px;
  overflow: hidden;
  max-width: 1200px;
  margin: 0 auto;
}
.about-num-card {
  background: var(--bg);
  padding: 32px 24px 26px;
  display: flex;
  flex-direction: column;
  gap: 8px;
  position: relative;
  transition: background .2s ease;
}
.about-num-card::before {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 2px;
  background: linear-gradient(90deg, transparent, #ff6b35, transparent);
  opacity: 0;
  transition: opacity .25s ease;
}
.about-num-card:hover { background: var(--surface-1); }
.about-num-card:hover::before { opacity: 1; }
.about-num-code {
  font-family: var(--font-mono);
  font-size: 10px;
  font-weight: 500;
  color: var(--text-faint);
  letter-spacing: .12em;
  margin-bottom: 4px;
}
.about-num-value {
  font-family: var(--font-sans);
  font-size: clamp(32px, 4vw, 44px);
  font-weight: 600;
  letter-spacing: -.04em;
  color: var(--text);
  line-height: 1;
}
.about-num-label {
  font-family: var(--font-sans);
  font-size: 13px;
  font-weight: 500;
  color: var(--text);
  text-transform: uppercase;
  letter-spacing: .04em;
  margin-top: 4px;
}
.about-num-meta {
  font-family: var(--font-mono);
  font-size: 11px;
  color: var(--text-muted);
  padding-top: 12px;
  margin-top: auto;
  border-top: 1px dashed var(--border);
}
@media (max-width: 1024px) { .about-num-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 480px)  { .about-num-grid { grid-template-columns: 1fr; } }

/* ─── Tech grid (anexo 6 reformulado) ────────────────────── */
.about-tech-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 1px;
  background: var(--border);
  border: 1px solid var(--border);
  border-radius: 16px;
  overflow: hidden;
  max-width: 1200px;
  margin: 0 auto;
}
.about-tech-card {
  background: var(--bg);
  padding: 24px 22px;
  display: flex;
  flex-direction: column;
  gap: 12px;
  position: relative;
  transition: background .2s ease;
}
.about-tech-card::before {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 2px;
  background: linear-gradient(90deg, transparent, #ff6b35, transparent);
  opacity: 0;
  transition: opacity .25s ease;
}
.about-tech-card:hover { background: var(--surface-1); }
.about-tech-card:hover::before { opacity: 1; }
.about-tech-name {
  font-family: var(--font-sans);
  font-size: 17px;
  font-weight: 600;
  color: var(--text);
  letter-spacing: -.01em;
}
.about-tech-meta {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 8px;
  padding-top: 12px;
  border-top: 1px dashed var(--border);
}
.about-tech-cat {
  font-family: var(--font-mono);
  font-size: 10px;
  font-weight: 500;
  color: var(--text-muted);
  letter-spacing: .12em;
  text-transform: uppercase;
}
.about-tech-tag {
  font-family: var(--font-mono);
  font-size: 10px;
  color: var(--text-faint);
  letter-spacing: .04em;
}
@media (max-width: 1024px) { .about-tech-grid { grid-template-columns: repeat(3, 1fr); } }
@media (max-width: 768px)  { .about-tech-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 480px)  { .about-tech-grid { grid-template-columns: 1fr; } }

/* ─── Network grid (anexo 7 reformulado) ─────────────────── */
.about-net-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1px;
  background: var(--border);
  border: 1px solid var(--border);
  border-radius: 16px;
  overflow: hidden;
  max-width: 1200px;
  margin: 0 auto;
}
.about-net-card {
  background: var(--bg);
  padding: 26px 24px;
  display: flex;
  flex-direction: column;
  gap: 10px;
  position: relative;
  text-decoration: none;
  color: inherit;
  transition: background .2s ease;
}
.about-net-card::before {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 2px;
  background: linear-gradient(90deg, transparent, #ff6b35, transparent);
  opacity: 0;
  transition: opacity .25s ease;
}
.about-net-card:hover { background: var(--surface-1); }
.about-net-card:hover::before { opacity: 1; }
.about-net-head {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding-bottom: 14px;
  border-bottom: 1px dashed var(--border);
  margin-bottom: 4px;
}
.about-net-code {
  font-family: var(--font-mono);
  font-size: 11px;
  font-weight: 500;
  color: var(--text-muted);
  text-transform: uppercase;
  letter-spacing: .08em;
}
.about-net-arrow {
  font-family: var(--font-mono);
  font-size: 16px;
  color: var(--text-muted);
  transition: color .25s ease, transform .25s ease;
}
.about-net-card:hover .about-net-arrow {
  color: #ff6b35;
  transform: translateX(4px);
}
.about-net-name {
  font-family: var(--font-sans);
  font-size: 17px;
  font-weight: 600;
  color: var(--text);
  letter-spacing: -.01em;
}
.about-net-domain {
  font-family: var(--font-mono);
  font-size: 12px;
  color: var(--text-muted);
}
.about-net-desc {
  font-family: var(--font-sans);
  font-size: 13px;
  color: var(--text-muted);
  line-height: 1.5;
  margin-top: 4px;
}
@media (max-width: 1024px) { .about-net-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 480px)  { .about-net-grid { grid-template-columns: 1fr; } }

/* ─── Contact help rows (sidebar "Como podemos ajudar") ─── */
.contact-help-list {
  display: flex;
  flex-direction: column;
  gap: 1px;
  background: var(--border);
  border: 1px solid var(--border);
  border-radius: 10px;
  overflow: hidden;
}
.contact-help-row {
  display: grid;
  grid-template-columns: auto auto 1fr;
  align-items: center;
  gap: 12px;
  padding: 14px 14px;
  background: var(--card-bg);
  position: relative;
  transition: background .2s ease;
}
.contact-help-row::before {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 2px;
  background: linear-gradient(90deg, transparent, #ff6b35, transparent);
  opacity: 0;
  transition: opacity .25s ease;
}
.contact-help-row:hover { background: var(--surface-1); }
.contact-help-row:hover::before { opacity: 1; }
.contact-help-code {
  font-family: var(--font-mono);
  font-size: 10px;
  font-weight: 500;
  color: var(--text-faint);
  letter-spacing: .08em;
  text-transform: uppercase;
}
.contact-help-icon {
  width: 28px;
  height: 28px;
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--text-muted);
  transition: color .25s ease;
}
.contact-help-row:hover .contact-help-icon { color: #ff6b35; }
.contact-help-body { min-width: 0; }
.contact-help-name {
  font-family: var(--font-sans);
  font-size: 13px;
  font-weight: 600;
  color: var(--text);
  letter-spacing: -.005em;
  line-height: 1.3;
}
.contact-help-desc {
  font-family: var(--font-sans);
  font-size: 11px;
  color: var(--text-muted);
  margin-top: 2px;
  line-height: 1.4;
}

/* ═══════════════════════════════════════════════════════════
   GLOBAL TECH EFFECTS — v6.9 (transversal, applied site-wide)
   ═══════════════════════════════════════════════════════════ */

/* Site-wide ambient layer: fixed behind everything, subtle */
.site-ambient {
  position: fixed;
  inset: 0;
  z-index: -2;
  pointer-events: none;
  overflow: hidden;
}

/* Dot grid background — covers entire viewport, very subtle */
.site-ambient::before {
  content: '';
  position: absolute;
  inset: 0;
  background-image: radial-gradient(circle at 1px 1px, rgba(26, 26, 46, .07) 1px, transparent 0);
  background-size: 32px 32px;
  background-position: 0 0;
  mask-image: radial-gradient(ellipse 100% 80% at 50% 30%, black 30%, transparent 100%);
  -webkit-mask-image: radial-gradient(ellipse 100% 80% at 50% 30%, black 30%, transparent 100%);
  opacity: .55;
}

[data-theme="dark"] .site-ambient::before {
  background-image: radial-gradient(circle at 1px 1px, rgba(255, 255, 255, .05) 1px, transparent 0);
  opacity: .65;
}

/* Floating ambient orbs — 3 orbs that drift slowly */
.site-ambient-orb {
  position: absolute;
  border-radius: 50%;
  filter: blur(80px);
  opacity: .55;
  will-change: transform;
}
.site-ambient-orb--1 {
  width: 600px;
  height: 600px;
  background: radial-gradient(circle, rgba(217, 119, 6, .12), transparent 70%);
  top: -200px;
  right: -150px;
  animation: ambient-drift-1 28s ease-in-out infinite;
}
.site-ambient-orb--2 {
  width: 500px;
  height: 500px;
  background: radial-gradient(circle, rgba(99, 102, 241, .09), transparent 70%);
  top: 40%;
  left: -180px;
  animation: ambient-drift-2 32s ease-in-out infinite;
}
.site-ambient-orb--3 {
  width: 700px;
  height: 700px;
  background: radial-gradient(circle, rgba(234, 88, 12, .08), transparent 70%);
  bottom: -300px;
  right: 20%;
  animation: ambient-drift-3 36s ease-in-out infinite;
}

[data-theme="dark"] .site-ambient-orb--1 { background: radial-gradient(circle, rgba(250, 204, 21, .08), transparent 70%); }
[data-theme="dark"] .site-ambient-orb--2 { background: radial-gradient(circle, rgba(99, 102, 241, .12), transparent 70%); }
[data-theme="dark"] .site-ambient-orb--3 { background: radial-gradient(circle, rgba(234, 88, 12, .06), transparent 70%); }

@keyframes ambient-drift-1 {
  0%, 100% { transform: translate(0, 0) scale(1); }
  33% { transform: translate(-40px, 60px) scale(1.08); }
  66% { transform: translate(30px, -40px) scale(.95); }
}
@keyframes ambient-drift-2 {
  0%, 100% { transform: translate(0, 0) scale(1); }
  50% { transform: translate(60px, -50px) scale(1.05); }
}
@keyframes ambient-drift-3 {
  0%, 100% { transform: translate(0, 0) scale(1); }
  40% { transform: translate(-50px, -40px) scale(.92); }
  80% { transform: translate(40px, 30px) scale(1.06); }
}

/* Reduce motion — disable orb animations */
@media (prefers-reduced-motion: reduce) {
  .site-ambient-orb { animation: none !important; }
}

/* Mobile — hide orbs, keep only dot grid */
@media (max-width: 768px) {
  .site-ambient-orb { display: none; }
  .site-ambient::before { background-size: 24px 24px; }
}

/* ═══ Section-level alternating backgrounds ═══ */

/* Subtle dot grid at section level (denser than ambient) */
.section-dots {
  position: relative;
  isolation: isolate;
}
.section-dots::before {
  content: '';
  position: absolute;
  inset: 0;
  background-image: radial-gradient(circle at 1px 1px, rgba(26, 26, 46, .055) 1px, transparent 0);
  background-size: 22px 22px;
  mask-image: linear-gradient(180deg, transparent 0%, black 15%, black 85%, transparent 100%);
  -webkit-mask-image: linear-gradient(180deg, transparent 0%, black 15%, black 85%, transparent 100%);
  z-index: -1;
  pointer-events: none;
}
[data-theme="dark"] .section-dots::before {
  background-image: radial-gradient(circle at 1px 1px, rgba(255, 255, 255, .055) 1px, transparent 0);
}

/* Grid lines pattern — for tech-heavy sections */
.section-grid {
  position: relative;
  isolation: isolate;
}
.section-grid::before {
  content: '';
  position: absolute;
  inset: 0;
  background-image:
    linear-gradient(rgba(26, 26, 46, .035) 1px, transparent 1px),
    linear-gradient(90deg, rgba(26, 26, 46, .035) 1px, transparent 1px);
  background-size: 64px 64px;
  mask-image: radial-gradient(ellipse 70% 80% at 50% 50%, black 30%, transparent 100%);
  -webkit-mask-image: radial-gradient(ellipse 70% 80% at 50% 50%, black 30%, transparent 100%);
  z-index: -1;
  pointer-events: none;
}
[data-theme="dark"] .section-grid::before {
  background-image:
    linear-gradient(rgba(255, 255, 255, .04) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255, 255, 255, .04) 1px, transparent 1px);
}

/* Tech section divider — animated dotted line */
.section-divider-tech {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 12px;
  padding: 32px 20px;
  position: relative;
}
.section-divider-tech::before,
.section-divider-tech::after {
  content: '';
  flex: 1;
  max-width: 200px;
  height: 1px;
  background: linear-gradient(90deg, transparent, var(--border) 20%, var(--border) 80%, transparent);
}
.section-divider-tech-dot {
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: var(--accent);
  box-shadow: 0 0 12px var(--accent);
  animation: divider-pulse 2.4s ease-in-out infinite;
}
.section-divider-tech-mono {
  font-family: var(--font-mono);
  font-size: 11px;
  color: var(--text-faint);
  letter-spacing: .12em;
  text-transform: uppercase;
}
@keyframes divider-pulse {
  0%, 100% { opacity: .4; transform: scale(1); }
  50% { opacity: 1; transform: scale(1.3); }
}

/* Tech corner brackets — for premium sections */
.tech-corners {
  position: relative;
}
.tech-corners::before,
.tech-corners::after {
  content: '';
  position: absolute;
  width: 24px;
  height: 24px;
  border: 1px solid var(--border-hover);
  pointer-events: none;
  opacity: .5;
}
.tech-corners::before {
  top: 24px;
  left: 24px;
  border-right: none;
  border-bottom: none;
}
.tech-corners::after {
  bottom: 24px;
  right: 24px;
  border-left: none;
  border-top: none;
}

/* Section glow variants — solid coloured ambient */
.section-glow-orange {
  position: relative;
  isolation: isolate;
}
.section-glow-orange::before {
  content: '';
  position: absolute;
  inset: 0;
  background:
    radial-gradient(ellipse 50% 60% at 20% 50%, rgba(217, 119, 6, .06), transparent 70%),
    radial-gradient(ellipse 40% 50% at 80% 20%, rgba(234, 88, 12, .05), transparent 70%);
  z-index: -1;
  pointer-events: none;
}
[data-theme="dark"] .section-glow-orange::before {
  background:
    radial-gradient(ellipse 50% 60% at 20% 50%, rgba(250, 204, 21, .04), transparent 70%),
    radial-gradient(ellipse 40% 50% at 80% 20%, rgba(234, 88, 12, .03), transparent 70%);
}

.section-glow-blue {
  position: relative;
  isolation: isolate;
}
.section-glow-blue::before {
  content: '';
  position: absolute;
  inset: 0;
  background:
    radial-gradient(ellipse 50% 50% at 80% 30%, rgba(99, 102, 241, .05), transparent 70%),
    radial-gradient(ellipse 40% 40% at 20% 80%, rgba(56, 189, 248, .04), transparent 70%);
  z-index: -1;
  pointer-events: none;
}

/* Animated gradient line — at top/bottom of premium sections */
.section-line-top,
.section-line-bottom {
  position: relative;
}
.section-line-top::before,
.section-line-bottom::after {
  content: '';
  position: absolute;
  left: 0;
  right: 0;
  height: 1px;
  background: linear-gradient(90deg,
    transparent 0%,
    var(--border) 20%,
    var(--accent) 50%,
    var(--border) 80%,
    transparent 100%);
  opacity: .4;
  pointer-events: none;
}
.section-line-top::before { top: 0; }
.section-line-bottom::after { bottom: 0; }

/* Fix z-index conflicts — content must stay above effects */
.section-dots > *,
.section-grid > *,
.section-glow-orange > *,
.section-glow-blue > * {
  position: relative;
  z-index: 1;
}

/* ═══════════════════════════════════════════════════════════
   TECH NETWORK — reusable canvas effect for sections
   ═══════════════════════════════════════════════════════════ */

.tech-network {
  position: absolute;
  pointer-events: auto;
  z-index: 0;
  inset: 0;
}

/* Position variants */
.tech-network--right    { left: 50%; right: 0; top: 0; bottom: 0; }
.tech-network--left     { left: 0; right: 50%; top: 0; bottom: 0; }
.tech-network--top      { top: 0; left: 0; right: 0; height: 60%; bottom: auto; }
.tech-network--bottom   { bottom: 0; left: 0; right: 0; height: 60%; top: auto; }
.tech-network--corner-tr{ top: 0; right: 0; width: 45%; height: 70%; left: auto; bottom: auto; }
.tech-network--corner-bl{ bottom: 0; left: 0; width: 45%; height: 70%; right: auto; top: auto; }
.tech-network--full     { inset: 0; }

/* Soft fade on edges */
.tech-network--right,
.tech-network--corner-tr {
  mask-image: linear-gradient(90deg, transparent 0%, black 30%, black 100%);
  -webkit-mask-image: linear-gradient(90deg, transparent 0%, black 30%, black 100%);
}
.tech-network--left,
.tech-network--corner-bl {
  mask-image: linear-gradient(90deg, black 0%, black 70%, transparent 100%);
  -webkit-mask-image: linear-gradient(90deg, black 0%, black 70%, transparent 100%);
}
.tech-network--top {
  mask-image: linear-gradient(180deg, black 0%, black 60%, transparent 100%);
  -webkit-mask-image: linear-gradient(180deg, black 0%, black 60%, transparent 100%);
}
.tech-network--bottom {
  mask-image: linear-gradient(180deg, transparent 0%, black 40%, black 100%);
  -webkit-mask-image: linear-gradient(180deg, transparent 0%, black 40%, black 100%);
}
.tech-network--full {
  mask-image: radial-gradient(ellipse 80% 70% at 50% 50%, black 30%, transparent 100%);
  -webkit-mask-image: radial-gradient(ellipse 80% 70% at 50% 50%, black 30%, transparent 100%);
}

/* Hide on small mobile */
@media (max-width: 768px) {
  .tech-network { display: none; }
}

/* Sections that contain a network must have relative positioning + overflow hidden */
.has-tech-network {
  position: relative;
  overflow: hidden;
  isolation: isolate;
}
.has-tech-network > *:not(.tech-network) {
  position: relative;
  z-index: 1;
}

/* ═══════════════════════════════════════════════════════════
   TECH EFFECTS LIBRARY — v7.1
   Reusable visual effects for sections
   ═══════════════════════════════════════════════════════════ */

/* All effects layer below content */
.tech-rays,
.tech-scanline,
.tech-circuit,
.tech-perspective,
.tech-blueprint,
.tech-noise,
.tech-corner-marks,
.tech-pulse-grid,
.tech-data-stream {
  position: absolute;
  inset: 0;
  pointer-events: none;
  z-index: 0;
  overflow: hidden;
}

/* ─── RAYS — diagonal light beams ─────────────────────────── */
.tech-rays::before,
.tech-rays::after {
  content: '';
  position: absolute;
  width: 200%;
  height: 1px;
  background: linear-gradient(90deg,
    transparent 0%,
    rgba(217, 119, 6, .12) 30%,
    rgba(217, 119, 6, .35) 50%,
    rgba(217, 119, 6, .12) 70%,
    transparent 100%);
  transform-origin: center;
  filter: blur(.5px);
}
.tech-rays::before {
  top: 30%;
  left: -50%;
  transform: rotate(-12deg);
  animation: ray-sweep-1 8s ease-in-out infinite;
}
.tech-rays::after {
  top: 65%;
  left: -50%;
  transform: rotate(8deg);
  animation: ray-sweep-2 11s ease-in-out infinite;
  background: linear-gradient(90deg,
    transparent 0%,
    rgba(99, 102, 241, .08) 30%,
    rgba(99, 102, 241, .25) 50%,
    rgba(99, 102, 241, .08) 70%,
    transparent 100%);
}
[data-theme="dark"] .tech-rays::before { background: linear-gradient(90deg, transparent 0%, rgba(250, 204, 21, .08) 30%, rgba(250, 204, 21, .28) 50%, rgba(250, 204, 21, .08) 70%, transparent 100%); }
[data-theme="dark"] .tech-rays::after { background: linear-gradient(90deg, transparent 0%, rgba(99, 102, 241, .07) 30%, rgba(99, 102, 241, .22) 50%, rgba(99, 102, 241, .07) 70%, transparent 100%); }
@keyframes ray-sweep-1 {
  0%, 100% { opacity: .3; transform: rotate(-12deg) translateX(0); }
  50%      { opacity: .9; transform: rotate(-12deg) translateX(80px); }
}
@keyframes ray-sweep-2 {
  0%, 100% { opacity: .25; transform: rotate(8deg) translateX(0); }
  50%      { opacity: .8; transform: rotate(8deg) translateX(-100px); }
}

/* ─── SCANLINE — horizontal sweep ────────────────────────── */
.tech-scanline::before {
  content: '';
  position: absolute;
  left: 0; right: 0;
  height: 2px;
  background: linear-gradient(90deg,
    transparent 0%,
    rgba(217, 119, 6, .15) 20%,
    rgba(217, 119, 6, .55) 50%,
    rgba(217, 119, 6, .15) 80%,
    transparent 100%);
  filter: blur(.5px);
  animation: scanline-vertical 6s linear infinite;
  box-shadow: 0 0 20px rgba(217, 119, 6, .35), 0 0 40px rgba(217, 119, 6, .2);
}
[data-theme="dark"] .tech-scanline::before {
  background: linear-gradient(90deg, transparent 0%, rgba(250, 204, 21, .15) 20%, rgba(250, 204, 21, .6) 50%, rgba(250, 204, 21, .15) 80%, transparent 100%);
  box-shadow: 0 0 20px rgba(250, 204, 21, .35), 0 0 40px rgba(250, 204, 21, .2);
}
@keyframes scanline-vertical {
  0%   { top: -2%; opacity: 0; }
  10%  { opacity: 1; }
  90%  { opacity: 1; }
  100% { top: 102%; opacity: 0; }
}

/* ─── CIRCUIT — PCB-style svg pattern ────────────────────── */
.tech-circuit {
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 200 200'><g fill='none' stroke='rgba(26,26,46,.06)' stroke-width='1'><path d='M0 50 L80 50 L80 100 L150 100 L150 30 L200 30'/><path d='M0 130 L60 130 L60 170 L120 170'/><path d='M40 0 L40 30 L100 30 L100 80 L180 80 L180 200'/><path d='M170 130 L170 200'/></g><g fill='rgba(217,119,6,.18)'><circle cx='80' cy='50' r='2.5'/><circle cx='80' cy='100' r='2.5'/><circle cx='150' cy='100' r='2.5'/><circle cx='150' cy='30' r='2.5'/><circle cx='60' cy='130' r='2.5'/><circle cx='60' cy='170' r='2.5'/><circle cx='40' cy='30' r='2.5'/><circle cx='100' cy='30' r='2.5'/><circle cx='100' cy='80' r='2.5'/><circle cx='180' cy='80' r='2.5'/></g></svg>");
  background-size: 200px 200px;
  background-repeat: repeat;
  opacity: .55;
  mask-image: radial-gradient(ellipse 80% 70% at 50% 50%, black 30%, transparent 100%);
  -webkit-mask-image: radial-gradient(ellipse 80% 70% at 50% 50%, black 30%, transparent 100%);
}
[data-theme="dark"] .tech-circuit {
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 200 200'><g fill='none' stroke='rgba(255,255,255,.05)' stroke-width='1'><path d='M0 50 L80 50 L80 100 L150 100 L150 30 L200 30'/><path d='M0 130 L60 130 L60 170 L120 170'/><path d='M40 0 L40 30 L100 30 L100 80 L180 80 L180 200'/><path d='M170 130 L170 200'/></g><g fill='rgba(250,204,21,.2)'><circle cx='80' cy='50' r='2.5'/><circle cx='80' cy='100' r='2.5'/><circle cx='150' cy='100' r='2.5'/><circle cx='150' cy='30' r='2.5'/><circle cx='60' cy='130' r='2.5'/><circle cx='60' cy='170' r='2.5'/><circle cx='40' cy='30' r='2.5'/><circle cx='100' cy='30' r='2.5'/><circle cx='100' cy='80' r='2.5'/><circle cx='180' cy='80' r='2.5'/></g></svg>");
}

/* ─── PERSPECTIVE GRID — Tron-style floor ────────────────── */
.tech-perspective {
  perspective: 800px;
}
.tech-perspective::before {
  content: '';
  position: absolute;
  bottom: 0;
  left: -10%;
  right: -10%;
  height: 70%;
  background-image:
    linear-gradient(rgba(217, 119, 6, .12) 1px, transparent 1px),
    linear-gradient(90deg, rgba(217, 119, 6, .12) 1px, transparent 1px);
  background-size: 50px 50px;
  transform: rotateX(60deg);
  transform-origin: bottom;
  mask-image: linear-gradient(180deg, transparent 0%, black 50%, black 90%, transparent 100%);
  -webkit-mask-image: linear-gradient(180deg, transparent 0%, black 50%, black 90%, transparent 100%);
  animation: perspective-pulse 6s ease-in-out infinite;
}
[data-theme="dark"] .tech-perspective::before {
  background-image:
    linear-gradient(rgba(250, 204, 21, .14) 1px, transparent 1px),
    linear-gradient(90deg, rgba(250, 204, 21, .14) 1px, transparent 1px);
}
@keyframes perspective-pulse {
  0%, 100% { opacity: .6; }
  50%      { opacity: 1; }
}

/* ─── BLUEPRINT — engineering corners + measure marks ─── */
.tech-blueprint {
  --bp-color: rgba(26, 26, 46, .25);
}
[data-theme="dark"] .tech-blueprint { --bp-color: rgba(255, 255, 255, .25); }
.tech-blueprint::before,
.tech-blueprint::after {
  content: '';
  position: absolute;
  width: 56px;
  height: 56px;
  border: 1px solid var(--bp-color);
}
.tech-blueprint::before {
  top: 24px;
  left: 24px;
  border-right: none;
  border-bottom: none;
}
.tech-blueprint::after {
  bottom: 24px;
  right: 24px;
  border-left: none;
  border-top: none;
}
.tech-blueprint .bp-tick {
  position: absolute;
  font-family: 'Space Mono', monospace;
  font-size: 9px;
  letter-spacing: .15em;
  color: var(--bp-color);
  text-transform: uppercase;
  pointer-events: none;
}
.tech-blueprint .bp-tick--tl { top: 12px; left: 90px; }
.tech-blueprint .bp-tick--br { bottom: 12px; right: 90px; text-align: right; }
.tech-blueprint .bp-tick--ruler-l {
  top: 50%;
  left: 8px;
  transform: translateY(-50%) rotate(-90deg);
  transform-origin: left center;
}
.tech-blueprint .bp-tick--ruler-r {
  top: 50%;
  right: 8px;
  transform: translateY(-50%) rotate(90deg);
  transform-origin: right center;
}

/* ─── NOISE — film grain texture ────────────────────────── */
.tech-noise {
  background-image: url("data:image/svg+xml;utf8,<svg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='.85' numOctaves='2' stitchTiles='stitch'/></filter><rect width='100%' height='100%' filter='url(%23n)' opacity='.45'/></svg>");
  opacity: .035;
  mix-blend-mode: multiply;
}
[data-theme="dark"] .tech-noise { mix-blend-mode: screen; opacity: .05; }

/* ─── CORNER MARKS — minimal mono brackets with codes ───── */
.tech-corner-marks {
  --cm-color: rgba(26, 26, 46, .35);
}
[data-theme="dark"] .tech-corner-marks { --cm-color: rgba(255, 255, 255, .3); }
.tech-corner-marks .cm-bracket {
  position: absolute;
  width: 18px;
  height: 18px;
  border: 1.5px solid var(--cm-color);
}
.tech-corner-marks .cm-bracket--tl { top: 32px; left: 32px; border-right: none; border-bottom: none; }
.tech-corner-marks .cm-bracket--tr { top: 32px; right: 32px; border-left: none; border-bottom: none; }
.tech-corner-marks .cm-bracket--bl { bottom: 32px; left: 32px; border-right: none; border-top: none; }
.tech-corner-marks .cm-bracket--br { bottom: 32px; right: 32px; border-left: none; border-top: none; }
.tech-corner-marks .cm-code {
  position: absolute;
  font-family: 'Space Mono', monospace;
  font-size: 10px;
  letter-spacing: .15em;
  color: var(--cm-color);
  text-transform: uppercase;
  white-space: nowrap;
}
.tech-corner-marks .cm-code--top    { top: 36px; left: 56px; }
.tech-corner-marks .cm-code--bottom { bottom: 36px; right: 56px; }

/* ─── PULSE GRID — grid with random pulsing dots ────────── */
.tech-pulse-grid::before {
  content: '';
  position: absolute;
  inset: 0;
  background-image:
    linear-gradient(rgba(26, 26, 46, .04) 1px, transparent 1px),
    linear-gradient(90deg, rgba(26, 26, 46, .04) 1px, transparent 1px);
  background-size: 40px 40px;
  mask-image: radial-gradient(ellipse 80% 90% at 50% 50%, black 30%, transparent 100%);
  -webkit-mask-image: radial-gradient(ellipse 80% 90% at 50% 50%, black 30%, transparent 100%);
}
[data-theme="dark"] .tech-pulse-grid::before {
  background-image:
    linear-gradient(rgba(255, 255, 255, .04) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255, 255, 255, .04) 1px, transparent 1px);
}
.tech-pulse-grid .pg-dot {
  position: absolute;
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: var(--accent);
  box-shadow: 0 0 12px var(--accent);
  animation: pg-pulse 3s ease-in-out infinite;
  opacity: 0;
}
.tech-pulse-grid .pg-dot:nth-child(1) { top: 20%;  left: 15%; animation-delay: 0s; }
.tech-pulse-grid .pg-dot:nth-child(2) { top: 35%;  left: 75%; animation-delay: .5s; }
.tech-pulse-grid .pg-dot:nth-child(3) { top: 60%;  left: 25%; animation-delay: 1s; }
.tech-pulse-grid .pg-dot:nth-child(4) { top: 75%;  left: 80%; animation-delay: 1.5s; }
.tech-pulse-grid .pg-dot:nth-child(5) { top: 45%;  left: 50%; animation-delay: 2s; }
.tech-pulse-grid .pg-dot:nth-child(6) { top: 80%;  left: 45%; animation-delay: 2.5s; }
@keyframes pg-pulse {
  0%, 100% { opacity: 0; transform: scale(.5); }
  50%      { opacity: 1; transform: scale(1.5); }
}

/* ─── DATA STREAM — vertical mono characters falling ───── */
.tech-data-stream {
  font-family: 'Space Mono', monospace;
  color: var(--accent);
}
.tech-data-stream .ds-col {
  position: absolute;
  top: -10%;
  font-size: 11px;
  line-height: 1.4;
  letter-spacing: 0;
  white-space: pre;
  opacity: .15;
  animation: ds-fall 12s linear infinite;
  filter: blur(.3px);
}
.tech-data-stream .ds-col:nth-child(1) { left: 8%;  animation-duration: 14s; animation-delay: 0s; }
.tech-data-stream .ds-col:nth-child(2) { left: 22%; animation-duration: 18s; animation-delay: -3s; opacity: .1; }
.tech-data-stream .ds-col:nth-child(3) { left: 78%; animation-duration: 16s; animation-delay: -6s; opacity: .12; }
.tech-data-stream .ds-col:nth-child(4) { left: 92%; animation-duration: 20s; animation-delay: -9s; opacity: .08; }
@keyframes ds-fall {
  to { top: 110%; }
}

/* Mobile — hide most decorative effects, keep only static ones */
@media (max-width: 768px) {
  .tech-rays,
  .tech-scanline,
  .tech-perspective,
  .tech-pulse-grid,
  .tech-data-stream { display: none; }
  .tech-circuit,
  .tech-blueprint,
  .tech-corner-marks,
  .tech-noise { opacity: .5; }
}

/* Reduce motion compliance */
@media (prefers-reduced-motion: reduce) {
  .tech-rays::before,
  .tech-rays::after,
  .tech-scanline::before,
  .tech-perspective::before,
  .tech-pulse-grid .pg-dot,
  .tech-data-stream .ds-col {
    animation: none !important;
  }
}

/* Make sure parent has positioning + z-index for content above */
.has-tech-fx {
  position: relative;
  overflow: hidden;
  isolation: isolate;
}
.has-tech-fx > *:not([class*="tech-"]) {
  position: relative;
  z-index: 1;
}
