﻿/* ================================================================
   OpenShort — Professional 3D Immersive Design  |  openshort.online
   Mobile-first, accessible, performant
   ================================================================ */

@import url('https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800;900&display=swap');

:root{
  --bg:#020d1a;--bg2:#041222;
  --surface:rgba(0,200,255,.05);--surface2:rgba(0,200,255,.09);--surface3:rgba(0,200,255,.13);
  --border:rgba(0,200,255,.12);--border2:rgba(0,200,255,.22);
  --primary:#00C8FF;--primary-light:#38D9FF;--primary-dark:#0099CC;
  --secondary:#7C3AED;--accent:#A855F7;
  --success:#10B981;--warning:#F59E0B;--danger:#EF4444;--info:#A855F7;
  --text:#E0F7FF;--text-muted:rgba(224,247,255,.55);--text-faint:rgba(224,247,255,.28);
  --primary-hover:#38D9FF;--text-secondary:rgba(224,247,255,.5);
  --background:#020d1a;--card-bg:#061828;--border-color:rgba(0,200,255,.12);
  --r-sm:10px;--r:16px;--r-lg:24px;--r-xl:32px;
  --shadow:0 8px 32px rgba(0,0,0,.6);--shadow-lg:0 24px 64px rgba(0,0,0,.75);
  --glow:0 0 40px rgba(0,200,255,.3);--glow-lg:0 0 80px rgba(0,200,255,.45);
  --font:'Inter',-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;
  --ease:cubic-bezier(.4,0,.2,1);
}

/* ── RESET ── */
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box;-webkit-tap-highlight-color:transparent}
html{scroll-behavior:smooth;font-size:16px}
body{font-family:var(--font);background:var(--bg);color:var(--text);min-height:100vh;overflow-x:hidden;
  -webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;
  perspective:1200px;perspective-origin:50% 50%;
  text-rendering:optimizeLegibility}
::-webkit-scrollbar{width:4px}::-webkit-scrollbar-track{background:var(--bg2)}::-webkit-scrollbar-thumb{background:var(--primary);border-radius:2px}

/* ── 3D BACKGROUND SCENE ── */
.bg-canvas{position:fixed;inset:0;z-index:0;pointer-events:none;overflow:hidden;transform-style:preserve-3d}
.bg-orb{position:absolute;border-radius:50%;filter:blur(60px);will-change:transform;opacity:.6}
.bg-orb-1{width:600px;height:600px;background:radial-gradient(circle,rgba(0,200,255,.28),transparent 70%);top:-250px;left:-180px;animation:orbFloat1 18s ease-in-out infinite}
.bg-orb-2{width:500px;height:500px;background:radial-gradient(circle,rgba(124,58,237,.25),transparent 70%);bottom:-150px;right:-120px;animation:orbFloat2 14s ease-in-out infinite}
.bg-orb-3{width:350px;height:350px;background:radial-gradient(circle,rgba(0,255,200,.14),transparent 70%);top:55%;left:65%;animation:orbFloat3 22s ease-in-out infinite}
.bg-grid{position:fixed;inset:0;z-index:0;pointer-events:none;
  background-image:linear-gradient(rgba(0,200,255,.04) 1px,transparent 1px),linear-gradient(90deg,rgba(0,200,255,.04) 1px,transparent 1px);
  background-size:60px 60px;transform:perspective(600px) rotateX(60deg) translateZ(-200px) scale(3);transform-origin:center top;opacity:.45}
@keyframes orbFloat1{0%,100%{transform:translate3d(0,0,0) scale(1)}50%{transform:translate3d(40px,-60px,100px) scale(1.1)}}
@keyframes orbFloat2{0%,100%{transform:translate3d(0,0,0) scale(1)}50%{transform:translate3d(-30px,50px,80px) scale(1.08)}}
@keyframes orbFloat3{0%,100%{transform:translate3d(0,0,0) scale(1)}50%{transform:translate3d(20px,-40px,60px) scale(1.05)}}

.page-wrap{position:relative;z-index:1;min-height:100vh;display:flex;flex-direction:column}

/* ══════════════════════════════════════════════════
   NAVBAR — floating glass, mobile-first
   ═════════════════════════════════════════════════ */
.navbar{position:sticky;top:0;z-index:200;
  background:rgba(2,10,22,.85);backdrop-filter:blur(12px) saturate(1.6);-webkit-backdrop-filter:blur(12px) saturate(1.6);
  border-bottom:1px solid rgba(0,200,255,.08);
  box-shadow:0 4px 30px rgba(0,0,0,.4),inset 0 -1px 0 rgba(0,200,255,.06);
  overflow:visible}
.nav-container{max-width:1100px;margin:0 auto;height:56px;display:flex;align-items:center;justify-content:space-between;padding:0 16px}
.nav-brand{display:flex;align-items:center;gap:10px;text-decoration:none;flex-shrink:0}
.nav-logo{width:36px;height:36px;background:linear-gradient(135deg,#00C8FF,#0099CC);border-radius:11px;display:flex;align-items:center;justify-content:center;
  box-shadow:0 0 20px rgba(0,200,255,.4);
  transform:perspective(200px) rotateY(-5deg);transition:transform .3s var(--ease)}
.nav-brand:hover .nav-logo{transform:perspective(200px) rotateY(5deg)}
.nav-logo svg{width:17px;height:17px}
.nav-name{font-size:18px;font-weight:800;letter-spacing:-.5px;color:#38D9FF}
.nav-links{display:flex;align-items:center;gap:6px}
.nav-btn{padding:8px 16px;border-radius:var(--r-sm);font-size:13px;font-weight:600;text-decoration:none;color:var(--text);
  transition:all .25s var(--ease);white-space:nowrap;display:inline-flex;align-items:center;gap:5px}
.nav-btn:hover{color:var(--text);background:var(--surface2)}
.nav-btn-primary{background:#00C8FF;color:#fff!important;
  box-shadow:0 4px 20px rgba(0,200,255,.4);
  transform:perspective(200px) translateZ(0)}
.nav-btn-primary:hover{transform:perspective(200px) translateZ(8px);box-shadow:0 8px 30px rgba(0,200,255,.5)}
.nav-btn-outline{border:1px solid var(--border2);background:rgba(255,255,255,.04)}
.nav-btn-admin{color:#FCD34D!important}.nav-btn-admin:hover{background:rgba(252,211,77,.08)}

/* HAMBURGER */
.nav-toggle{display:none;background:none;border:none;cursor:pointer;padding:10px;flex-direction:column;gap:5px;z-index:201}
.nav-toggle span{display:block;width:22px;height:2px;background:var(--text-muted);border-radius:1px;transition:all .3s var(--ease)}
.nav-toggle.active span:nth-child(1){transform:rotate(45deg) translate(5px,5px)}
.nav-toggle.active span:nth-child(2){opacity:0;transform:scaleX(0)}
.nav-toggle.active span:nth-child(3){transform:rotate(-45deg) translate(5px,-5px)}

@media(max-width:640px){
  .nav-toggle{display:flex}
  .nav-container{position:relative}
  .nav-links{
    position:fixed;top:56px;left:0;right:0;
    background:rgba(2,10,22,.98);backdrop-filter:blur(30px);-webkit-backdrop-filter:blur(30px);
    flex-direction:column;padding:0 16px;gap:6px;
    border-top:1px solid transparent;
    max-height:0;overflow:hidden;
    opacity:0;pointer-events:none;
    transition:max-height .35s var(--ease),opacity .3s var(--ease),padding .35s var(--ease),border-color .35s;
    z-index:9999;
    justify-content:flex-start;box-shadow:0 12px 40px rgba(0,0,0,.7)}
  .nav-links.open{
    max-height:400px;padding:14px 16px 20px;
    opacity:1;pointer-events:all;
    border-top-color:var(--border)}
  .nav-btn{width:100%;justify-content:center;padding:13px 16px;font-size:15px;border-radius:var(--r)}
  .nav-btn-primary{padding:14px 16px;font-size:15px}
  .nav-btn-outline{padding:13px 16px;font-size:15px}
}

/* ══════════════════════════════════════════════════
   HERO
   ═════════════════════════════════════════════════ */
.hero{padding:32px 16px 40px;display:flex;align-items:flex-start;justify-content:center}
.hero-inner{width:100%;max-width:720px;text-align:center}
.hero-badge{display:inline-flex;align-items:center;gap:6px;padding:6px 16px;
  background:rgba(0,200,255,.08);border:1px solid rgba(0,200,255,.2);border-radius:999px;
  font-size:11px;font-weight:700;color:var(--primary-light);letter-spacing:1px;text-transform:uppercase;margin-bottom:24px;
  box-shadow:0 0 20px rgba(0,200,255,.15);
  transform:perspective(400px) translateZ(15px);animation:badgeFloat 5s ease-in-out infinite}
.hero-badge-dot{width:6px;height:6px;border-radius:50%;background:var(--primary-light);animation:dotPulse 2s infinite}
@keyframes dotPulse{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(.7)}}
@keyframes badgeFloat{0%,100%{transform:perspective(400px) translateZ(15px) translateY(0)}50%{transform:perspective(400px) translateZ(22px) translateY(-4px)}}

.hero-h1{font-size:clamp(34px,9vw,64px);font-weight:900;line-height:1.05;letter-spacing:-2px;margin-bottom:16px;
  transform:perspective(600px) translateZ(30px)}
.hero-h1 .line2{display:block;background:linear-gradient(135deg,#38D9FF 10%,#00FFB0 55%,#A855F7 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.hero-sub{font-size:clamp(14px,3.5vw,17px);color:var(--text-muted);line-height:1.65;margin-bottom:36px;max-width:480px;margin-left:auto;margin-right:auto;
  transform:perspective(400px) translateZ(8px)}

/* ══════════════════════════════════════════════════
   THEME PICKER (Step 1 — visual card gallery)
   ═════════════════════════════════════════════════ */
.theme-picker{
  background:#061828;
  border:1px solid var(--border);border-radius:var(--r-lg);padding:20px;margin-bottom:20px;
  box-shadow:0 4px 6px rgba(0,0,0,.12),0 16px 48px rgba(0,0,0,.35);
  transition:box-shadow .3s var(--ease);
  position:relative;text-align:left}
.theme-picker::before{content:'';position:absolute;inset:-1px;border-radius:inherit;padding:1px;
  background:linear-gradient(135deg,rgba(0,200,255,.2),transparent 50%,rgba(0,200,255,.12));
  -webkit-mask:linear-gradient(#fff 0 0) content-box,linear-gradient(#fff 0 0);-webkit-mask-composite:xor;mask-composite:exclude;pointer-events:none;z-index:1}
.theme-picker:hover{box-shadow:0 4px 6px rgba(0,0,0,.15),0 24px 64px rgba(0,0,0,.45),0 0 60px rgba(0,200,255,.07)}

.tp-head{display:flex;align-items:center;gap:14px;margin-bottom:16px}
.tp-step{width:32px;height:32px;border-radius:10px;background:linear-gradient(135deg,var(--primary),var(--secondary));color:#fff;display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:800;flex-shrink:0;
  box-shadow:0 0 16px rgba(0,200,255,.35)}
.tp-title{font-size:15px;font-weight:700;letter-spacing:-.3px}
.tp-sub{font-size:12px;color:var(--text-muted);margin-top:2px}

.tp-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:10px}
.tp-card{background:var(--surface);border:2px solid transparent;border-radius:var(--r);overflow:hidden;cursor:pointer;
  transition:all .3s var(--ease);transform:perspective(400px) translateZ(0)}
.tp-card:hover{transform:perspective(400px) translateZ(8px) scale(1.03);border-color:var(--border2);
  box-shadow:0 8px 30px rgba(0,0,0,.4)}
.tp-card.selected{border-color:var(--primary);box-shadow:0 0 0 1px var(--primary),0 0 30px rgba(0,200,255,.2)}
.tp-visual{height:90px;position:relative;overflow:hidden;display:flex;align-items:center;justify-content:center;background:var(--surface2)}
.tp-visual img{width:100%;height:100%;object-fit:cover;background:var(--surface2)}
.tp-grad{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;background-size:cover;background-position:center}
.tp-logo-thumb{width:100%;height:100%;object-fit:cover;border-radius:0}
.tp-direct-visual{flex-direction:column;gap:6px;background:linear-gradient(135deg,rgba(0,200,255,.06),rgba(0,200,255,.06))}
.tp-direct-label{font-size:10px;font-weight:700;letter-spacing:.5px;text-transform:uppercase;color:var(--primary-light)}
.tp-info{padding:8px 10px;display:flex;align-items:center;justify-content:space-between;gap:6px}
.tp-serial{width:20px;height:20px;border-radius:6px;background:linear-gradient(135deg,var(--primary),var(--secondary));color:#fff;
  font-size:9px;font-weight:800;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.tp-name{font-size:11px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;flex:1}
.tp-cat{font-size:9px;font-weight:700;text-transform:uppercase;letter-spacing:.3px;color:#C084FC;
  background:rgba(124,58,237,.12);padding:2px 6px;border-radius:99px;flex-shrink:0}

/* Preview button on theme cards */
.tp-card{position:relative}
.tp-preview-btn{position:absolute;top:5px;right:5px;background:rgba(0,0,0,.72);color:#fff;
  font-size:10px;font-weight:700;padding:3px 7px;border-radius:6px;text-decoration:none;
  z-index:3;opacity:0;transition:opacity .2s;pointer-events:none;backdrop-filter:blur(6px);
  border:1px solid rgba(255,255,255,.15)}
.tp-card:hover .tp-preview-btn{opacity:1;pointer-events:all}
@media(hover:none){.tp-preview-btn{opacity:.75;pointer-events:all;font-size:9px;padding:2px 6px}}

@media(max-width:640px){
  .tp-grid{grid-template-columns:repeat(2,1fr);gap:8px}
  .tp-visual{height:70px}
  .tp-info{padding:6px 8px}
  .tp-name{font-size:10px}
}

@media(max-width:480px){
  .tp-grid{grid-template-columns:repeat(2,1fr);gap:8px}
  .tp-visual{height:65px}
  .tp-info{padding:6px 8px}
  .tp-name{font-size:10px}
}

/* ══════════════════════════════════════════════════
   CREATE BOX (Step 2 — form card)
   ═════════════════════════════════════════════════ */
.create-box{background:#061828;backdrop-filter:none;-webkit-backdrop-filter:none;
  border:1px solid var(--border);border-radius:var(--r-lg);padding:20px;
  box-shadow:0 4px 6px rgba(0,0,0,.12),0 16px 48px rgba(0,0,0,.35);
  transition:box-shadow .3s var(--ease);
  position:relative;text-align:left}
.create-box::before{content:'';position:absolute;inset:-1px;border-radius:inherit;padding:1px;
  background:linear-gradient(135deg,rgba(0,200,255,.25),transparent 50%,rgba(124,58,237,.18));
  -webkit-mask:linear-gradient(#fff 0 0) content-box,linear-gradient(#fff 0 0);-webkit-mask-composite:xor;mask-composite:exclude;pointer-events:none;z-index:1}
.create-box:hover{
  box-shadow:0 4px 6px rgba(0,0,0,.15),0 24px 64px rgba(0,0,0,.45),0 0 60px rgba(0,200,255,.07)}
.cb-head{display:flex;align-items:center;gap:14px;margin-bottom:18px}

/* ── 3D CARD (generic) ── */
.card-3d{background:#061828;backdrop-filter:none;-webkit-backdrop-filter:none;
  border:1px solid var(--border);border-radius:var(--r-lg);padding:28px 24px;
  box-shadow:0 4px 6px rgba(0,0,0,.12),0 20px 50px rgba(0,0,0,.4);
  transform:perspective(1000px) rotateX(1.5deg) translateZ(0);
  transition:transform .5s var(--ease),box-shadow .5s var(--ease);position:relative;text-align:left;
  transform-style:preserve-3d}
.card-3d::before{content:'';position:absolute;inset:-1px;border-radius:inherit;padding:1px;
  background:linear-gradient(135deg,rgba(0,200,255,.2),transparent 50%,rgba(0,200,255,.12));
  -webkit-mask:linear-gradient(#fff 0 0) content-box,linear-gradient(#fff 0 0);-webkit-mask-composite:xor;mask-composite:exclude;
  pointer-events:none;z-index:1}
.card-3d:hover{transform:perspective(1000px) rotateX(0) translateZ(16px);
  box-shadow:0 4px 6px rgba(0,0,0,.15),0 28px 70px rgba(0,0,0,.5),0 0 60px rgba(0,200,255,.08)}

/* ══════════════════════════════════════════════════
   FORM ELEMENTS
   ═════════════════════════════════════════════════ */
.field{margin-bottom:14px}
.field-label{display:block;font-size:11px;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.8px;margin-bottom:5px}
.field-input{width:100%;padding:11px 13px;background:rgba(255,255,255,.04);border:1px solid var(--border);border-radius:var(--r-sm);color:var(--text);font-size:15px;font-family:var(--font);
  transition:border-color .2s,box-shadow .2s;outline:none}
.field-input:focus{border-color:var(--primary);box-shadow:0 0 0 3px rgba(0,200,255,.12),0 0 16px rgba(0,200,255,.06)}
.field-input::placeholder{color:var(--text-faint)}
.alias-wrap{display:flex;align-items:stretch;border:1px solid var(--border);border-radius:var(--r-sm);background:rgba(255,255,255,.04);overflow:hidden;transition:border-color .2s,box-shadow .2s}
.alias-wrap:focus-within{border-color:var(--primary);box-shadow:0 0 0 3px rgba(0,200,255,.12)}
.alias-prefix{padding:11px 8px 11px 13px;font-size:12px;color:var(--text-muted);background:rgba(255,255,255,.03);white-space:nowrap;border-right:1px solid var(--border);display:flex;align-items:center}
.alias-wrap .field-input{border:none;background:transparent;border-radius:0}
.alias-wrap .field-input:focus{box-shadow:none}
.alias-fee{display:inline-flex;padding:2px 8px;border-radius:99px;font-size:10px;font-weight:700;
  background:rgba(245,158,11,.15);color:#F59E0B;margin-left:6px;vertical-align:middle;letter-spacing:.3px}
.alias-hint{font-size:11px;color:var(--text-faint);margin-top:5px;line-height:1.4}
select.field-input{appearance:none;-webkit-appearance:none;
  background-color:#060e16;color:#E0F7FF;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='rgba(255,255,255,.5)' stroke-width='2'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");
  background-repeat:no-repeat;background-position:right 14px center;padding-right:36px}
select.field-input option{background:#060e16;color:#E0F7FF;padding:8px}

/* HERO MESSAGE */
.hero-msg{display:none;margin-top:12px;padding:11px 14px;border-radius:var(--r-sm);font-size:13px;font-weight:500}
.hero-msg-error{background:rgba(239,68,68,.1);color:#f87171;border:1px solid rgba(239,68,68,.15)}
.hero-msg-success{background:rgba(16,185,129,.1);color:#10B981;border:1px solid rgba(16,185,129,.15)}

/* ══════════════════════════════════════════════════
   BUTTONS
   ═════════════════════════════════════════════════ */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:12px 24px;border:none;border-radius:var(--r-sm);font-size:14px;font-weight:650;font-family:var(--font);cursor:pointer;text-decoration:none;transition:all .3s var(--ease);white-space:nowrap;position:relative;overflow:hidden}
.btn-primary{background:#00C8FF;color:#fff;
  box-shadow:0 4px 20px rgba(0,200,255,.35);
  transform:perspective(300px) translateZ(0)}
.btn-primary:hover{transform:perspective(300px) translateZ(6px);box-shadow:0 8px 30px rgba(0,200,255,.45)}
.btn-primary:active{transform:perspective(300px) translateZ(-2px)}
.btn-primary::after{content:'';position:absolute;inset:0;background:linear-gradient(135deg,rgba(255,255,255,.1),transparent);pointer-events:none}
.btn-outline{border:1px solid var(--border2);color:var(--text);background:transparent}
.btn-outline:hover{background:var(--surface2);border-color:var(--primary)}
.btn-danger{background:linear-gradient(135deg,#EF4444,#DC2626);color:#fff;box-shadow:0 4px 16px rgba(239,68,68,.3)}
.btn-success{background:linear-gradient(135deg,#10B981,#059669);color:#fff;box-shadow:0 4px 16px rgba(16,185,129,.3)}
.btn-block{width:100%}
.btn-lg{padding:14px 28px;font-size:15px;border-radius:14px}
.btn-sm{padding:7px 14px;font-size:12px}

/* ══════════════════════════════════════════════════
   STATS STRIP
   ═════════════════════════════════════════════════ */
.stats-section{padding:0 16px 48px}
.stats-card{max-width:560px;margin:0 auto;display:flex;gap:2px;
  background:#061828;backdrop-filter:none;border:1px solid var(--border);border-radius:var(--r-lg);padding:3px;
  box-shadow:var(--shadow);transform:perspective(800px) rotateX(1.5deg) translateZ(8px)}
.stat{flex:1;text-align:center;padding:18px 8px;border-radius:var(--r);transition:background .2s}
.stat:hover{background:var(--surface2)}
.stat-n{font-size:24px;font-weight:800;letter-spacing:-1px;color:#fff}
.stat-l{font-size:10px;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.8px;margin-top:4px}

/* ══════════════════════════════════════════════════
   HOW IT WORKS
   ═════════════════════════════════════════════════ */
.how-section{padding:32px 16px 64px;max-width:720px;margin:0 auto}
.section-head{text-align:center;margin-bottom:32px}
.section-head h2{font-size:clamp(24px,6vw,34px);font-weight:800;letter-spacing:-.8px;margin-bottom:6px;color:#fff}
.section-head p{color:var(--text-muted);font-size:14px}
.steps-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}
.step-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r);padding:20px 16px;
  display:flex;gap:12px;
  transform:perspective(600px) rotateX(1deg) translateZ(0);transition:transform .4s var(--ease),box-shadow .4s var(--ease);
  box-shadow:0 4px 16px rgba(0,0,0,.25)}
.step-card:hover{transform:perspective(600px) rotateX(0deg) translateZ(12px);box-shadow:0 12px 40px rgba(0,0,0,.35),0 0 25px rgba(0,200,255,.07)}
.step-num{width:32px;height:32px;border-radius:9px;background:#7C3AED;color:#fff;display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:800;flex-shrink:0;
  box-shadow:0 0 16px rgba(124,58,237,.35)}
.step-info h4{font-size:14px;font-weight:700;margin-bottom:3px;color:#fff}
.step-info p{font-size:12px;color:var(--text-muted);line-height:1.5}
@media(max-width:640px){.steps-grid{grid-template-columns:1fr}}

/* ══════════════════════════════════════════════════
   MODAL (bottom-sheet on mobile, centered on desktop)
   ═════════════════════════════════════════════════ */
.modal-overlay{position:fixed;inset:0;z-index:1000;background:rgba(0,0,0,.7);backdrop-filter:blur(8px);display:none;align-items:flex-end;justify-content:center}
.modal-overlay.active{display:flex}
.modal{background:var(--bg2);border:1px solid var(--border);border-radius:var(--r-lg) var(--r-lg) 0 0;padding:24px 18px 28px;
  width:100%;max-width:460px;max-height:90vh;overflow-y:auto;
  box-shadow:0 -16px 50px rgba(0,0,0,.6);
  transform:perspective(600px) translateZ(16px);
  animation:modalUp .35s var(--ease)}
@keyframes modalUp{from{transform:perspective(600px) translateY(100%) translateZ(16px)}to{transform:perspective(600px) translateY(0) translateZ(16px)}}
@media(min-width:640px){
  .modal-overlay.active{align-items:center}
  .modal{border-radius:var(--r-lg);animation:modalScale .35s var(--ease)}
  @keyframes modalScale{from{transform:perspective(600px) scale(.92) translateZ(16px);opacity:0}to{transform:perspective(600px) scale(1) translateZ(16px);opacity:1}}
}
@media(max-width:480px){
  .modal{padding:18px 14px 22px;max-height:88vh}
  .qr-box{padding:10px;margin:8px auto}
  .modal-sub{margin-bottom:10px}
}
.modal-title{font-size:19px;font-weight:800;margin-bottom:4px;color:#fff}
.modal-sub{font-size:13px;color:var(--text-muted);margin-bottom:18px}
.modal-close{position:absolute;top:14px;right:14px;background:var(--surface2);border:none;color:var(--text-muted);width:30px;height:30px;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:15px;transition:all .2s}
.modal-close:hover{background:var(--danger);color:#fff}
.qr-box{background:white;border-radius:var(--r);padding:14px;margin:12px auto;width:fit-content;max-width:100%;
  box-shadow:0 6px 24px rgba(0,0,0,.3)}
.qr-box img,.qr-box canvas{display:block;max-width:100%!important;height:auto!important}
.qr-box:hover{transform:none}
.utr-input{width:100%;padding:11px 13px;background:rgba(255,255,255,.04);border:1px solid var(--border);border-radius:var(--r-sm);color:var(--text);font-size:15px;font-family:var(--font);outline:none;transition:all .2s;margin:10px 0}
.utr-input:focus{border-color:var(--primary);box-shadow:0 0 0 3px rgba(0,200,255,.12)}

/* ══════════════════════════════════════════════════
   PAYMENT BADGE
   ═════════════════════════════════════════════════ */
.pay-badge{display:inline-flex;padding:3px 10px;border-radius:99px;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.5px}
.pay-badge.paid{background:rgba(16,185,129,.15);color:#10B981}
.pay-badge.pending{background:rgba(245,158,11,.15);color:#F59E0B;cursor:pointer;transition:all .2s}
.pay-badge.pending:hover{background:rgba(245,158,11,.25)}

/* ══════════════════════════════════════════════════
   DASHBOARD — Redesigned
   ═════════════════════════════════════════════════ */
.dash{padding:28px 16px 64px;max-width:900px;margin:0 auto}
.dash-title{font-size:clamp(22px,6vw,30px);font-weight:800;letter-spacing:-1px;margin-bottom:6px;color:#fff}
.dash-sub{color:var(--text-muted);font-size:13px;margin-bottom:28px}
.links-list{display:flex;flex-direction:column;gap:10px;margin-top:28px}
.link-row{display:flex;flex-wrap:wrap;align-items:center;gap:10px;background:var(--surface);border:1px solid var(--border);border-radius:var(--r);padding:14px;
  transform:perspective(600px) translateZ(0);transition:all .3s var(--ease);
  box-shadow:0 2px 10px rgba(0,0,0,.18)}
.link-row:hover{transform:perspective(600px) translateZ(8px);box-shadow:0 8px 28px rgba(0,0,0,.3);border-color:var(--border2)}
.link-alias{font-weight:700;color:var(--primary-light);font-size:14px;cursor:pointer;flex:1;min-width:100px}
.link-dest{font-size:12px;color:var(--text-muted);flex:2;min-width:160px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.link-actions{display:flex;gap:6px;flex-shrink:0}

/* ── New Dashboard Page ── */
.dash-page{padding:20px 16px 64px}
.dash-container{max-width:800px;margin:0 auto}
.dash-hero{text-align:center;margin-bottom:28px;padding:28px 16px 0}
.dash-hero-icon{width:56px;height:56px;border-radius:16px;background:linear-gradient(135deg,rgba(0,200,255,.1),rgba(0,200,255,.1));
  border:1px solid rgba(0,200,255,.15);display:flex;align-items:center;justify-content:center;margin:0 auto 16px;color:var(--primary-light)}
.dash-hero-title{font-size:clamp(24px,6vw,32px);font-weight:800;letter-spacing:-.8px;margin-bottom:4px;color:#fff;text-shadow:none}
.dash-hero-sub{color:var(--text-muted);font-size:14px}
.dash-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin-bottom:20px}
.dash-stat-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r);padding:16px 14px;display:flex;align-items:center;gap:12px;
  transition:all .3s var(--ease);transform:perspective(400px) translateZ(0)}
.dash-stat-card:hover{transform:perspective(400px) translateZ(6px);border-color:var(--border2);box-shadow:0 8px 24px rgba(0,0,0,.2)}
.dash-stat-icon{width:40px;height:40px;border-radius:12px;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.dash-stat-n{font-size:20px;font-weight:800;letter-spacing:-.5px}
.dash-stat-l{font-size:11px;color:var(--text-muted);font-weight:500;margin-top:1px}
.dash-alert{display:flex;align-items:flex-start;gap:10px;padding:14px 16px;border-radius:var(--r-sm);margin-bottom:18px;font-size:13px}
.dash-alert-warn{background:rgba(245,158,11,.08);border:1px solid rgba(245,158,11,.18);color:#FCD34D}
.dash-alert-warn strong{display:block;margin-bottom:2px}
.dash-alert-warn span{color:rgba(252,211,77,.7);font-size:12px}
.dash-create-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);padding:24px 20px;margin-bottom:24px;
  transform:perspective(600px) translateZ(0);transition:all .3s var(--ease);box-shadow:0 4px 20px rgba(0,0,0,.2)}
.dash-create-card:hover{transform:perspective(600px) translateZ(6px);box-shadow:0 10px 36px rgba(0,0,0,.3)}
.dash-card-head{display:flex;align-items:center;gap:10px;margin-bottom:18px}
.dash-card-head h2{font-size:16px;font-weight:700}
.dash-form-grid{display:grid;gap:14px;margin-bottom:16px}
.dash-links-section{margin-top:8px}
.dash-links-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px}
.dash-links-head h2{font-size:16px;font-weight:700}
.dash-badge{background:linear-gradient(135deg,var(--primary),var(--secondary));color:#fff;font-size:11px;font-weight:700;
  padding:3px 10px;border-radius:99px}
.dash-empty{text-align:center;padding:48px 16px;color:var(--text-faint)}
.dash-empty p{margin-top:12px;font-size:13px}
.dash-links-list{display:flex;flex-direction:column;gap:10px}
.dash-link-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r);padding:16px;
  transition:all .3s var(--ease);transform:perspective(400px) translateZ(0)}
.dash-link-card:hover{transform:perspective(400px) translateZ(6px);border-color:var(--border2);box-shadow:0 8px 28px rgba(0,0,0,.25)}
.dash-link-top{display:flex;align-items:center;justify-content:space-between;gap:8px;margin-bottom:8px}
.dash-link-alias-row{display:flex;align-items:center;gap:8px;min-width:0;flex:1}
.dash-link-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}
.dash-link-dot.active{background:#10B981;box-shadow:0 0 8px rgba(16,185,129,.5)}
.dash-link-dot.pending{background:#F59E0B;box-shadow:0 0 8px rgba(245,158,11,.5)}
.dash-link-alias{color:var(--primary-light);font-weight:700;font-size:14px;text-decoration:none;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.dash-link-alias:hover{text-decoration:underline}
.dash-link-actions{display:flex;gap:4px;flex-shrink:0}
.dash-action-btn{width:32px;height:32px;border-radius:8px;border:1px solid var(--border);background:transparent;color:var(--text-muted);
  display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s;text-decoration:none}
.dash-action-btn:hover{background:var(--surface2);color:var(--text);border-color:var(--border2)}
.dash-action-btn.danger:hover{background:rgba(239,68,68,.12);color:var(--danger);border-color:rgba(239,68,68,.3)}
.dash-link-dest{font-size:12px;color:var(--text-muted);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;margin-bottom:10px}
.dash-link-meta{display:flex;align-items:center;gap:10px;flex-wrap:wrap;font-size:12px}
.dash-link-clicks{display:flex;align-items:center;gap:4px;color:var(--text-muted)}
.dash-pay-badge{padding:2px 10px;border-radius:99px;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.3px}
.dash-pay-badge.active{background:rgba(16,185,129,.12);color:#10B981}
.dash-pay-badge.pending{background:rgba(245,158,11,.12);color:#F59E0B;cursor:pointer;transition:all .2s}
.dash-pay-badge.pending:hover{background:rgba(245,158,11,.22)}
.dash-link-date{color:var(--text-faint);font-size:11px;margin-left:auto}
@media(max-width:640px){
  .dash-stats{grid-template-columns:1fr}
  .dash-link-top{flex-direction:column;align-items:flex-start}
  .dash-link-actions{width:100%;justify-content:flex-end}
}

/* ══════════════════════════════════════════════════
   AUTH PAGES (login / register) — Professional Redesign
   ═════════════════════════════════════════════════ */
.auth-page{min-height:calc(100vh - 56px);display:flex;align-items:center;justify-content:center;padding:32px 16px;position:relative}
.auth-card{width:100%;max-width:420px;position:relative}
.auth-card-inner{
  background:#061828;backdrop-filter:none;-webkit-backdrop-filter:none;
  border:1px solid rgba(0,200,255,.12);border-radius:24px;padding:40px 32px;
  position:relative;overflow:hidden;
  box-shadow:0 24px 80px rgba(0,0,0,.5),0 0 0 1px rgba(255,255,255,.04) inset}
.auth-card-inner::before{content:'';position:absolute;top:-50%;left:-50%;width:200%;height:200%;
  background:conic-gradient(from 180deg at 50% 50%,transparent 0deg,rgba(0,200,255,.05) 120deg,transparent 240deg,rgba(0,200,255,.05) 360deg);
  animation:authShimmer 8s linear infinite;pointer-events:none}
@keyframes authShimmer{0%{transform:rotate(0deg)}100%{transform:rotate(360deg)}}
.auth-glow{position:absolute;top:-100px;left:50%;transform:translateX(-50%);width:300px;height:200px;
  background:radial-gradient(ellipse,rgba(0,200,255,.14),transparent 70%);pointer-events:none;z-index:0}
.auth-icon-wrap{width:60px;height:60px;border-radius:18px;
  background:linear-gradient(135deg,var(--primary),var(--secondary));
  display:flex;align-items:center;justify-content:center;margin:0 auto 20px;position:relative;z-index:1;
  box-shadow:0 8px 32px rgba(0,200,255,.45),0 0 0 6px rgba(0,200,255,.07)}
.auth-heading{text-align:center;font-size:24px;font-weight:800;letter-spacing:-.5px;position:relative;z-index:1;color:#fff}
.auth-desc{text-align:center;font-size:14px;color:var(--text-muted);margin:6px 0 24px;position:relative;z-index:1;line-height:1.5}
.auth-alert{display:flex;align-items:center;gap:8px;background:rgba(239,68,68,.08);border:1px solid rgba(239,68,68,.2);
  border-radius:12px;padding:12px 16px;font-size:13px;color:#f87171;margin-bottom:16px;position:relative;z-index:1}
.auth-form{position:relative;z-index:1}
.auth-field{margin-bottom:16px}
.auth-field label{display:block;font-size:12px;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.8px;margin-bottom:6px}
.auth-input-wrap{display:flex;align-items:center;gap:10px;
  background:rgba(255,255,255,.04);border:1.5px solid rgba(255,255,255,.1);border-radius:14px;
  padding:0 14px;transition:all .25s var(--ease)}
.auth-input-wrap:focus-within{border-color:var(--primary);background:rgba(0,200,255,.04);
  box-shadow:0 0 0 4px rgba(0,200,255,.1),0 0 20px rgba(0,200,255,.05)}
.auth-input-wrap svg{flex-shrink:0;color:var(--text-faint);transition:color .2s}
.auth-input-wrap:focus-within svg{color:var(--primary-light)}
.auth-input-wrap input{flex:1;background:none;border:none;outline:none;color:var(--text);
  font-size:15px;font-family:var(--font);padding:13px 0}
.auth-input-wrap input::placeholder{color:var(--text-faint)}
.auth-submit{width:100%;padding:14px 24px;border:none;border-radius:14px;
  background:linear-gradient(135deg,var(--primary),var(--secondary));color:#fff;
  font-size:15px;font-weight:700;font-family:var(--font);cursor:pointer;
  display:flex;align-items:center;justify-content:center;gap:8px;
  box-shadow:0 6px 24px rgba(0,200,255,.4);
  transition:all .3s var(--ease);margin-top:4px}
.auth-submit:hover{box-shadow:0 10px 36px rgba(0,200,255,.5);transform:translateY(-1px)}
.auth-submit:active{transform:translateY(0)}
.auth-switch{text-align:center;font-size:13px;color:var(--text-muted);margin-top:20px;position:relative;z-index:1}
.auth-switch a{color:var(--primary-light);text-decoration:none;font-weight:600;transition:color .2s}
.auth-switch a:hover{color:#fff}

@media(max-width:480px){
  .auth-card-inner{padding:28px 20px;border-radius:20px}
  .auth-icon-wrap{width:52px;height:52px;border-radius:15px}
  .auth-heading{font-size:22px}
}

/* ══════════════════════════════════════════════════
   CENTER PAGES (404, payment-required, etc)
   ═════════════════════════════════════════════════ */
.center-page{min-height:calc(100vh - 56px);display:flex;align-items:center;justify-content:center;padding:32px 16px}
.center-card{text-align:center;max-width:380px;
  background:var(--surface);backdrop-filter:blur(30px);border:1px solid var(--border);border-radius:var(--r-lg);padding:40px 28px;
  box-shadow:0 20px 50px rgba(0,0,0,.4);
  transform:perspective(800px) translateZ(24px)}
.error-code{font-size:64px;font-weight:900;letter-spacing:-3px;color:var(--primary-light);margin-bottom:10px}

/* ══════════════════════════════════════════════════
   ADMIN
   ═════════════════════════════════════════════════ */
.admin-wrap{padding:20px 16px 64px;max-width:1100px;margin:0 auto}
.admin-section{background:var(--surface);border:1px solid var(--border);border-radius:var(--r);padding:18px;margin-bottom:18px;
  transform:perspective(600px) translateZ(0);transition:all .3s;box-shadow:0 4px 16px rgba(0,0,0,.2)}
.admin-section:hover{transform:perspective(600px) translateZ(6px);box-shadow:0 10px 32px rgba(0,0,0,.3)}
.admin-section h3{font-size:15px;font-weight:700;margin-bottom:14px;color:var(--primary-light)}
.admin-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:12px}
.admin-theme-card{background:var(--surface2);border:1px solid var(--border);border-radius:var(--r-sm);overflow:hidden;
  transform:perspective(400px) translateZ(0);transition:all .3s}
.admin-theme-card:hover{transform:perspective(400px) translateZ(8px);border-color:var(--primary)}
.admin-theme-img{width:100%;height:90px;object-fit:cover;display:block}
.admin-theme-info{padding:10px 12px}
.admin-theme-info h4{font-size:13px;font-weight:700;margin-bottom:3px;display:flex;align-items:center;gap:8px}
.admin-theme-logo{width:48px;height:36px;border-radius:6px;object-fit:cover;border:1px solid var(--border);flex-shrink:0;
  box-shadow:0 2px 8px rgba(0,0,0,.3)}
.admin-theme-info p{font-size:10px;color:var(--text-muted)}

/* PW PROMPT */
.pw-section{text-align:center}
.pw-section input[type=password]{max-width:280px;margin:12px auto;display:block}

/* ── HERO CTA ── */
.hero-cta{display:flex;gap:12px;justify-content:center;flex-wrap:wrap;transform:perspective(400px) translateZ(12px)}

/* ── STATUS BANNER ── */
.status-banner{padding:12px;border-radius:var(--r-sm);margin-bottom:18px;font-size:13px;font-weight:600;display:flex;align-items:center;gap:8px}
.status-banner.approved{background:rgba(16,185,129,.1);border:1px solid rgba(16,185,129,.18);color:#10B981}
.status-banner.unapproved{background:rgba(245,158,11,.1);border:1px solid rgba(245,158,11,.18);color:#F59E0B}

/* ── GUEST HIGHLIGHT ── */
.guest-highlight{margin-top:48px;padding:28px 16px;max-width:600px;margin-left:auto;margin-right:auto;text-align:center}
.guest-highlight h2{font-size:clamp(20px,5vw,26px);font-weight:800;margin-bottom:10px;color:#fff}
.guest-highlight p{color:var(--text-muted);font-size:13px;margin-bottom:20px}

/* ══════════════════════════════════════════════════
   THEME LANDING PAGE (standalone)
   ═════════════════════════════════════════════════ */
.theme-landing{min-height:100vh;display:flex;justify-content:center;align-items:center;text-align:center}
.theme-container{max-width:480px;width:92%;padding:24px;background:rgba(0,0,0,.5);border-radius:20px;backdrop-filter:blur(10px)}
.theme-logo img{width:100%;max-width:340px;height:auto;max-height:180px;border-radius:12px;object-fit:cover;margin-bottom:18px;box-shadow:0 0 24px rgba(0,0,0,.4)}
.theme-heading{font-size:22px;font-weight:700;margin-bottom:10px}
.theme-paragraph{font-size:14px;margin-bottom:22px;opacity:.9;line-height:1.6}
.theme-buttons{display:flex;flex-direction:column;gap:10px;align-items:center}
.theme-btn{padding:13px 28px;border:none;border-radius:28px;font-size:14px;font-weight:700;cursor:pointer;transition:transform .3s;text-decoration:none;color:#fff;display:inline-block;min-width:180px}
.theme-btn:hover{transform:scale(1.05)}
.theme-banner img{width:100%;border-radius:12px;margin-top:18px}

/* ── COPY TOAST ── */
.copy-toast{position:fixed;bottom:24px;left:50%;transform:translateX(-50%) translateY(20px);
  background:var(--primary);color:#fff;padding:8px 20px;border-radius:99px;font-size:13px;font-weight:600;
  opacity:0;transition:all .3s var(--ease);pointer-events:none;z-index:9999;
  box-shadow:0 4px 20px rgba(0,200,255,.35)}
.copy-toast.show{opacity:1;transform:translateX(-50%) translateY(0)}

/* ══════════════════════════════════════════════════
   RESPONSIVE — global mobile fixes
   ═════════════════════════════════════════════════ */
/* Remove 3D rotateX on mobile — fixes touch hit-test misalignment (iOS Safari) */
@media(max-width:768px){
  .create-box,.theme-picker,.card-3d,.auth-card,.stats-card,.step-card{
    transform:none!important}
  .create-box:hover,.theme-picker:hover,.card-3d:hover,.auth-card:hover,.step-card:hover{
    transform:translateY(-2px)!important}}
@media(max-width:480px){
  .hero{padding:24px 14px 28px}
  .hero-h1{letter-spacing:-1.5px}
  .hero-sub{margin-bottom:28px}
  .hero-cta .btn{width:100%}
  .stats-card{flex-direction:row}
  .stat{padding:14px 6px}
  .stat-n{font-size:20px}
  .auth-card-inner{padding:28px 20px}
  .modal{padding:20px 14px 24px}
  .link-row{flex-direction:column;align-items:flex-start}
  .link-dest{width:100%}
  .create-box{padding:16px}
  .theme-picker{padding:16px}
}

/* ══════════════════════════════════════════════════
   ADMIN DASHBOARD — existing classes from admin.ejs
   ═════════════════════════════════════════════════ */
.dashboard-section{padding:20px 16px 64px}
.dashboard-container{max-width:1100px;margin:0 auto}
.dashboard-header{text-align:center;margin-bottom:24px}
.dashboard-header h1{font-size:clamp(22px,6vw,32px);font-weight:800;color:#fff}
.dashboard-header p{color:var(--text-muted);font-size:13px;margin-top:4px}

.admin-tabs{display:flex;gap:4px;flex-wrap:wrap;background:var(--surface);border:1px solid var(--border);border-radius:var(--r);padding:4px;margin-bottom:20px}
.admin-tab{padding:8px 14px;border:none;border-radius:8px;font-size:12px;font-weight:600;cursor:pointer;color:var(--text-muted);background:transparent;font-family:var(--font);transition:all .2s;white-space:nowrap}
.admin-tab:hover{color:var(--text);background:var(--surface2)}
.admin-tab.active{color:#fff;background:linear-gradient(135deg,var(--primary),var(--secondary));box-shadow:0 2px 12px rgba(0,200,255,.25)}
.admin-tab-content{display:none}
.admin-tab-content.active{display:block}

.stats-row{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:10px}
.stat-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r);padding:16px 14px;
  border-left:3px solid var(--primary);transition:all .2s}
.stat-card:hover{background:var(--surface2)}
.stat-card .stat-number{font-size:22px;font-weight:800;color:var(--primary-light)}
.stat-card .stat-label{font-size:11px;color:var(--text-muted);margin-top:2px;text-transform:uppercase;letter-spacing:.5px}
.stat-total{border-left-color:var(--primary)}.stat-today{border-left-color:var(--secondary)}

.admin-grid-2{display:grid;grid-template-columns:repeat(2,1fr);gap:16px}
@media(max-width:768px){.admin-grid-2{grid-template-columns:1fr}}
.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r);padding:18px;margin-bottom:16px}
.card h3{font-size:15px;font-weight:700;margin-bottom:12px}

/* ── Tables ── */
.table-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch}
.links-table,.clicks-table{width:100%;border-collapse:collapse;font-size:13px}
.links-table th,.clicks-table th{text-align:left;padding:8px 10px;font-size:11px;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;border-bottom:1px solid var(--border)}
.links-table td,.clicks-table td{padding:8px 10px;border-bottom:1px solid var(--border);vertical-align:middle}
.links-table tr:hover,.clicks-table tr:hover{background:var(--surface)}

.short-link{color:var(--primary-light);font-weight:600;cursor:pointer}
.click-badge{display:inline-flex;padding:2px 8px;border-radius:99px;font-size:12px;font-weight:700;background:rgba(0,200,255,.08);color:var(--primary-light)}
.status-badge{display:inline-flex;padding:2px 8px;border-radius:99px;font-size:11px;font-weight:600}

/* User cards */
.user-cards-mobile{display:none}
.user-card-m{background:var(--surface);border:1px solid var(--border);border-radius:var(--r);padding:14px;margin-bottom:8px}
.user-card-m-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:6px}
.user-card-m-stats{display:flex;gap:12px;font-size:12px;color:var(--text-muted);margin-bottom:8px}
.user-card-m-actions{display:flex;gap:6px;flex-wrap:wrap}

/* Hot link + activity */
.hotlink-cards-mobile{display:none}
.hotlink-card-m{background:var(--surface);border:1px solid var(--border);border-radius:var(--r);padding:14px;margin-bottom:8px}
.hotlink-card-m-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:6px}
.hotlink-card-m-url{font-size:12px;color:var(--text-muted);margin-bottom:6px;cursor:pointer}
.hotlink-card-m-meta{display:flex;gap:10px;font-size:12px;color:var(--text-muted)}
.activity-cards-mobile{display:none}
.activity-card-m{background:var(--surface);border:1px solid var(--border);border-radius:var(--r);padding:12px;margin-bottom:8px}
.activity-card-m-top{display:flex;justify-content:space-between;font-size:12px;color:var(--text-muted);margin-bottom:4px}
.activity-card-m-details{display:flex;gap:10px;font-size:12px;color:var(--text-muted);margin-bottom:4px}
.activity-card-m-ref{font-size:12px;color:var(--text-muted);cursor:pointer}

.search-cards-mobile{display:none}

@media(max-width:768px){
  .users-table-desktop,.hotlink-table-desktop,.activity-table-desktop,.search-table-desktop{display:none}
  .user-cards-mobile,.hotlink-cards-mobile,.activity-cards-mobile,.search-cards-mobile{display:block}
  .admin-tabs{gap:2px;padding:3px}
  .admin-tab{padding:6px 10px;font-size:11px}
}

/* Actions */
.actions-cell{white-space:nowrap}
.btn-approve{background:linear-gradient(135deg,#10B981,#059669);color:#fff;box-shadow:0 2px 8px rgba(16,185,129,.2)}
.btn-analytics{background:rgba(99,102,241,.12);color:var(--primary-light)}
.btn-override{background:rgba(20,184,166,.12);color:var(--success);font-size:12px;padding:5px 12px}

/* Bans */
.ban-list{display:flex;flex-direction:column;gap:6px}
.ban-item{display:flex;align-items:center;gap:8px;padding:8px 10px;background:var(--surface);border:1px solid var(--border);border-radius:8px;font-size:12px}
.ban-type-badge{padding:2px 6px;border-radius:4px;font-size:10px;font-weight:700}
.ban-ip{background:rgba(239,68,68,.12);color:#f87171}
.ban-domain{background:rgba(245,158,11,.12);color:#F59E0B}
.ban-value{font-weight:600;color:var(--text)}
.ban-reason{color:var(--text-muted);font-style:italic}

/* Audit */
.audit-log-list{display:flex;flex-direction:column;gap:6px}
.audit-entry{padding:8px 10px;background:var(--surface);border-radius:8px;font-size:12px}
.audit-hidden{display:none}
.audit-action{display:flex;align-items:center;gap:8px;margin-bottom:3px}
.audit-badge{padding:2px 8px;border-radius:4px;font-size:10px;font-weight:700;text-transform:uppercase;background:rgba(0,200,255,.1);color:var(--primary-light)}
.audit-time{color:var(--text-faint);font-size:11px}
.audit-detail{color:var(--text-muted);display:flex;gap:8px;flex-wrap:wrap}
.audit-admin{font-weight:600}
.audit-details-text{font-style:italic}

/* Countries bar */
.countries-bar-list{display:flex;flex-direction:column;gap:6px}
.country-bar-row{display:flex;align-items:center;gap:8px;font-size:12px}
.country-bar-label{width:40px;font-weight:600;flex-shrink:0}
.country-bar-track{flex:1;height:8px;background:var(--surface2);border-radius:4px;overflow:hidden}
.country-bar-fill{height:100%;background:linear-gradient(90deg,var(--primary),var(--secondary));border-radius:4px;transition:width .3s}
.country-bar-count{font-weight:600;color:var(--text-muted);min-width:40px;text-align:right}

/* Modal overlay for admin modals */
.modal-overlay{display:none}
.modal-overlay[style*="flex"],.modal-overlay.active{display:flex}
.modal-card{background:var(--bg2);border:1px solid var(--border);border-radius:var(--r-lg);padding:24px;width:90%;max-width:420px;
  box-shadow:0 20px 60px rgba(0,0,0,.6);transform:perspective(400px) translateZ(12px)}
.modal-card h3{font-size:18px;font-weight:700;margin-bottom:8px}
.modal-card .form-group{margin-bottom:12px}
.modal-card .form-group label{display:block;font-size:12px;font-weight:600;color:var(--text-muted);margin-bottom:4px}
.form-input,.form-select{width:100%;padding:10px 12px;background:#060e16;border:1px solid var(--border);border-radius:8px;color:#E0F7FF;font-size:14px;font-family:var(--font);outline:none;transition:border-color .2s}
.form-input:focus,.form-select:focus{border-color:var(--primary)}
.form-select{appearance:none;-webkit-appearance:none;color:#E0F7FF}
.form-select option{background:#060e16;color:#E0F7FF}

/* Override form */
.override-info{padding:10px;background:rgba(0,200,255,.05);border:1px solid rgba(0,200,255,.1);border-radius:8px;font-size:12px;color:var(--text-muted);margin-bottom:12px;line-height:1.5}
.ratio-presets{display:flex;gap:4px;flex-wrap:wrap;margin-top:4px}
.ratio-presets button{padding:4px 10px;border:1px solid var(--border);border-radius:6px;background:var(--surface);color:var(--text-muted);font-size:11px;font-weight:600;cursor:pointer;font-family:var(--font);transition:all .15s}
.ratio-presets button:hover{border-color:var(--primary);color:var(--primary-light)}

/* Alerts */
.alert{padding:10px 14px;border-radius:8px;font-size:13px;margin-bottom:8px}
.alert-success{background:rgba(16,185,129,.1);border:1px solid rgba(16,185,129,.15);color:#10B981}
.alert-error{background:rgba(239,68,68,.1);border:1px solid rgba(239,68,68,.15);color:#f87171}

/* Misc */
.text-muted-sm{font-size:13px;color:var(--text-muted)}

/* ══════════════════════════════════════════════════
   ANALYTICS PAGE
   ═════════════════════════════════════════════════ */
.analytics-section{padding:20px 16px 64px}
.analytics-container{max-width:1000px;margin:0 auto}
.analytics-header{margin-bottom:24px}
.analytics-header h1{font-size:clamp(22px,6vw,30px);font-weight:800;color:#fff;margin-bottom:8px}
.analytics-link-info{display:flex;align-items:center;gap:8px;flex-wrap:wrap;font-size:13px;margin-bottom:8px}
.analytics-link-info .short-url{color:var(--primary-light);font-weight:700;font-size:14px}
.analytics-link-info .arrow{color:var(--text-faint)}
.analytics-link-info .dest-url{color:var(--text-muted);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:300px}
.back-link{display:inline-flex;align-items:center;gap:6px;color:var(--text-muted);text-decoration:none;font-size:13px;font-weight:600;margin-bottom:16px;padding:8px 14px;background:var(--surface);border:1px solid var(--border);border-radius:var(--r-sm);transition:all .2s}
.back-link:hover{color:var(--primary-light);border-color:var(--primary);background:var(--surface2)}
.filter-bar{overflow:visible}
.filter-row{display:flex;flex-wrap:wrap;gap:12px;align-items:flex-end}
.filter-group{display:flex;flex-direction:column;gap:4px}
.filter-group label{font-size:11px;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px}
.filter-input,.filter-select{padding:7px 10px;background:rgba(255,255,255,.04);border:1px solid var(--border);border-radius:8px;color:var(--text);font-size:13px;font-family:var(--font);outline:none}
.filter-input:focus,.filter-select:focus{border-color:var(--primary)}
.filter-select option{background:#060e16;color:#E0F7FF}
.date-toggle.active{background:var(--primary)!important;color:#fff!important;border-color:var(--primary)!important}
.loading-state{text-align:center;padding:48px 16px;color:var(--text-muted)}
.loading-state .spinner{width:32px;height:32px;border:3px solid var(--border);border-top-color:var(--primary);border-radius:50%;animation:spin .7s linear infinite;margin:0 auto 12px}
@keyframes spin{to{transform:rotate(360deg)}}
.charts-row{display:grid;gap:16px;margin-bottom:24px}
.charts-row-2{grid-template-columns:repeat(2,1fr)}
@media(max-width:768px){.charts-row-2{grid-template-columns:1fr}}
.chart-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r);padding:18px}
.chart-card-full{background:var(--surface);border:1px solid var(--border);border-radius:var(--r);padding:18px}
.chart-card-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}
.chart-card-header h3{font-size:15px;font-weight:700;margin:0}
.btn-toggle-json{font-size:11px;padding:4px 10px}
.json-view{background:rgba(0,0,0,.3);border:1px solid var(--border);border-radius:8px;padding:12px;font-size:12px;color:var(--text-muted);max-height:300px;overflow-y:auto;white-space:pre-wrap;word-break:break-all}
.recent-clicks-card{margin-bottom:24px}
.view-more-wrap{text-align:center;margin-top:12px}
.analytics-locked-overlay{background:var(--surface);border:1px solid rgba(245,158,11,.25);border-radius:var(--r-lg);padding:48px 20px;text-align:center;margin-bottom:24px;box-shadow:0 0 40px rgba(245,158,11,.06)}
.analytics-locked-overlay svg{margin-bottom:16px;color:var(--warning)}
.analytics-locked-overlay h2{font-size:22px;font-weight:800;color:#fff;margin-bottom:10px}
.analytics-locked-overlay p{color:var(--text-muted);font-size:14px;margin-bottom:20px;max-width:320px;margin-left:auto;margin-right:auto;line-height:1.6}
.link-count{font-size:12px;color:var(--text-muted);font-weight:400}
.copy-touch{cursor:pointer}
.trend-toggles{display:flex;gap:4px}
.dest-cell{max-width:200px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;cursor:pointer}
.status-admin{background:rgba(252,211,77,.12);color:#FCD34D}
.status-approved{background:rgba(16,185,129,.12);color:#10B981}
.status-pending{background:rgba(245,158,11,.12);color:#F59E0B}
.status-expired{background:rgba(239,68,68,.12);color:#f87171}

/* ══════════════════════════════════════════════════
   GLOBAL TEXT CLARITY — ensure no blur/shadows hide text
   ═════════════════════════════════════════════════ */
p,span,label,td,th,li{text-shadow:none}
h1,h2,h3,h4,h5,h6{text-shadow:none}
.tp-name,.tp-cat,.tp-direct-label{text-shadow:none;color:#E0F7FF}
.dash-link-alias,.dash-link-dest,.dash-link-date,.dash-link-clicks{text-shadow:none}
.stat-number,.stat-label,.stat-n,.stat-l{text-shadow:none}
.card h3,.dash-card-head h2,.section-head h2{color:#fff;text-shadow:none}

/* Ensure all field inputs have readable text */
.field-input,.utr-input{color:#E0F7FF}
.field-input::placeholder,.utr-input::placeholder{color:rgba(224,247,255,.35)}

/* Dashboard action buttons tooltip labels */
.dash-action-btn{position:relative}
.dash-action-btn[title]:hover::after{
  content:attr(title);position:absolute;bottom:calc(100% + 6px);left:50%;transform:translateX(-50%);
  background:#0e1626;color:#fff;font-size:11px;font-weight:600;white-space:nowrap;
  padding:4px 8px;border-radius:6px;border:1px solid rgba(255,255,255,.12);
  pointer-events:none;z-index:100;
  box-shadow:0 4px 12px rgba(0,0,0,.4)}

/* ══════════════════════════════════════════════════
   MOBILE NAV — open-state button visibility fix
   ═════════════════════════════════════════════════ */
@media(max-width:640px){
  .nav-links.open .nav-btn{color:var(--text)!important}
  .nav-links.open .nav-btn-outline{
    background:rgba(255,255,255,.07)!important;
    border-color:rgba(255,255,255,.22)!important;
    color:var(--text)!important}
  .nav-links.open .nav-btn-primary{
    background:#00C8FF!important;
    color:#fff!important}
  .nav-links.open .nav-btn-admin{color:#FCD34D!important}
}

/* ══════════════════════════════════════════════════
   DEMO THEMES PAGE  (/demo_themes)
   ═════════════════════════════════════════════════ */
.demo-themes-page{padding:24px 16px 64px;max-width:560px;margin:0 auto}
.demo-themes-header{text-align:center;margin-bottom:28px}
.demo-themes-header h1{font-size:clamp(24px,7vw,38px);font-weight:900;letter-spacing:-1.5px;color:#fff;margin-bottom:8px}
.demo-themes-header p{color:var(--text-muted);font-size:14px;line-height:1.5}
.demo-themes-list{display:flex;flex-direction:column;gap:16px}
.dt-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);overflow:hidden;
  transition:all .3s var(--ease);transform:perspective(600px) translateZ(0);
  box-shadow:0 4px 16px rgba(0,0,0,.25)}
.dt-card:hover{transform:perspective(600px) translateZ(8px);border-color:var(--primary);
  box-shadow:0 12px 40px rgba(0,0,0,.4),0 0 30px rgba(0,200,255,.12)}
.dt-thumb{width:100%;height:160px;display:block;object-fit:cover;position:relative;overflow:hidden;
  background:var(--surface2);display:flex;align-items:center;justify-content:center}
.dt-thumb-img{width:100%;height:100%;object-fit:cover}
.dt-thumb-grad{width:100%;height:100%;position:absolute;inset:0;display:flex;align-items:center;justify-content:center}
.dt-thumb-logo{max-width:80%;max-height:80%;object-fit:contain;border-radius:10px}
.dt-thumb-placeholder{font-size:40px;opacity:.4}
.dt-body{padding:14px 16px 16px;display:flex;align-items:center;justify-content:space-between;gap:12px}
.dt-info{flex:1;min-width:0}
.dt-name{font-size:15px;font-weight:700;color:#fff;margin-bottom:3px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.dt-cat{display:inline-flex;padding:2px 8px;border-radius:99px;font-size:10px;font-weight:700;
  text-transform:uppercase;letter-spacing:.4px;background:rgba(124,58,237,.12);color:#C084FC}
.dt-preview-btn{padding:9px 18px;border:none;border-radius:var(--r-sm);
  background:#00C8FF;color:#fff;
  font-size:13px;font-weight:700;cursor:pointer;text-decoration:none;
  display:inline-flex;align-items:center;gap:6px;
  box-shadow:0 4px 16px rgba(0,200,255,.3);
  transition:all .3s var(--ease);white-space:nowrap;flex-shrink:0}
.dt-preview-btn:hover{transform:scale(1.04);box-shadow:0 6px 22px rgba(0,200,255,.45)}
.dt-direct-thumb{width:100%;height:160px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;
  background:linear-gradient(135deg,rgba(0,200,255,.06),rgba(0,200,255,.06));color:var(--text-muted)}
.dt-direct-label{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:var(--primary-light)}

/* Stats bar strip for 4-stat variant */
.stats-card .stat:last-child{border-right:none}
.stat-themes .stat-n{color:#A855F7}

/* ══════════════════════════════════════════════════
   PREVIEW MODAL (iframe overlay)
   ═════════════════════════════════════════════════ */
.preview-overlay{position:fixed;inset:0;z-index:2000;background:rgba(0,0,0,.85);backdrop-filter:blur(12px);
  display:none;align-items:center;justify-content:center;padding:16px}
.preview-overlay.active{display:flex}
.preview-modal{width:100%;max-width:420px;height:calc(100vh - 32px);
  background:var(--bg2);border:1px solid var(--border);border-radius:var(--r-lg);
  overflow:hidden;display:flex;flex-direction:column;position:relative;
  box-shadow:0 24px 80px rgba(0,0,0,.7),0 0 40px rgba(0,200,255,.1);
  animation:prevScale .3s var(--ease)}
@keyframes prevScale{from{transform:scale(.93);opacity:0}to{transform:scale(1);opacity:1}}
.preview-modal-header{display:flex;align-items:center;justify-content:space-between;padding:12px 14px;
  background:rgba(0,200,255,.06);border-bottom:1px solid var(--border);flex-shrink:0}
.preview-modal-label{font-size:12px;font-weight:700;color:var(--primary-light);
  display:flex;align-items:center;gap:6px}
.preview-modal-label::before{content:'👁';font-size:14px}
.preview-modal-close{background:var(--surface2);border:1px solid var(--border);color:var(--text-muted);
  width:28px;height:28px;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:14px;
  transition:all .2s}
.preview-modal-close:hover{background:rgba(239,68,68,.2);color:#f87171;border-color:rgba(239,68,68,.3)}
.preview-iframe-wrap{flex:1;overflow-y:auto;-webkit-overflow-scrolling:touch;position:relative;min-height:0}
.preview-iframe{width:100%;height:100%;min-height:660px;border:none;display:block}
.preview-note{padding:8px 14px;font-size:11px;color:var(--text-muted);text-align:center;
  background:rgba(0,0,0,.3);border-top:1px solid var(--border);flex-shrink:0;line-height:1.4}
.preview-note strong{color:var(--warning)}
/* Mobile: full-screen preview (no floating box) */
@media(max-width:640px){
  .preview-overlay{padding:0}
  .preview-modal{max-width:100%;height:100svh;height:100vh;border-radius:0;border-left:none;border-right:none}
}

/* ── Hero browse-themes CTA ── */
.browse-themes-btn{display:inline-flex;align-items:center;gap:8px;padding:11px 22px;
  border:1px solid rgba(0,200,255,.3);border-radius:var(--r);background:rgba(0,200,255,.06);
  color:var(--primary-light);font-size:13px;font-weight:700;text-decoration:none;
  transition:all .25s var(--ease);margin-bottom:20px}
.browse-themes-btn:hover{background:rgba(0,200,255,.12);border-color:var(--primary);color:#fff}

/* ── Preview btn in form ── */
.preview-link-btn{width:100%;padding:12px;border:1px solid rgba(124,58,237,.35);border-radius:var(--r-sm);
  background:rgba(124,58,237,.08);color:#C084FC;
  font-size:14px;font-weight:700;font-family:var(--font);cursor:pointer;
  display:inline-flex;align-items:center;justify-content:center;gap:8px;
  transition:all .25s var(--ease);margin-bottom:10px}
.preview-link-btn:hover:not(:disabled){background:rgba(124,58,237,.16);border-color:rgba(124,58,237,.6);color:#fff}
.preview-link-btn:disabled{opacity:.4;cursor:not-allowed}
