/* ═══════════════════════════════════════════════
   L0K1CAM — CYBERPUNK CSS v3.1
   Fixed layout + auth modal
   ═══════════════════════════════════════════════ */

:root {
    --bg: #05070f;
    --bg2: #0a0e1a;
    --surface: #0d1224;
    --surface2: #121a33;
    --cyan: #00f0ff;
    --cyan-dim: #00838f;
    --cyan-glow: rgba(0,240,255,0.15);
    --magenta: #ff006e;
    --yellow: #ffd600;
    --text: #e0e6f0;
    --text-dim: #6b7b99;
    --border: rgba(0,240,255,0.12);
    --radius: 8px;
    --font: 'Inter', -apple-system, sans-serif;
    --mono: 'JetBrains Mono', monospace;
    --display: 'Orbitron', sans-serif;
}

* { margin:0; padding:0; box-sizing:border-box; }
html { scroll-behavior:smooth; }
body {
    font-family:var(--font); background:var(--bg);
    color:var(--text); overflow-x:hidden; line-height:1.6;
}
#bgCanvas { position:fixed; top:0; left:0; width:100%; height:100%; z-index:0; pointer-events:none; opacity:0.35; }
.cyan { color:var(--cyan); }

/* ─── NAV ─── */
.nav {
    position:fixed; top:0; left:0; right:0; z-index:100;
    background:rgba(5,7,15,0.85); backdrop-filter:blur(20px);
    border-bottom:1px solid var(--border);
}
.nav-inner {
    max-width:1200px; margin:0 auto; padding:0 24px;
    display:flex; align-items:center; justify-content:space-between; height:64px;
}
.logo { display:flex; align-items:center; gap:10px; text-decoration:none; }
.logo-icon {
    width:36px; height:36px; border-radius:50%; border:2px solid var(--cyan);
    display:flex; align-items:center; justify-content:center;
    font-family:var(--display); font-size:10px; color:var(--cyan); position:relative;
}
.logo-ring {
    position:absolute; inset:-4px; border-radius:50%;
    border:1px solid rgba(0,240,255,0.2); animation:spin 8s linear infinite;
}
@keyframes spin { to { transform:rotate(360deg); } }
.logo-text { font-family:var(--display); font-size:18px; font-weight:700; color:#fff; letter-spacing:2px; }
.nav-links { display:flex; gap:28px; }
.nav-link {
    color:var(--text-dim); text-decoration:none; font-size:13px;
    font-weight:500; letter-spacing:1px; text-transform:uppercase; transition:color .3s;
}
.nav-link:hover { color:var(--cyan); }
.nav-actions { display:flex; align-items:center; gap:10px; }
.lang-toggle {
    background:rgba(0,240,255,0.08); border:1px solid var(--cyan-dim); border-radius:6px;
    padding:6px 12px; cursor:pointer; font-size:13px; transition:all .3s;
    display:flex; align-items:center; gap:6px; color:var(--cyan);
    font-family:var(--mono); font-weight:600; letter-spacing:1px;
}
.lang-toggle:hover { border-color:var(--cyan); background:rgba(0,240,255,0.15); }
.lang-globe { font-size:16px; }
.btn-nav {
    background:transparent; border:1px solid var(--cyan); color:var(--cyan);
    padding:7px 16px; border-radius:6px; font-family:var(--mono);
    font-size:12px; font-weight:600; letter-spacing:1px; cursor:pointer;
    transition:all .3s;
}
.btn-nav:hover { background:var(--cyan); color:#000; }

/* ─── HERO ─── */
.hero {
    min-height:100vh; display:flex; align-items:center;
    padding:100px 24px 60px; position:relative; overflow:hidden;
}
.hero-grid-overlay {
    position:absolute; inset:0;
    background-image:
        linear-gradient(rgba(0,240,255,0.03) 1px, transparent 1px),
        linear-gradient(90deg, rgba(0,240,255,0.03) 1px, transparent 1px);
    background-size:60px 60px;
    mask-image:radial-gradient(ellipse 70% 60% at 50% 50%, black 30%, transparent 70%);
}
.hero-wrapper {
    max-width:1200px; margin:0 auto; width:100%;
    display:flex; align-items:center; justify-content:space-between; gap:60px;
    position:relative; z-index:1;
}
.hero-content { max-width:520px; flex-shrink:0; }
.glitch-badge {
    display:inline-flex; align-items:center; gap:8px;
    background:var(--cyan-glow); border:1px solid rgba(0,240,255,0.3);
    padding:6px 16px; border-radius:20px; font-size:11px;
    font-weight:600; letter-spacing:2px; color:var(--cyan);
    margin-bottom:24px; font-family:var(--mono);
}
.badge-pulse {
    width:6px; height:6px; background:var(--cyan); border-radius:50%;
    animation:pulse 2s ease infinite;
}
@keyframes pulse { 0%,100%{ opacity:1; transform:scale(1); } 50%{ opacity:.4; transform:scale(1.5); } }
.hero-title { font-family:var(--display); font-weight:900; line-height:1.1; margin-bottom:20px; }
.hero-title .line1 { font-size:clamp(24px,4vw,44px); color:var(--text); display:block; }
.hero-title .line2 {
    font-size:clamp(36px,7vw,68px); display:block;
    background:linear-gradient(135deg, var(--cyan), var(--magenta));
    -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text;
}
.glitch { position:relative; }
.glitch::before, .glitch::after {
    content:attr(data-text); position:absolute; left:0; top:0; width:100%;
    background:linear-gradient(135deg, var(--cyan), var(--magenta));
    -webkit-background-clip:text; -webkit-text-fill-color:transparent;
}
.glitch::before { animation:g1 3s infinite; clip-path:inset(0 0 65% 0); }
.glitch::after { animation:g2 3s infinite; clip-path:inset(65% 0 0 0); }
@keyframes g1 { 0%,95%,100%{ transform:translate(0); } 96%{ transform:translate(-3px,-1px); } 97%{ transform:translate(3px,1px); } }
@keyframes g2 { 0%,95%,100%{ transform:translate(0); } 96%{ transform:translate(3px,1px); } 97%{ transform:translate(-3px,-1px); } }
.hero-desc { color:var(--text-dim); font-size:15px; line-height:1.7; margin-bottom:32px; }
.hero-buttons { display:flex; gap:14px; flex-wrap:wrap; }

/* PHONE */
.hero-phone { flex-shrink:0; }
.showcase-phone {
    width:220px; height:440px; background:var(--surface);
    border-radius:28px; border:2px solid var(--border); position:relative; overflow:hidden;
    box-shadow:0 0 80px rgba(0,240,255,0.06), inset 0 0 40px rgba(0,0,0,.5);
}
.phone-notch { width:72px; height:22px; background:var(--bg); border-radius:0 0 14px 14px; margin:0 auto; position:relative; z-index:2; }
.phone-screen { position:absolute; inset:6px; border-radius:22px; overflow:hidden; background:#000; }
.screen-scan {
    position:absolute; top:-100%; left:0; right:0; height:50%;
    background:linear-gradient(transparent, rgba(0,240,255,0.04), transparent);
    animation:scan 4s linear infinite;
}
@keyframes scan { 0%{ top:-50%; } 100%{ top:150%; } }
.cam-hud { position:absolute; inset:0; padding:14px; display:flex; flex-direction:column; justify-content:space-between; }
.hud-top,.hud-bottom { display:flex; justify-content:space-between; font-family:var(--mono); font-size:9px; }
.hud-rec { color:var(--magenta); animation:blink 1s step-end infinite; }
@keyframes blink { 50%{ opacity:0; } }
.hud-time { color:var(--text-dim); }
.hud-center { flex:1; display:flex; align-items:center; justify-content:center; }
.crosshair { width:36px; height:36px; position:relative; border:1px solid rgba(0,240,255,.3); }
.crosshair::before,.crosshair::after { content:''; position:absolute; background:var(--cyan); }
.crosshair::before { width:1px; height:100%; left:50%; transform:translateX(-50%); }
.crosshair::after { width:100%; height:1px; top:50%; transform:translateY(-50%); }
.hud-fps { color:var(--cyan); }
.hud-status { color:#0f0; }

/* ─── BUTTONS ─── */
.btn-cyber {
    position:relative; display:inline-flex; align-items:center; justify-content:center;
    padding:14px 32px; font-family:var(--display); font-size:13px;
    font-weight:700; letter-spacing:2px; color:#000; background:var(--cyan);
    border:none; cursor:pointer;
    clip-path:polygon(0 0, calc(100% - 12px) 0, 100% 12px, 100% 100%, 12px 100%, 0 calc(100% - 12px));
    transition:all .3s; text-decoration:none;
    box-shadow:0 0 20px rgba(0,240,255,.3);
}
.btn-cyber:hover { box-shadow:0 0 40px rgba(0,240,255,.5); transform:translateY(-2px); }
.btn-cyber-sm {
    display:inline-flex; align-items:center; justify-content:center;
    padding:12px 24px; font-family:var(--display); font-size:11px;
    font-weight:700; letter-spacing:2px; color:var(--cyan);
    background:transparent; border:1px solid var(--cyan); cursor:pointer;
    clip-path:polygon(0 0, calc(100% - 10px) 0, 100% 10px, 100% 100%, 10px 100%, 0 calc(100% - 10px));
    transition:all .3s; width:100%;
}
.btn-cyber-sm:hover { background:var(--cyan); color:#000; }
.btn-outline-cyber {
    display:inline-flex; align-items:center; justify-content:center;
    padding:14px 32px; font-family:var(--display); font-size:13px;
    font-weight:700; letter-spacing:2px; color:var(--cyan);
    background:transparent; border:1px solid var(--cyan-dim); text-decoration:none; transition:all .3s;
}
.btn-outline-cyber:hover { border-color:var(--cyan); background:var(--cyan-glow); }
.btn-full { width:100%; }

/* ─── SECTIONS ─── */
.section-inner { max-width:1100px; margin:0 auto; padding:100px 24px; position:relative; z-index:1; }
.section-label { display:flex; align-items:center; gap:16px; justify-content:center; margin-bottom:12px; }
.label-line { width:40px; height:1px; background:var(--cyan-dim); }
.section-label span { font-family:var(--mono); font-size:12px; letter-spacing:3px; color:var(--cyan); font-weight:600; }
.section-title { font-family:var(--display); font-size:clamp(22px,4vw,36px); font-weight:800; text-align:center; margin-bottom:48px; }

/* ─── APP SHOWCASE ─── */
.app-showcase {
    display:flex; align-items:center; gap:48px; margin-bottom:20px;
    background:var(--surface); border:1px solid var(--border); border-radius:16px;
    padding:40px; position:relative; overflow:hidden;
}
.app-showcase::before {
    content:''; position:absolute; top:0; left:0; right:0; height:2px;
    background:linear-gradient(90deg, transparent, var(--cyan), transparent);
}
.app-showcase-info { flex:1; }
.app-header { display:flex; align-items:center; gap:16px; margin-bottom:20px; }
.app-icon { width:64px; height:64px; border-radius:14px; border:2px solid var(--cyan-dim); box-shadow:0 0 20px rgba(0,240,255,0.15); }
.app-name { font-family:var(--display); font-size:26px; font-weight:800; letter-spacing:2px; }
.app-tagline { font-family:var(--mono); font-size:12px; color:var(--cyan); letter-spacing:1px; margin-top:2px; }
.app-desc { color:var(--text-dim); font-size:14px; line-height:1.7; margin-bottom:20px; }
.app-badges { display:flex; flex-wrap:wrap; gap:8px; margin-bottom:24px; }
.app-badge {
    padding:5px 12px; border:1px solid var(--cyan-dim); border-radius:20px;
    font-family:var(--mono); font-size:11px; color:var(--cyan); letter-spacing:1px;
    background:rgba(0,240,255,0.05);
}
.app-showcase-preview { flex-shrink:0; }
.app-preview-img {
    max-height:420px; border-radius:12px;
    box-shadow:0 20px 60px rgba(0,0,0,.5), 0 0 40px rgba(0,240,255,0.08);
}
@media (max-width:768px) {
    .app-showcase { flex-direction:column; padding:24px; }
    .app-preview-img { max-height:300px; max-width:100%; }
}

/* ─── PRODUCT ─── */
.product-grid { display:grid; grid-template-columns:repeat(4, 1fr); gap:20px; }
.product-card {
    background:var(--surface); border:1px solid var(--border);
    border-radius:var(--radius); padding:28px 20px; position:relative;
    overflow:hidden; transition:all .4s;
}
.product-card:hover { border-color:var(--cyan); transform:translateY(-4px); }
.product-card:hover .card-glow { opacity:1; }
.card-glow {
    position:absolute; top:-50%; left:-50%; width:200%; height:200%;
    background:radial-gradient(circle, var(--cyan-glow) 0%, transparent 70%);
    opacity:0; transition:opacity .4s;
}
.card-icon { font-size:28px; margin-bottom:14px; position:relative; }
.product-card h3 { font-family:var(--display); font-size:13px; font-weight:700; margin-bottom:8px; letter-spacing:.5px; position:relative; }
.product-card p { color:var(--text-dim); font-size:13px; line-height:1.6; position:relative; }

/* ─── PRICING ─── */
.pricing-section { background:var(--bg2); }
.pricing-grid { display:grid; grid-template-columns:repeat(4, 1fr); gap:20px; align-items:start; }
.price-card {
    background:var(--surface); border:1px solid var(--border);
    border-radius:var(--radius); padding:28px 20px; text-align:center;
    position:relative; transition:all .4s;
}
.price-card:hover { border-color:var(--cyan-dim); transform:translateY(-4px); }
.price-card.featured {
    border-color:var(--cyan);
    background:linear-gradient(180deg, rgba(0,240,255,0.06), var(--surface));
    box-shadow:0 0 40px rgba(0,240,255,.1);
}
.featured-badge {
    position:absolute; top:-12px; left:50%; transform:translateX(-50%);
    background:var(--cyan); color:#000; padding:4px 14px; border-radius:12px;
    font-family:var(--display); font-size:9px; font-weight:700; letter-spacing:1px; white-space:nowrap;
}
.price-tier { font-family:var(--display); font-size:12px; letter-spacing:3px; color:var(--text-dim); margin-bottom:12px; }
.price-num { font-family:var(--display); font-size:42px; font-weight:900; color:#fff; }
.price-unit { font-family:var(--mono); font-size:14px; color:var(--text-dim); margin-left:4px; }
.price-period { font-size:13px; color:var(--text-dim); margin-bottom:6px; }
.price-save {
    display:inline-block; background:rgba(0,240,255,.1); color:var(--cyan);
    padding:2px 10px; border-radius:10px; font-size:11px; font-weight:600;
    margin-bottom:16px; font-family:var(--mono);
}
.price-list { list-style:none; text-align:left; margin:16px 0; }
.price-list li { padding:6px 0; font-size:13px; color:var(--text-dim); border-bottom:1px solid rgba(255,255,255,.03); }
.price-list li:last-child { border:none; }

/* ─── ACTIVATE ─── */
.activate-section { background:var(--bg); }
.activate-box { max-width:520px; margin:0 auto; }
.activate-terminal {
    background:var(--surface); border:1px solid var(--border);
    border-radius:var(--radius); overflow:hidden; box-shadow:0 20px 60px rgba(0,0,0,.4);
}
.term-header {
    display:flex; align-items:center; gap:12px; padding:12px 16px;
    background:var(--bg2); border-bottom:1px solid var(--border);
}
.term-dots { display:flex; gap:6px; }
.term-dots span { width:10px; height:10px; border-radius:50%; }
.term-dots span:nth-child(1) { background:#ff5f57; }
.term-dots span:nth-child(2) { background:#febc2e; }
.term-dots span:nth-child(3) { background:#28c840; }
.term-title { font-family:var(--mono); font-size:11px; color:var(--text-dim); letter-spacing:1px; }
.term-body { padding:24px; }
.term-line { font-family:var(--mono); font-size:13px; color:var(--text-dim); margin-bottom:18px; }
.term-prompt { color:var(--cyan); }
.activate-form { display:flex; flex-direction:column; gap:14px; }
.input-group { display:flex; flex-direction:column; gap:5px; }
.input-group label { font-family:var(--mono); font-size:11px; letter-spacing:2px; color:var(--cyan); font-weight:600; }
.optional { color:var(--text-dim); font-size:10px; letter-spacing:0; }
.cyber-input {
    padding:11px 14px; background:var(--bg); border:1px solid var(--border);
    border-radius:var(--radius); color:#fff; font-family:var(--mono);
    font-size:13px; outline:none; transition:border-color .3s;
}
.cyber-input:focus { border-color:var(--cyan); box-shadow:0 0 10px var(--cyan-glow); }
.cyber-input::placeholder { color:rgba(107,123,153,.6); }
.term-result { margin-top:14px; font-family:var(--mono); font-size:13px; min-height:18px; }
.term-result.success { color:#28c840; }
.term-result.error { color:var(--magenta); }

/* ─── AUTH MODAL ─── */
.auth-modal { max-width:400px; }
.auth-tabs {
    display:flex; gap:0; margin-bottom:24px; border-bottom:1px solid var(--border);
}
.auth-tab {
    flex:1; padding:12px; background:none; border:none; color:var(--text-dim);
    font-family:var(--display); font-size:12px; letter-spacing:2px;
    cursor:pointer; position:relative; transition:color .3s;
}
.auth-tab:hover { color:var(--text); }
.auth-tab.active { color:var(--cyan); }
.auth-tab.active::after {
    content:''; position:absolute; bottom:-1px; left:0; right:0;
    height:2px; background:var(--cyan);
}
.auth-form { display:flex; flex-direction:column; gap:14px; }

/* ─── MODALS ─── */
.modal-overlay {
    position:fixed; inset:0; background:rgba(0,0,0,.8); backdrop-filter:blur(8px);
    z-index:200; display:none; align-items:center; justify-content:center; padding:24px;
}
.modal-overlay.open { display:flex; }
.modal-box {
    background:var(--surface); border:1px solid var(--border);
    border-radius:12px; padding:28px; max-width:420px; width:100%;
    position:relative; box-shadow:0 20px 60px rgba(0,240,255,.06);
}
.modal-close {
    position:absolute; top:12px; right:16px; background:none; border:none;
    color:var(--text-dim); font-size:20px; cursor:pointer; transition:color .2s;
}
.modal-close:hover { color:var(--magenta); }
.modal-header { text-align:center; margin-bottom:18px; }
.modal-icon { font-size:32px; margin-bottom:6px; }
.modal-header h3 { font-family:var(--display); font-size:16px; letter-spacing:1px; }
.checkout-plan {
    text-align:center; padding:10px; background:var(--bg2);
    border-radius:var(--radius); margin-bottom:18px;
    font-family:var(--mono); font-size:14px; color:var(--cyan);
}
.checkout-form { display:flex; flex-direction:column; gap:14px; }
.checkout-crypto {
    display:flex; justify-content:center; gap:8px; margin-top:14px;
    font-family:var(--mono); font-size:11px; color:var(--text-dim);
}
.checkout-crypto span { padding:3px 8px; border:1px solid var(--border); border-radius:4px; }
.checkout-note { text-align:center; font-size:11px; color:var(--text-dim); margin-top:10px; }

/* ─── FOOTER ─── */
.footer { border-top:1px solid var(--border); padding:36px 24px; }
.footer-inner {
    max-width:1100px; margin:0 auto;
    display:flex; justify-content:space-between; align-items:center;
}
.footer-brand p { font-size:12px; color:var(--text-dim); margin-top:4px; }
.footer-links { display:flex; gap:20px; }
.footer-links a { color:var(--text-dim); text-decoration:none; font-size:13px; transition:color .3s; }
.footer-links a:hover { color:var(--cyan); }

/* ─── ANIMATIONS ─── */
.product-card, .price-card {
    opacity:0; transform:translateY(24px);
    transition:opacity .5s ease, transform .5s ease;
}
.product-card.visible, .price-card.visible { opacity:1; transform:translateY(0); }

/* ─── RESPONSIVE ─── */
@media (max-width:1024px) {
    .product-grid { grid-template-columns:repeat(2,1fr); }
    .pricing-grid { grid-template-columns:repeat(2,1fr); }
}
@media (max-width:768px) {
    .nav-links { display:none; }
    .hero-wrapper { flex-direction:column; text-align:center; }
    .hero-phone { display:none; }
    .hero-buttons { justify-content:center; }
    .product-grid { grid-template-columns:1fr; }
    .pricing-grid { grid-template-columns:1fr; max-width:360px; margin:0 auto; }
    .footer-inner { flex-direction:column; gap:16px; text-align:center; }
}
