/* eMondor — editorial-dev system, dark + light, cyan accent */

*{box-sizing:border-box;margin:0;padding:0}

:root{
  --accent: #5ef0f0;
  --accent-2: #3dd8d8;
  --accent-soft: rgba(94,240,240,0.12);
  --accent-line: rgba(94,240,240,0.22);

  /* dark (default) */
  --bg: #08080f;
  --bg2: #0d0d1a;
  --bg3: #14142a;
  --bg-elevated: #11112a;
  --border: #1a1a2e;
  --border-strong: #2a2a4a;
  --text: #e6e6f0;
  --text-mute: #9090b0;
  --muted: #55557a;
  --dim: #33334a;
  --grid: rgba(94,240,240,0.05);
  --noise-opacity: 0.04;
  --shadow: 0 18px 40px -20px rgba(0,0,0,0.6);

  --font-display: 'Syne', sans-serif;
  --font-mono: 'Space Mono', ui-monospace, monospace;

  --pad-x: clamp(1.25rem, 4vw, 3rem);
  --max-w: 1280px;
}

[data-theme="light"]{
  --accent: #0d8e8e;
  --accent-2: #0aa3a3;
  --accent-soft: rgba(13,142,142,0.10);
  --accent-line: rgba(13,142,142,0.22);
  --bg: #f5f3ee;
  --bg2: #ffffff;
  --bg3: #ebe8e0;
  --bg-elevated: #ffffff;
  --border: #d8d4ca;
  --border-strong: #b8b3a5;
  --text: #14141e;
  --text-mute: #5b5b74;
  --muted: #7c7a90;
  --dim: #aeaab6;
  --grid: rgba(13,142,142,0.07);
  --noise-opacity: 0.025;
  --shadow: 0 18px 40px -22px rgba(20,20,30,0.18);
}

html{scroll-behavior:smooth}
body{
  font-family:var(--font-display);
  background:var(--bg);
  color:var(--text);
  line-height:1.6;
  min-height:100vh;
  display:flex;
  flex-direction:column;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  transition:background .35s ease, color .35s ease;
}
a{color:inherit;text-decoration:none}
img,svg{display:block;max-width:100%}
button{font-family:inherit}
:focus{outline:none}
:focus-visible{outline:2px solid var(--accent);outline-offset:3px;border-radius:4px}

/* subtle page noise */
body::before{
  content:'';
  position:fixed;inset:0;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='200' height='200'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2' stitchTiles='stitch'/><feColorMatrix values='0 0 0 0 1  0 0 0 0 1  0 0 0 0 1  0 0 0 0.7 0'/></filter><rect width='200' height='200' filter='url(%23n)'/></svg>");
  opacity:var(--noise-opacity);
  pointer-events:none;
  z-index:1;
  mix-blend-mode:overlay;
}
[data-theme="light"] body::before{ mix-blend-mode:multiply; }

main, nav, footer{position:relative;z-index:2}

hr{border:none;border-top:1px solid var(--border)}

/* ─────────── NAV ─────────── */
nav{
  display:flex;align-items:center;justify-content:space-between;
  padding:1rem var(--pad-x);
  border-bottom:1px solid var(--border);
  position:sticky;top:0;
  background:color-mix(in srgb, var(--bg) 88%, transparent);
  backdrop-filter:blur(12px);
  -webkit-backdrop-filter:blur(12px);
  z-index:200;gap:1rem;
}
.logo{
  font-family:var(--font-mono);
  font-size:1.05rem;font-weight:700;letter-spacing:-0.5px;
  display:inline-flex;align-items:center;gap:2px;
  flex-shrink:0;
}
.logo .m{color:var(--accent)}
.logo .rest{color:var(--text-mute)}
.logo::after{
  content:'';width:6px;height:6px;background:var(--accent);
  border-radius:50%;margin-left:6px;
  box-shadow:0 0 8px var(--accent);
  animation:pulse 2.4s ease-in-out infinite;
}
.nav-links{display:flex;gap:1.5rem;font-size:0.72rem;letter-spacing:1.8px;text-transform:uppercase;color:var(--text-mute)}
.nav-links a{transition:color .2s;position:relative;padding:4px 0}
.nav-links a:hover,.nav-links a.active{color:var(--accent)}
.nav-links a.active::after{
  content:'';position:absolute;bottom:-3px;left:0;
  width:100%;height:1px;background:var(--accent);
}
.nav-actions{display:flex;align-items:center;gap:.5rem;flex-shrink:0}
.icon-btn{
  width:44px;height:44px;display:inline-flex;align-items:center;justify-content:center;
  border:1px solid var(--border-strong);background:transparent;color:var(--text);
  border-radius:6px;cursor:pointer;transition:all .2s;font-size:.95rem;
}
.icon-btn:hover{border-color:var(--accent);color:var(--accent)}
.lang-btn{
  font-family:var(--font-mono);font-size:.7rem;
  border:1px solid var(--border-strong);background:transparent;color:var(--accent);
  padding:5px 10px;border-radius:6px;cursor:pointer;transition:all .2s;letter-spacing:1px;
}
.lang-btn:hover{background:var(--accent);color:var(--bg);border-color:var(--accent)}
.burger{display:none;background:transparent;border:none;color:var(--text);font-size:1.4rem;cursor:pointer;padding:4px}

/* ─────────── COMMON BLOCKS ─────────── */
.eyebrow{
  font-family:var(--font-mono);font-size:.62rem;color:var(--accent);
  letter-spacing:3px;text-transform:uppercase;
  display:inline-flex;align-items:center;gap:10px;
}
.eyebrow::before{content:'';width:22px;height:1px;background:var(--accent)}

.page-header{
  padding:4.5rem var(--pad-x) 2.5rem;
  max-width:var(--max-w);margin:0 auto;width:100%;
  display:grid;grid-template-columns:1fr auto;gap:2rem;align-items:end;
}
.page-tag{
  font-family:var(--font-mono);font-size:.65rem;color:var(--accent);
  letter-spacing:3px;text-transform:uppercase;margin-bottom:.6rem;
  display:flex;align-items:center;gap:10px;
}
.page-tag::before{content:'';width:22px;height:1px;background:var(--accent)}
.page-title{
  font-size:clamp(2.4rem, 6vw, 4.4rem);
  font-weight:800;letter-spacing:-1px;line-height:1.25;
}
.page-title em{font-style:normal;color:var(--accent)}
.page-meta{
  font-family:var(--font-mono);font-size:.62rem;color:var(--muted);
  letter-spacing:1.5px;text-transform:uppercase;text-align:right;line-height:1.8;
}
.page-meta b{color:var(--text);font-weight:700}

.sec{padding:4rem var(--pad-x);max-width:var(--max-w);margin:0 auto;width:100%}
.sec-head{display:flex;justify-content:space-between;align-items:flex-end;gap:2rem;margin-bottom:2.5rem;flex-wrap:wrap}
.sec-label{font-family:var(--font-mono);font-size:.62rem;color:var(--accent);letter-spacing:3px;text-transform:uppercase;margin-bottom:.5rem}
.sec-title{font-size:clamp(1.6rem, 3vw, 2.2rem);font-weight:800;letter-spacing:-1.2px;line-height:1.05}
.sec-title em{font-style:normal;color:var(--accent)}
.sec-sub{font-size:.95rem;color:var(--text-mute);max-width:42ch;margin-top:.5rem}

/* ─────────── HERO ─────────── */
.hero{
  position:relative;overflow:hidden;
  padding:4.5rem var(--pad-x) 3rem;
  max-width:var(--max-w);margin:0 auto;width:100%;
}
.hero-grid{
  display:grid;grid-template-columns:1.15fr 1fr;gap:3rem;align-items:center;
}
.hero h1{
  font-size:clamp(3rem, 7vw, 6rem);
  font-weight:800;line-height:1;letter-spacing:-1px;
  margin:1.2rem 0 1.6rem;
}
.hero h1 .accent{color:var(--accent)}
.hero h1 .struck{
  position:relative;display:inline-block;color:var(--text-mute);
}
.hero h1 .struck::after{
  content:'';position:absolute;left:-2%;right:-2%;top:55%;height:4px;background:var(--accent);
  transform:scaleX(0);transform-origin:left;animation:strike 1.2s .6s ease forwards;
}
@keyframes strike{to{transform:scaleX(1)}}
.hero-sub{
  font-size:1.05rem;color:var(--text-mute);line-height:1.7;
  max-width:46ch;margin-bottom:2.2rem;
}
.btns{display:flex;gap:.8rem;flex-wrap:wrap}
.btn-p{
  background:var(--accent);color:#08080f;
  font-family:var(--font-mono);font-size:.72rem;font-weight:700;
  padding:14px 22px;border-radius:6px;border:none;cursor:pointer;
  letter-spacing:1.2px;text-transform:uppercase;
  display:inline-flex;align-items:center;gap:8px;
  transition:transform .2s, box-shadow .2s, background .2s;
  box-shadow:0 6px 24px -10px var(--accent);
}
.btn-p:hover{background:var(--accent-2);transform:translateY(-2px);box-shadow:0 12px 32px -10px var(--accent)}
.btn-s{
  background:transparent;color:var(--text);
  font-family:var(--font-mono);font-size:.72rem;font-weight:700;
  border:1px solid var(--border-strong);
  padding:14px 22px;border-radius:6px;cursor:pointer;
  letter-spacing:1.2px;text-transform:uppercase;
  display:inline-flex;align-items:center;gap:8px;
  transition:all .2s;
}
.btn-s:hover{border-color:var(--accent);color:var(--accent)}

.status{
  display:inline-flex;align-items:center;gap:10px;margin-top:2.4rem;
  font-family:var(--font-mono);font-size:.7rem;color:var(--accent);
  letter-spacing:1.5px;
  padding:8px 14px;border:1px solid var(--accent-line);border-radius:99px;
  background:var(--accent-soft);
}
.dot{
  width:7px;height:7px;background:var(--accent);border-radius:50%;
  animation:pulse 2s infinite;flex-shrink:0;
}
@keyframes pulse{
  0%,100%{opacity:1;box-shadow:0 0 0 0 var(--accent-line)}
  50%{opacity:.55;box-shadow:0 0 0 8px transparent}
}

/* hero animated grid bg */
.hero-bg{
  position:absolute;inset:0;pointer-events:none;z-index:0;
  background-image:
    linear-gradient(var(--grid) 1px, transparent 1px),
    linear-gradient(90deg, var(--grid) 1px, transparent 1px);
  background-size:48px 48px;
  mask-image:radial-gradient(ellipse 80% 60% at 30% 40%, #000 30%, transparent 80%);
  -webkit-mask-image:radial-gradient(ellipse 80% 60% at 30% 40%, #000 30%, transparent 80%);
}
.hero-blob{
  position:absolute;top:-15%;right:-10%;width:55%;height:90%;
  background:radial-gradient(circle, var(--accent-soft) 0%, transparent 60%);
  pointer-events:none;z-index:0;filter:blur(8px);
}
.hero > *:not(.hero-bg):not(.hero-blob){position:relative;z-index:1}

/* ─────── HERO TERMINAL MOCK ─────── */
.terminal{
  background:var(--bg2);border:1px solid var(--border);border-radius:10px;
  font-family:var(--font-mono);font-size:.78rem;
  overflow:hidden;box-shadow:var(--shadow);
}
.terminal-bar{
  display:flex;align-items:center;gap:8px;padding:10px 14px;
  background:var(--bg3);border-bottom:1px solid var(--border);
}
.terminal-bar .tname{
  margin-left:0;font-size:.7rem;color:var(--accent);letter-spacing:1px;font-family:var(--font-mono);
}
.terminal-body{padding:18px 18px 22px;line-height:1.8;color:var(--text-mute)}
.terminal-body .pmt{color:var(--accent);user-select:none}
.terminal-body .ok{color:#28c940}
.terminal-body .kw{color:#c792ff}
.terminal-body .str{color:#ffd479}
.terminal-body .com{color:var(--muted)}
[data-theme="light"] .terminal-body .ok{color:#1a7a2e}
[data-theme="light"] .terminal-body .kw{color:#6d28d9}
[data-theme="light"] .terminal-body .str{color:#b45309}
.terminal-body .cursor{
  display:inline-block;width:8px;height:14px;background:var(--accent);
  vertical-align:middle;animation:blink 1s steps(2) infinite;margin-left:2px;
}
@keyframes blink{50%{opacity:0}}

/* ─────── MARQUEE ─────── */
.marquee{
  border-top:1px solid var(--border);border-bottom:1px solid var(--border);
  overflow:hidden;background:var(--bg2);
  position:relative;
}
.marquee::before,.marquee::after{
  content:'';position:absolute;top:0;bottom:0;width:80px;z-index:2;pointer-events:none;
}
.marquee::before{left:0;background:linear-gradient(90deg, var(--bg2), transparent)}
.marquee::after{right:0;background:linear-gradient(-90deg, var(--bg2), transparent)}
.marquee-track{
  display:flex;gap:3.5rem;width:max-content;
  padding:1.4rem 0;
  animation:scroll 36s linear infinite;
  font-family:var(--font-mono);font-size:.78rem;letter-spacing:2px;text-transform:uppercase;
  color:var(--text-mute);
}
.marquee-track .mi{display:inline-flex;align-items:center;gap:10px;white-space:nowrap}
.marquee-track .mi i{color:var(--accent);font-size:1.1rem}
.marquee-track .sep{color:var(--accent);opacity:.6}
@keyframes scroll{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* ─────── STATS ─────── */
.stats{
  display:grid;grid-template-columns:repeat(4,1fr);
  border-top:1px solid var(--border);border-bottom:1px solid var(--border);
  background:var(--bg);
}
.stat{padding:2rem var(--pad-x);border-right:1px solid var(--border)}
.stat:last-child{border-right:none}
.stat-num{
  font-family:var(--font-mono);font-size:2rem;font-weight:700;
  letter-spacing:-1px;color:var(--text);line-height:1;margin-bottom:.4rem;
}
.stat-num em{font-style:normal;color:var(--accent)}
.stat-lab{
  font-family:var(--font-mono);font-size:.62rem;color:var(--muted);
  letter-spacing:2px;text-transform:uppercase;
}

/* ─────── PREVIEW GRID (home) ─────── */
.preview-grid-section{
  display:grid;grid-template-columns:repeat(4,1fr);
  gap:1px;background:var(--border);
}
.preview-card{
  background:var(--bg2);padding:2rem 1.5rem;
  display:flex;flex-direction:column;gap:.45rem;
  position:relative;overflow:hidden;
  transition:background .2s;
}
.preview-card::before{
  content:'';position:absolute;left:0;top:0;width:2px;height:0;
  background:var(--accent);transition:height .35s ease;
}
.preview-card:hover{background:var(--bg3)}
.preview-card:hover::before{height:100%}
.preview-num{
  font-family:var(--font-mono);font-size:.6rem;color:var(--muted);
  letter-spacing:2px;margin-bottom:.6rem;
}
.preview-ico{font-size:1.4rem;color:var(--accent);margin-bottom:.6rem}
.preview-title{font-size:1.1rem;font-weight:700;letter-spacing:-.5px}
.preview-desc{font-size:.78rem;color:var(--text-mute)}
.preview-arrow{
  position:absolute;top:1.4rem;right:1.4rem;font-size:1rem;color:var(--dim);
  transition:transform .25s, color .25s;
}
.preview-card:hover .preview-arrow{color:var(--accent);transform:translate(2px,-2px)}

/* ─────── FEATURED PROJECT ─────── */
.featured{
  display:grid;grid-template-columns:1fr 1fr;gap:1px;background:var(--border);
  border:1px solid var(--border);border-radius:12px;overflow:hidden;
}
.featured-vis{
  background:linear-gradient(135deg, var(--bg3), var(--bg2));
  min-height:340px;position:relative;overflow:hidden;
  display:flex;align-items:center;justify-content:center;
}
.featured-vis::before{
  content:'';position:absolute;inset:0;
  background-image:
    linear-gradient(var(--grid) 1px, transparent 1px),
    linear-gradient(90deg, var(--grid) 1px, transparent 1px);
  background-size:32px 32px;
  opacity:.7;
}
.featured-info{
  background:var(--bg2);padding:2.5rem;
  display:flex;flex-direction:column;justify-content:center;gap:1rem;
}
.featured-tag{
  font-family:var(--font-mono);font-size:.62rem;color:var(--accent);
  letter-spacing:2.5px;text-transform:uppercase;
}
.featured-name{font-size:2rem;font-weight:800;letter-spacing:-1.5px;line-height:1.05}
.featured-desc{color:var(--text-mute);font-size:.95rem;line-height:1.7}
.featured-meta{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:.5rem}
.chip{
  font-family:var(--font-mono);font-size:.6rem;letter-spacing:1.5px;text-transform:uppercase;
  padding:5px 10px;border:1px solid var(--border-strong);border-radius:99px;color:var(--text-mute);
}
.chip.active{background:var(--accent-soft);color:var(--accent);border-color:var(--accent-line)}

/* ─────── SERVICES ─────── */
.services-grid{
  display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));
  gap:1px;background:var(--border);border:1px solid var(--border);border-radius:8px;overflow:hidden;
}
.svc{
  background:var(--bg2);padding:2.2rem 1.6rem;position:relative;
  transition:background .2s;display:flex;flex-direction:column;gap:.6rem;min-height:200px;
}
.svc:hover{background:var(--bg3)}
.svc::before{
  content:attr(data-num);position:absolute;top:1.2rem;right:1.4rem;
  font-family:var(--font-mono);font-size:.6rem;color:var(--muted);letter-spacing:2px;
}
.svc-ico{
  width:46px;height:46px;border-radius:10px;
  background:var(--accent-soft);color:var(--accent);
  display:inline-flex;align-items:center;justify-content:center;
  font-size:1.35rem;margin-bottom:.5rem;
}
.svc-title{font-size:1.05rem;font-weight:700;letter-spacing:-.4px}
.svc-desc{font-size:.85rem;color:var(--text-mute);line-height:1.7;flex:1}
.svc-stack{
  margin-top:.6rem;display:flex;flex-wrap:wrap;gap:.4rem;
}

/* ─────── PORTFOLIO ─────── */
.port-grid{
  display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1.2rem;
}
.port-card{
  background:var(--bg2);border:1px solid var(--border);border-radius:10px;
  overflow:hidden;transition:border-color .2s, transform .25s;
  display:flex;flex-direction:column;
}
.port-card:hover{border-color:var(--accent-line);transform:translateY(-3px)}
.port-thumb{
  height:180px;position:relative;overflow:hidden;
  display:flex;align-items:center;justify-content:center;
  background:linear-gradient(135deg, var(--bg3), var(--bg2));
}
.port-thumb svg{width:80%;height:auto}
.port-info{padding:1.1rem 1.3rem 1.3rem;display:flex;flex-direction:column;gap:.5rem}
.port-name{font-size:1rem;font-weight:700;letter-spacing:-.4px}
.port-desc{font-size:.78rem;color:var(--text-mute);line-height:1.6}
.port-tags{display:flex;flex-wrap:wrap;gap:.4rem;margin-top:.2rem}
.port-tag{
  font-family:var(--font-mono);font-size:.58rem;background:var(--border);
  color:var(--accent);padding:3px 8px;border-radius:3px;letter-spacing:1.2px;text-transform:uppercase;
}

/* ─────── APPS ─────── */
.apps-grid{
  display:grid;grid-template-columns:repeat(auto-fit,minmax(360px,1fr));gap:1.5rem;
}
.app-card{
  background:var(--bg2);border:1px solid var(--border);border-radius:14px;
  padding:1.8rem;display:flex;gap:1.4rem;align-items:flex-start;
  transition:border-color .2s, transform .25s;position:relative;overflow:hidden;
}
.app-card:hover{border-color:var(--accent-line);transform:translateY(-3px)}
.app-card.featured-app{
  grid-column:1/-1;display:grid;grid-template-columns:1fr 1.3fr;gap:0;padding:0;
}
.app-card.featured-app .app-side{padding:2.4rem 2.2rem;display:flex;flex-direction:column;justify-content:center;gap:1rem}
.app-card.featured-app .app-vis{
  position:relative;background:linear-gradient(135deg,#0a1426,#0f2440);
  min-height:380px;border-left:1px solid var(--border);overflow:hidden;
}
[data-theme="light"] .app-card.featured-app .app-vis{ background:linear-gradient(135deg,#dde6ee,#c4d4e6) }
.app-ico{
  width:56px;height:56px;background:var(--accent);border-radius:14px;
  display:flex;align-items:center;justify-content:center;
  font-size:1.6rem;color:#08080f;flex-shrink:0;
  box-shadow:0 8px 24px -8px var(--accent);
}
.app-ico.dark{background:var(--bg3);color:var(--accent);box-shadow:none;border:1px solid var(--border-strong)}
.app-name{font-size:1.2rem;font-weight:800;letter-spacing:-.6px;margin-bottom:.35rem}
.app-desc{font-size:.86rem;color:var(--text-mute);line-height:1.65;margin-bottom:.9rem}
.app-link{
  font-family:var(--font-mono);font-size:.64rem;color:var(--accent);letter-spacing:1.5px;
  display:inline-flex;align-items:center;gap:8px;text-transform:uppercase;
  padding:8px 12px;border:1px solid var(--accent-line);border-radius:6px;
  transition:all .2s;
}
.app-link:hover{background:var(--accent);color:#08080f}
.app-meta{
  display:flex;gap:1.4rem;margin-top:.8rem;flex-wrap:wrap;
  font-family:var(--font-mono);font-size:.62rem;color:var(--muted);letter-spacing:1.5px;text-transform:uppercase;
}
.app-meta b{color:var(--text);font-weight:700}

/* ─────── PRICING ─────── */
.price-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:1.4rem}
.price-card{
  background:var(--bg2);border:1px solid var(--border);border-radius:12px;
  padding:2rem 1.6rem;position:relative;transition:border-color .2s,transform .25s;
  display:flex;flex-direction:column;
}
.price-card:hover{border-color:var(--border-strong);transform:translateY(-3px)}
.price-card.featured{
  border-color:var(--accent);
  box-shadow:0 24px 60px -28px var(--accent);
  background:linear-gradient(180deg, var(--accent-soft) 0%, var(--bg2) 30%);
}
.price-badge{
  position:absolute;top:-11px;left:50%;transform:translateX(-50%);
  background:var(--accent);color:#08080f;
  font-family:var(--font-mono);font-size:.6rem;font-weight:700;
  padding:5px 14px;border-radius:99px;letter-spacing:1.5px;white-space:nowrap;
}
.price-name{
  font-size:.7rem;font-family:var(--font-mono);letter-spacing:2.5px;
  color:var(--accent);text-transform:uppercase;margin-bottom:.6rem;
}
.price-val{font-size:1.9rem;font-weight:800;letter-spacing:-1.2px;margin-bottom:.3rem;line-height:1}
.price-val small{font-size:.7rem;font-weight:400;color:var(--muted);font-family:var(--font-mono);letter-spacing:1px;margin-left:.4rem}
.price-sub{font-size:.78rem;color:var(--text-mute);margin-bottom:1.4rem}
.price-feats{list-style:none;margin-bottom:1.5rem;flex:1}
.price-feats li{
  font-size:.82rem;color:var(--text-mute);padding:8px 0;
  border-bottom:1px dashed var(--border);display:flex;align-items:center;gap:10px;
}
.price-feats li:last-child{border-bottom:none}
.price-feats li i{color:var(--accent);font-size:14px;flex-shrink:0}
.price-btn{
  width:100%;background:transparent;border:1px solid var(--border-strong);
  color:var(--text);font-family:var(--font-mono);font-size:.68rem;
  padding:12px;border-radius:6px;cursor:pointer;letter-spacing:1.2px;
  text-transform:uppercase;transition:all .2s;margin-top:auto;
  display:inline-flex;align-items:center;justify-content:center;gap:8px;
}
.price-btn:hover{border-color:var(--accent);color:var(--accent)}
.price-card.featured .price-btn{background:var(--accent);color:#08080f;border-color:var(--accent)}
.price-card.featured .price-btn:hover{background:var(--accent-2);border-color:var(--accent-2)}

/* ─────── FAQ ─────── */
.faq{display:flex;flex-direction:column;gap:.6rem;max-width:780px;margin:0 auto}
.faq details{
  background:var(--bg2);border:1px solid var(--border);border-radius:10px;
  padding:1.1rem 1.3rem;transition:border-color .2s;
}
.faq details[open]{border-color:var(--accent-line)}
.faq summary{
  cursor:pointer;list-style:none;display:flex;align-items:center;justify-content:space-between;gap:1rem;
  font-size:.95rem;font-weight:700;letter-spacing:-.3px;
}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{
  content:'+';font-family:var(--font-mono);color:var(--accent);
  font-size:1.4rem;transition:transform .25s;line-height:1;
}
.faq details[open] summary::after{transform:rotate(45deg)}
.faq-a{margin-top:.8rem;font-size:.88rem;color:var(--text-mute);line-height:1.7}

/* ─────── TECH STACK ─────── */
.stack{
  display:flex;flex-wrap:wrap;gap:.6rem;
}
.stack .chip{
  padding:8px 14px;font-size:.7rem;
  background:var(--bg2);border:1px solid var(--border);
  display:inline-flex;align-items:center;gap:8px;
  transition:all .2s;cursor:default;
}
.stack .chip i{color:var(--accent);font-size:1rem}
.stack .chip:hover{border-color:var(--accent-line);background:var(--bg3)}

/* ─────── TESTIMONIALS ─────── */
.testi-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1.2rem}
.testi{
  background:var(--bg2);border:1px solid var(--border);border-radius:12px;
  padding:1.8rem 1.6rem;display:flex;flex-direction:column;gap:1.1rem;position:relative;
}
.testi::before{
  content:'\201C';position:absolute;top:.4rem;right:1rem;
  font-family:Georgia,serif;font-size:3.5rem;color:var(--accent);opacity:.25;line-height:1;
}
.testi-quote{font-size:.95rem;color:var(--text);line-height:1.65;font-weight:500}
.testi-meta{display:flex;align-items:center;gap:.8rem;margin-top:auto}
.testi-avatar{
  width:38px;height:38px;border-radius:50%;flex-shrink:0;
  background:linear-gradient(135deg,var(--accent),var(--bg3));
  display:flex;align-items:center;justify-content:center;
  font-family:var(--font-mono);font-weight:700;color:var(--bg);font-size:.8rem;
}
.testi-name{font-size:.85rem;font-weight:700;letter-spacing:-.2px}
.testi-role{font-family:var(--font-mono);font-size:.6rem;color:var(--muted);letter-spacing:1.5px;text-transform:uppercase}

/* ─────── PROCESS ─────── */
.process{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--border);border:1px solid var(--border);border-radius:10px;overflow:hidden}
.proc{background:var(--bg2);padding:1.8rem 1.4rem;position:relative;display:flex;flex-direction:column;gap:.6rem}
.proc-num{
  font-family:var(--font-mono);font-size:.65rem;color:var(--accent);
  letter-spacing:2.5px;
}
.proc-title{font-size:1rem;font-weight:700;letter-spacing:-.4px}
.proc-desc{font-size:.8rem;color:var(--text-mute);line-height:1.65}

/* ─────── CONTACT ─────── */
.contact-wrap{display:grid;grid-template-columns:1fr 1.4fr;gap:3rem;align-items:start}
.contact-info{display:flex;flex-direction:column;gap:1.5rem}
.contact-block{
  background:var(--bg2);border:1px solid var(--border);border-radius:12px;padding:1.6rem;
  display:flex;flex-direction:column;gap:1rem;
}
.contact-item{display:flex;align-items:center;gap:14px;font-size:.88rem;color:var(--text-mute)}
.contact-item i{font-size:1.05rem;color:var(--accent);width:20px;flex-shrink:0}
.contact-item b{color:var(--text);font-weight:600}
.form{display:flex;flex-direction:column;gap:.9rem}
.label{
  font-family:var(--font-mono);font-size:.6rem;color:var(--muted);
  letter-spacing:1.8px;text-transform:uppercase;margin-bottom:.4rem;display:block;
}
.inp{
  background:var(--bg2);border:1px solid var(--border);border-radius:8px;
  padding:12px 14px;color:var(--text);font-family:inherit;font-size:.92rem;
  outline:none;transition:border-color .2s, box-shadow .2s;width:100%;
}
.inp:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}
.inp::placeholder{color:var(--dim)}
textarea.inp{resize:vertical;min-height:140px;font-family:inherit}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:.9rem}
.submit{
  background:var(--accent);color:#08080f;
  font-family:var(--font-mono);font-size:.74rem;font-weight:700;
  padding:14px;border-radius:8px;border:none;cursor:pointer;
  letter-spacing:1.5px;text-transform:uppercase;transition:all .2s;width:100%;
  display:inline-flex;align-items:center;justify-content:center;gap:8px;
}
.submit:hover{background:var(--accent-2);transform:translateY(-1px)}
.submit:disabled{opacity:.6;cursor:default;transform:none}
.chip:has(input[type="radio"]:checked){background:var(--accent-soft);color:var(--accent);border-color:var(--accent-line)}
.form-status{font-family:var(--font-mono);font-size:.72rem;letter-spacing:1px;margin-top:.5rem;min-height:1.2em}
.form-status.ok{color:var(--accent)}
.form-status.err{color:#ff6b6b}

/* ─────── CTA BANNER ─────── */
.cta-banner{
  margin:0 auto;padding:3.5rem var(--pad-x);max-width:var(--max-w);width:100%;
  display:flex;justify-content:space-between;align-items:center;gap:2rem;flex-wrap:wrap;
  border-top:1px solid var(--border);border-bottom:1px solid var(--border);
  background:
    radial-gradient(circle at 20% 50%, var(--accent-soft) 0%, transparent 60%),
    var(--bg2);
}
.cta-banner h3{font-size:clamp(1.4rem,3vw,2rem);font-weight:800;letter-spacing:-1px;line-height:1.1}
.cta-banner h3 em{font-style:normal;color:var(--accent)}

/* ─────── FOOTER ─────── */
footer{
  border-top:1px solid var(--border);
  padding:2.5rem var(--pad-x) 1.5rem;
  margin-top:auto;background:var(--bg2);
}
.footer-grid{
  display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:2.5rem;
  max-width:var(--max-w);margin:0 auto;padding-bottom:2rem;border-bottom:1px solid var(--border);
}
.footer-brand .footer-logo{
  font-family:var(--font-mono);font-size:1.2rem;font-weight:700;letter-spacing:-.5px;
  color:var(--text);margin-bottom:.7rem;
}
.footer-brand .footer-logo span{color:var(--accent)}
.footer-brand p{font-size:.84rem;color:var(--text-mute);max-width:36ch;line-height:1.6}
.footer-col h4{
  font-family:var(--font-mono);font-size:.62rem;color:var(--accent);
  letter-spacing:2.5px;text-transform:uppercase;margin-bottom:1rem;
}
.footer-col ul{list-style:none;display:flex;flex-direction:column;gap:.55rem}
.footer-col a{font-size:.84rem;color:var(--text-mute);transition:color .2s}
.footer-col a:hover{color:var(--accent)}
.footer-bottom{
  display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:1rem;
  max-width:var(--max-w);margin:0 auto;padding-top:1.2rem;
}
.footer-copy{font-family:var(--font-mono);font-size:.62rem;color:var(--muted);letter-spacing:1.5px}
.social{display:flex;gap:.6rem}
.social a{
  width:34px;height:34px;border-radius:8px;
  display:inline-flex;align-items:center;justify-content:center;
  border:1px solid var(--border);color:var(--text-mute);font-size:1rem;transition:all .2s;
}
.social a:hover{border-color:var(--accent);color:var(--accent);transform:translateY(-2px)}

/* ─────── REVEAL ANIM ─────── */
.reveal{opacity:0;transform:translateY(16px);transition:opacity .7s ease, transform .7s ease}
.reveal.in{opacity:1;transform:none}

/* ─────── MOBILE ─────── */
@media(max-width:980px){
  .hero-grid{grid-template-columns:1fr;gap:2.5rem}
  .featured{grid-template-columns:1fr}
  .stats{grid-template-columns:repeat(2,1fr)}
  .stat:nth-child(2){border-right:none}
  .stat:nth-child(1),.stat:nth-child(2){border-bottom:1px solid var(--border)}
  .preview-grid-section{grid-template-columns:1fr 1fr}
  .process{grid-template-columns:1fr 1fr}
  .contact-wrap{grid-template-columns:1fr;gap:2rem}
  .footer-grid{grid-template-columns:1fr 1fr;gap:2rem}
  .app-card.featured-app{grid-template-columns:1fr}
  .app-card.featured-app .app-vis{border-left:none;border-top:1px solid var(--border);min-height:280px}
  .page-header{grid-template-columns:1fr}
  .page-meta{text-align:left}
}
@media(max-width:640px){
  .nav-links{
    display:none;position:absolute;top:100%;left:0;right:0;
    background:var(--bg);border-bottom:1px solid var(--border);
    flex-direction:column;padding:1rem var(--pad-x);gap:1.2rem;
  }
  .nav-links.open{display:flex}
  .burger{display:block}
  .preview-grid-section{grid-template-columns:1fr}
  .stats{grid-template-columns:1fr 1fr}
  .process{grid-template-columns:1fr}
  .form-row{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr;gap:1.6rem}
  .price-card.featured{margin-top:.6rem}
  .btns{flex-direction:column;align-items:stretch}
  .btn-p,.btn-s{justify-content:center}
}

/* ─────── TWEAKS PANEL stub ─────── */
.tweaks{
  position:fixed;bottom:1.2rem;right:1.2rem;z-index:300;
  background:var(--bg2);border:1px solid var(--border-strong);border-radius:12px;
  padding:1rem;display:none;flex-direction:column;gap:.8rem;
  width:240px;box-shadow:var(--shadow);font-size:.78rem;
}
.tweaks.open{display:flex}
.tweaks h5{
  font-family:var(--font-mono);font-size:.62rem;color:var(--accent);
  letter-spacing:2.5px;text-transform:uppercase;
}
.tweaks-row{display:flex;justify-content:space-between;align-items:center;gap:.6rem}
.tweaks-row label{font-family:var(--font-mono);font-size:.65rem;color:var(--text-mute);letter-spacing:1.2px;text-transform:uppercase}
.swatches{display:flex;gap:.4rem}
.sw{
  width:22px;height:22px;border-radius:50%;border:2px solid transparent;
  cursor:pointer;transition:transform .15s;
}
.sw:hover{transform:scale(1.1)}
.sw.active{border-color:var(--text)}
