/* ================================================================
   PsikoTest Pro — Design System v4.0
   Direction: Refined Professional · Clean · Premium
   Font: Outfit (display) + DM Sans (body) — loaded via Google Fonts
   Colors: Deep Navy primary, Sky accent, Emerald success, Warm neutrals
   ================================================================ */

@import url('https://fonts.googleapis.com/css2?family=Outfit:wght@300;400;500;600;700;800;900&family=DM+Sans:ital,wght@0,300;0,400;0,500;0,600;0,700;1,400&display=swap');

/* ── TOKENS ────────────────────────────────────────────────── */
*, *::before, *::after { margin:0; padding:0; box-sizing:border-box; }

:root {
  /* Navy → Sky gradient brand */
  --navy:    #0c1e3d;
  --navy-2:  #1a3c6e;
  --navy-3:  #1d4ed8;
  --sky:     #2563eb;
  --sky-l:   #93c5fd;
  --sky-xl:  #dbeafe;
  --sky-2xl: #eff6ff;

  /* Emerald success */
  --emerald:   #2563eb;
  --emerald-d: #1d4ed8;
  --emerald-l: #dbeafe;

  /* Amber warning */
  --amber:   #f59e0b;
  --amber-l: #fef3c7;

  /* Coral accent */
  --coral:   #f97316;
  --coral-l: #fff7ed;

  /* Red danger */
  --red:   #E21D1D;
  --red-l: #FEF0F0;

  /* Neutral scale */
  --n0:   #FCFCFC;
  --n50:  #FCFCFC;
  --n100: #f0f7ff;
  --n200: #bfdbfe;
  --n300: #cbd5e1;
  --n400: #94a3b8;
  --n500: #64748b;
  --n600: #475569;
  --n700: #374151;
  --n800: #1e293b;
  --n900: #0c1e3d;

  /* Semantic aliases */
  --accent:     var(--sky);
  --accent-dim: var(--sky-2xl);
  --brand-50:   var(--sky-2xl);
  --brand-100:  var(--sky-xl);
  --brand-200:  #bfdbfe;
  --brand-500:  var(--sky);
  --brand-600:  #1d4ed8;
  --brand-700:  #1d4ed8;
  --brand-800:  #1a3c6e;
  --brand-900:  var(--navy-2);
  --teal-500:   var(--emerald);
  --teal-600:   var(--emerald-d);
  --teal-700:   #1d4ed8;
  --green:      var(--emerald);
  --gold:       var(--amber);
  --purple:     #2563eb;
  --gray-50:    var(--n50);
  --gray-100:   var(--n100);
  --gray-200:   var(--n200);
  --gray-300:   var(--n300);
  --gray-400:   var(--n400);
  --gray-500:   var(--n500);
  --gray-600:   var(--n600);
  --gray-700:   var(--n700);
  --gray-800:   var(--n800);
  --gray-900:   var(--n900);

  /* Typography */
  --font-head: 'Outfit', system-ui, sans-serif;
  --font-body: 'DM Sans', system-ui, sans-serif;

  /* Radius */
  --r:    10px;
  --r-sm:  8px;
  --r-xl: 16px;
  --r-2xl:20px;
  --r-3xl:28px;

  /* Transitions */
  --t:    .16s ease;
  --ease: cubic-bezier(.4,0,.2,1);

  /* Shadows — premium layered */
  --sh:     0 1px 2px rgba(15,23,42,.04), 0 2px 8px rgba(15,23,42,.06);
  --sh-md:  0 4px 12px rgba(15,23,42,.07), 0 1px 3px rgba(15,23,42,.05);
  --sh-lg:  0 8px 28px rgba(15,23,42,.10), 0 2px 6px rgba(15,23,42,.06);
  --sh-xl:  0 20px 60px rgba(15,23,42,.14), 0 4px 16px rgba(15,23,42,.08);
  --sh-sky: 0 4px 20px rgba(37,99,235,.28);
  --sh-em:  0 4px 16px rgba(37,99,235,.25);
}

html { scroll-behavior:smooth; font-size:16px; }
body {
  font-family: var(--font-body);
  color: var(--n800);
  background: var(--n0);
  line-height: 1.6;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}
a { color: var(--brand-600); text-decoration:none; }
a:hover { text-decoration:underline; }
img { max-width:100%; display:block; }
input,textarea,select,button { font-family:inherit; }
.container { max-width:1180px; margin:0 auto; padding:0 24px; }

/* ── TOPBAR ──────────────────────────────────────────────── */
.topbar {
  background: var(--navy);
  color:rgba(255,255,255,.6);
  font-size:.75rem; padding:8px 0; display:none;
  letter-spacing:.01em;
}
.topbar .container{display:flex;align-items:center;justify-content:space-between}
.topbar-links{display:flex;gap:20px}
.topbar-links a{color:rgba(255,255,255,.6);display:flex;align-items:center;gap:5px;transition:color var(--t)}
.topbar-links a:hover{color:#fff;text-decoration:none}
.topbar-social{display:flex;gap:10px}
.topbar-social a{color:rgba(255,255,255,.4);font-size:.7rem;font-weight:600;transition:color var(--t)}
.topbar-social a:hover{color:#fff;text-decoration:none}
@media(min-width:768px){.topbar{display:block}}

/* ── NAVBAR ──────────────────────────────────────────────── */
.navbar-wrap{
  position:sticky;top:0;z-index:5000;
  background:rgba(255,255,255,.95);
  backdrop-filter:blur(20px) saturate(180%);
  -webkit-backdrop-filter:blur(20px) saturate(180%);
  border-bottom:1px solid var(--n100);
  transition:box-shadow var(--t);
  overflow:visible;
}
.navbar-wrap.scrolled{box-shadow:var(--sh-md)}
.container > .navbar{display:flex;align-items:center;justify-content:space-between;height:68px;gap:32px;overflow:visible}
.nav-brand{display:flex;align-items:center;gap:10px;font-family:var(--font-head);font-weight:800;color:var(--navy);font-size:1.15rem;text-decoration:none;flex-shrink:0}
.nav-brand:hover{text-decoration:none;color:var(--sky)}
.nav-brand-logo{height:34px;width:auto}
.nav-brand-icon{
  width:36px;height:36px;border-radius:10px;
  background:linear-gradient(135deg,var(--sky),var(--brand-700));
  display:flex;align-items:center;justify-content:center;font-size:1.1rem;
  box-shadow:var(--sh-sky);
}
.nav-links{display:none;list-style:none;gap:2px;align-items:center;flex-wrap:nowrap;flex:1;min-width:0;justify-content:flex-end;overflow:visible}
@media(min-width:900px){.nav-links{display:flex}}
.nav-links > li{flex-shrink:0;white-space:nowrap}
.nav-links li a{
  color:var(--n600);font-size:.875rem;font-weight:500;
  padding:7px 14px;border-radius:8px;transition:all var(--t);text-decoration:none;display:block;white-space:nowrap;
}
.nav-links li a:hover,.nav-links li a.active{color:var(--sky);background:var(--sky-2xl)}
.nav-dd{position:relative;z-index:1}
.nav-dd:hover,.nav-dd:focus-within,.nav-dd.is-open{z-index:100}
.nav-dd > a{display:flex;align-items:center;gap:6px;white-space:nowrap}
.nav-dd-caret{font-size:.75rem;opacity:.7}
.nav-dd-menu{
  position:absolute !important;
  left:0 !important;
  top:100% !important;
  right:auto !important;
  margin:0 !important;
  float:none !important;
  min-width:260px;
  max-width:340px;
  max-width:min(340px,calc(100vw - 32px));
  width:auto;
  box-sizing:border-box;
  background:#fff;border:1px solid var(--n100);border-radius:14px;
  box-shadow:var(--sh-lg);
  padding:8px;
  display:none !important;
  z-index:6000;
}
.nav-dd-menu::before{
  content:'';
  position:absolute;
  left:0; right:0;
  top:-10px;
  height:10px;
}
.nav-dd:hover .nav-dd-menu,
.nav-dd:focus-within .nav-dd-menu,
.nav-dd.is-open .nav-dd-menu{display:block !important}
@media(max-width:899px){
  .nav-links .nav-dd-menu{display:none!important}
}
.nav-dd-item{
  display:flex;gap:10px;align-items:flex-start;
  padding:10px 10px;border-radius:12px;
  text-decoration:none;color:var(--n700);
  transition:background var(--t), color var(--t);
  max-width:100%;
}
.nav-dd-item > span:last-child{min-width:0}
.nav-dd-item:hover{background:var(--sky-2xl);color:var(--sky);text-decoration:none}
.nav-dd-ic{width:28px;height:28px;border-radius:10px;background:var(--sky-2xl);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.nav-dd-t{font-weight:800;font-size:.86rem;color:var(--n900);line-height:1.25;overflow-wrap:anywhere;word-break:break-word}
.nav-dd-p{font-size:.76rem;color:var(--n500);line-height:1.45;margin-top:2px;overflow-wrap:anywhere;word-break:break-word}
.nav-dd-item:hover .nav-dd-t{color:var(--sky)}
.nav-dd-item:hover .nav-dd-ic{background:#dbeafe}
.nav-actions{display:flex;align-items:center;gap:8px}
.nav-btn-ghost{color:var(--n600);font-size:.875rem;font-weight:500;padding:8px 16px;border-radius:8px;transition:all var(--t);display:none;text-decoration:none}
.nav-btn-ghost:hover{background:var(--n100);color:var(--n800);text-decoration:none}
.nav-btn-outline{font-size:.875rem;font-weight:600;padding:8px 16px;border-radius:9px;border:1.5px solid var(--n200);color:var(--n700);transition:all var(--t);display:none;text-decoration:none}
.nav-btn-outline:hover{border-color:var(--sky);color:var(--sky);text-decoration:none}
.nav-btn-primary{
  background:var(--navy);color:#fff;
  font-size:.875rem;font-weight:600;padding:9px 22px;border-radius:10px;
  transition:all var(--t);white-space:nowrap;text-decoration:none;
  box-shadow:0 2px 8px rgba(10,22,40,.2);
}
.nav-btn-primary:hover{background:var(--navy-3);text-decoration:none;transform:translateY(-1px);box-shadow:0 4px 14px rgba(10,22,40,.3)}
@media(min-width:768px){.nav-btn-ghost,.nav-btn-outline{display:block}}
.nav-hamburger{width:40px;height:40px;border-radius:8px;background:var(--n100);border:none;cursor:pointer;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:5px}
@media(min-width:900px){.nav-hamburger{display:none}}
.nav-hamburger span{width:20px;height:2px;background:var(--n600);border-radius:2px;transition:all var(--t);display:block}
.nav-mobile{display:none;position:fixed;inset:0;z-index:10000;background:#fff;flex-direction:column;padding:80px 24px 40px;gap:4px;overflow-y:auto}
.nav-mobile.open{display:flex}
.nav-mobile a{display:flex;align-items:center;gap:12px;padding:14px 16px;border-radius:12px;color:var(--n700);font-weight:500;font-size:.95rem;text-decoration:none;transition:all var(--t)}
.nav-mobile a:hover,.nav-mobile a.active{background:var(--sky-2xl);color:var(--sky)}
.nav-mobile-sep{height:1px;background:var(--n100);margin:12px 0}
.nav-overlay{display:none;position:fixed;inset:0;z-index:9999;background:rgba(0,0,0,.4)}
.nav-overlay.open{display:block}

/* ── BUTTONS ─────────────────────────────────────────────── */
.btn{
  display:inline-flex;align-items:center;justify-content:center;
  gap:8px;padding:10px 22px;border-radius:var(--r);
  font-family:var(--font-body);font-weight:600;font-size:.9rem;
  cursor:pointer;transition:all var(--t);border:1.5px solid transparent;
  text-decoration:none;white-space:nowrap;line-height:1;
}
.btn:hover{text-decoration:none;transform:translateY(-1px)}
.btn-primary{background:var(--navy);color:#fff;box-shadow:0 2px 8px rgba(10,22,40,.2)}
.btn-primary:hover{background:var(--navy-3);box-shadow:0 4px 16px rgba(10,22,40,.3)}
.btn-sky{background:linear-gradient(135deg,var(--sky),var(--brand-700));color:#fff;box-shadow:var(--sh-sky)}
.btn-sky:hover{filter:brightness(1.07)}
.btn-emerald{background:linear-gradient(135deg,var(--emerald),var(--emerald-d));color:#fff;box-shadow:var(--sh-em)}
.btn-emerald:hover{filter:brightness(1.07)}
.btn-secondary{background:var(--emerald);color:#fff}
.btn-secondary:hover{background:var(--emerald-d)}
.btn-outline{background:transparent;border-color:var(--n200);color:var(--n700)}
.btn-outline:hover{border-color:var(--sky);color:var(--sky);background:var(--sky-2xl)}
.btn-ghost{background:transparent;color:var(--sky)}
.btn-ghost:hover{background:var(--sky-2xl)}
.btn-danger{background:var(--red);color:#fff}
.btn-danger:hover{background:#E21D1D}
.btn-sm{padding:7px 14px;font-size:.8rem}
.btn-lg{padding:13px 30px;font-size:.95rem;border-radius:12px}
.btn-xl{padding:15px 36px;font-size:1rem;border-radius:14px}
.btn-block{width:100%}
.btn[disabled]{opacity:.5;cursor:not-allowed;transform:none}

/* ── PILLS / BADGES ─────────────────────────────────────── */
.pill{display:inline-flex;align-items:center;gap:4px;padding:3px 10px;border-radius:999px;font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em}
.pill-blue{background:var(--sky-2xl);color:var(--brand-700)}
.pill-green{background:var(--emerald-l);color:var(--emerald-d)}
.pill-red{background:var(--red-l);color:#B71515}
.pill-yellow{background:var(--amber-l);color:#b45309}
.pill-gray{background:var(--n100);color:var(--n500)}
.pill-purple{background:#eff6ff;color:#6d28d9}
.pill-teal{background:var(--emerald-l);color:var(--emerald-d)}
.pill-coral{background:var(--coral-l);color:var(--coral)}
.pill-navy{background:var(--navy-2);color:#fff}

/* ── ALERTS ─────────────────────────────────────────────── */
.alert{display:flex;align-items:flex-start;gap:12px;padding:13px 16px;border-radius:var(--r);font-size:.875rem;margin-bottom:16px;line-height:1.55}
.alert-success{background:var(--emerald-l);border:1px solid #93c5fd;color:#1a3c6e}
.alert-error{background:var(--red-l);border:1px solid #F9A0A0;color:#B71515}
.alert-info{background:var(--sky-2xl);border:1px solid var(--brand-200);color:var(--brand-700)}
.alert-warn{background:var(--amber-l);border:1px solid #fcd34d;color:#92400e}

/* ── FORMS ───────────────────────────────────────────────── */
.form-group{margin-bottom:18px}
.form-label{display:block;font-size:.82rem;font-weight:600;color:var(--n700);margin-bottom:6px}
.form-input,.form-select,.form-textarea{
  width:100%;padding:11px 14px;background:var(--n0);
  border:1.5px solid var(--n200);border-radius:var(--r);
  color:var(--n800);font-size:.9rem;
  transition:border-color var(--t),box-shadow var(--t);
}
.form-input:focus,.form-select:focus,.form-textarea:focus{
  outline:none;border-color:var(--sky);box-shadow:0 0 0 3px rgba(37,99,235,.1);
}
.form-textarea{min-height:100px;resize:vertical}
.form-hint{font-size:.75rem;color:var(--n400);margin-top:4px}

/* ── HEADINGS ───────────────────────────────────────────── */
.heading-xl{font-family:var(--font-head);font-size:clamp(2.2rem,5vw,3.6rem);font-weight:800;line-height:1.12;letter-spacing:-.025em}
.heading-lg{font-family:var(--font-head);font-size:clamp(1.6rem,3.5vw,2.4rem);font-weight:700;line-height:1.2}
.heading-md{font-family:var(--font-head);font-size:1.4rem;font-weight:700}
.text-gradient{background:linear-gradient(135deg,var(--sky),var(--emerald));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.lead{font-size:1.08rem;line-height:1.75;color:var(--n500)}
.lead-dark{color:rgba(255,255,255,.75)}

/* ── PAGE HERO ───────────────────────────────────────────── */
.page-hero{
  background:linear-gradient(135deg,var(--navy) 0%,var(--navy-3) 60%,#1d4ed8 100%);
  padding:64px 0 48px;color:#fff;text-align:center;position:relative;overflow:hidden;
}
.page-hero::after{
  content:'';position:absolute;inset:0;
  background:radial-gradient(ellipse 60% 80% at 80% 20%,rgba(37,99,235,.15) 0%,transparent 60%);
}
.breadcrumb{display:flex;align-items:center;justify-content:center;gap:8px;font-size:.8rem;color:rgba(255,255,255,.55);margin-bottom:14px;flex-wrap:wrap;position:relative;z-index:1}
.breadcrumb a{color:rgba(255,255,255,.7);text-decoration:none}
.breadcrumb a:hover{color:#fff}
.breadcrumb-sep{color:rgba(255,255,255,.3)}

/* ── SECTION HEADERS ─────────────────────────────────────── */
.section-header{text-align:center;margin-bottom:52px}
.section-badge{display:inline-flex;align-items:center;gap:6px;padding:5px 16px;background:var(--sky-2xl);color:var(--brand-700);border-radius:999px;font-size:.75rem;font-weight:700;letter-spacing:.05em;margin-bottom:14px}
.section-title{font-family:var(--font-head);font-size:clamp(1.6rem,3.5vw,2.4rem);font-weight:700;color:var(--navy);margin-bottom:14px;line-height:1.2}
.section-desc{font-size:.95rem;color:var(--n500);max-width:520px;margin:0 auto;line-height:1.75}

/* ── GRIDS ──────────────────────────────────────────────── */
.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:24px}
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.grid-4{display:grid;grid-template-columns:repeat(4,1fr);gap:20px}
@media(max-width:1024px){.grid-4{grid-template-columns:repeat(2,1fr)}}
@media(max-width:768px){.grid-3,.grid-4{grid-template-columns:1fr 1fr}.grid-2{grid-template-columns:1fr}}
@media(max-width:480px){.grid-3,.grid-4{grid-template-columns:1fr}}

/* ── CARDS ──────────────────────────────────────────────── */
.card{background:var(--n0);border-radius:var(--r-2xl);border:1px solid var(--n100);box-shadow:var(--sh);overflow:hidden;transition:transform var(--t),box-shadow var(--t)}
.card:hover{transform:translateY(-3px);box-shadow:var(--sh-lg)}
.card-body{padding:28px}
.card-title{font-family:var(--font-head);font-weight:700;font-size:1rem;color:var(--n900);margin-bottom:8px}
.card-text{font-size:.875rem;color:var(--n500);line-height:1.65}

/* ── TEST CARDS ─────────────────────────────────────────── */
.test-card{
  background:var(--n0);border-radius:var(--r-2xl);border:1.5px solid var(--n100);
  padding:26px 22px;transition:all var(--t);position:relative;overflow:hidden;
  display:flex;flex-direction:column;
}
.test-card::after{
  content:'';position:absolute;top:0;left:0;right:0;height:3px;
  background:linear-gradient(90deg,var(--sky),var(--emerald));
  transform:scaleX(0);transform-origin:left;transition:transform .3s ease;
}
.test-card:hover::after{transform:scaleX(1)}
.test-card:hover{border-color:var(--sky-xl);transform:translateY(-3px);box-shadow:var(--sh-lg)}
.test-card-icon{width:50px;height:50px;border-radius:14px;display:flex;align-items:center;justify-content:center;font-size:1.35rem;margin-bottom:14px;flex-shrink:0}
.test-card-name{font-family:var(--font-head);font-weight:700;font-size:.95rem;color:var(--n900);margin-bottom:7px}
.test-card-desc{font-size:.82rem;color:var(--n500);line-height:1.6;flex:1;margin-bottom:14px}
.test-card-footer{display:flex;align-items:center;justify-content:space-between;padding-top:12px;border-top:1px solid var(--n100);margin-top:auto}
.test-card-meta{font-size:.75rem;color:var(--n400);display:flex;align-items:center;gap:4px}

/* ── STAT CARDS ─────────────────────────────────────────── */
.stat-card{background:var(--n0);border-radius:var(--r-xl);padding:26px;border:1px solid var(--n100);box-shadow:var(--sh);text-align:center}
.stat-card-num{font-family:var(--font-head);font-size:2.4rem;font-weight:800;color:var(--navy);line-height:1;margin-bottom:6px}
.stat-card-lbl{font-size:.82rem;color:var(--n500);font-weight:500}

/* ── AUTH PAGES ─────────────────────────────────────────── */
.auth-shell,.auth-page{
  min-height:100vh;display:flex;align-items:center;justify-content:center;
  background:linear-gradient(160deg,var(--sky-2xl) 0%,var(--n0) 50%,var(--emerald-l) 100%);
  padding:40px 16px;position:relative;overflow:hidden;
}
.auth-shell::before{
  content:'';position:absolute;top:-200px;right:-200px;width:500px;height:500px;
  border-radius:50%;background:radial-gradient(circle,rgba(37,99,235,.06) 0%,transparent 70%);
}
.auth-card{
  background:var(--n0);border-radius:var(--r-3xl);padding:44px 40px;width:100%;max-width:440px;
  box-shadow:var(--sh-xl);border:1px solid var(--n100);position:relative;z-index:1;
}
.auth-logo{text-align:center;margin-bottom:28px}
.auth-logo-icon{
  width:56px;height:56px;border-radius:16px;
  background:linear-gradient(135deg,var(--sky),var(--brand-700));
  display:flex;align-items:center;justify-content:center;font-size:1.7rem;
  margin:0 auto 14px;box-shadow:var(--sh-sky);
}
.auth-logo h1{font-family:var(--font-head);font-size:1.3rem;font-weight:800;color:var(--navy)}
.auth-logo p{font-size:.85rem;color:var(--n500);margin-top:4px}
.auth-title{font-family:var(--font-head);font-size:1.5rem;font-weight:800;color:var(--navy);text-align:center;margin-bottom:6px}
.auth-sub{text-align:center;color:var(--n500);font-size:.875rem;margin-bottom:28px}
.auth-error{background:var(--red-l);border:1.5px solid #F9A0A0;color:#B71515;border-radius:10px;padding:12px 14px;font-size:.875rem;margin-bottom:16px}
.auth-divider{display:flex;align-items:center;gap:12px;margin:20px 0}
.auth-divider::before,.auth-divider::after{content:'';flex:1;height:1px;background:var(--n200)}
.auth-divider span{font-size:.75rem;color:var(--n400);white-space:nowrap}
.auth-form-label{display:block;font-size:.82rem;font-weight:600;color:var(--n700);margin-bottom:6px;display:flex;justify-content:space-between;align-items:center}
.auth-form-label a{font-weight:500;color:var(--sky);font-size:.78rem}
.auth-input{
  width:100%;padding:11px 14px;border:1.5px solid var(--n200);border-radius:10px;
  font-size:.9rem;color:var(--n800);background:var(--n0);
  transition:border-color .2s,box-shadow .2s;font-family:var(--font-body);
}
.auth-input:focus{outline:none;border-color:var(--sky);box-shadow:0 0 0 3px rgba(37,99,235,.1)}
.auth-footer{text-align:center;margin-top:16px;font-size:.875rem;color:var(--n500)}
.google-btn{
  display:flex;align-items:center;justify-content:center;gap:10px;width:100%;
  padding:11px;border:1.5px solid var(--n200);border-radius:10px;background:var(--n0);
  color:var(--n700);font-size:.9rem;font-weight:600;cursor:pointer;transition:all .2s;text-decoration:none;
  font-family:var(--font-body);
}
.google-btn:hover{border-color:var(--n300);background:var(--n50);color:var(--n800);text-decoration:none}

/* ── FOOTER ─────────────────────────────────────────────── */
.footer{
  background:var(--navy);
  color:rgba(255,255,255,.55);padding:68px 0 0;margin-top:auto;
}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:48px;margin-bottom:48px}
.footer-brand{margin-bottom:14px;display:flex;align-items:center;gap:10px}
.footer-brand-name{font-family:var(--font-head);font-weight:800;color:#fff;font-size:1.05rem}
.footer-desc{font-size:.85rem;line-height:1.75;margin-bottom:20px}
.footer-social{display:flex;gap:8px;flex-wrap:wrap}
.footer-social a{width:34px;height:34px;border-radius:8px;background:rgba(255,255,255,.07);color:rgba(255,255,255,.5);display:flex;align-items:center;justify-content:center;font-size:.8rem;font-weight:700;transition:all var(--t);text-decoration:none}
.footer-social a:hover{background:var(--sky);color:#fff}
.footer-heading{font-family:var(--font-head);font-size:.75rem;font-weight:700;color:rgba(255,255,255,.85);text-transform:uppercase;letter-spacing:.1em;margin-bottom:14px}
.footer-links{list-style:none;display:flex;flex-direction:column;gap:9px}
.footer-links a{color:rgba(255,255,255,.7);font-size:.85rem;transition:color var(--t);text-decoration:none}
.footer-links a:hover{color:#fff}
.footer-contact-list a{color:rgba(255,255,255,.85);text-decoration:none;transition:color var(--t)}
.footer-contact-list a:hover{color:#fff}
.footer-bottom{border-top:1px solid rgba(255,255,255,.07);padding:18px 0;display:flex;align-items:center;justify-content:space-between;gap:16px;font-size:.8rem;flex-wrap:wrap}
.footer-bottom-links{display:flex;gap:20px}
.footer-bottom-links a{color:rgba(255,255,255,.6);text-decoration:none}
.footer-bottom-links a:hover{color:rgba(255,255,255,.7)}
@media(max-width:900px){.footer-grid{grid-template-columns:1fr 1fr}}
@media(max-width:560px){.footer-grid{grid-template-columns:1fr}.footer-bottom{flex-direction:column;text-align:center}}

/* ── WA + BACK TO TOP ────────────────────────────────────── */
.wa-btn{position:fixed;bottom:28px;right:28px;z-index:990;width:52px;height:52px;border-radius:50%;background:#25d366;color:#fff;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 20px rgba(37,211,102,.4);transition:all var(--t)}
.wa-btn:hover{transform:scale(1.1)}
.back-top{position:fixed;bottom:90px;right:28px;z-index:989;width:40px;height:40px;border-radius:50%;background:var(--n0);color:var(--sky);border:1.5px solid var(--n200);font-size:1rem;cursor:pointer;display:none;align-items:center;justify-content:center;box-shadow:var(--sh);transition:all var(--t)}
.back-top.show{display:flex}
.back-top:hover{background:var(--sky);color:#fff;border-color:var(--sky)}

/* ── ANIMATIONS ─────────────────────────────────────────── */
.fade-up{animation:fadeUp .5s var(--ease) both}
@keyframes fadeUp{from{opacity:0;transform:translateY(18px)}to{opacity:1;transform:none}}

/* ── ADMIN SIDEBAR ───────────────────────────────────────── */
.admin-layout{display:flex;min-height:100vh;background:var(--n50)}
.admin-sidebar{
  width:240px;flex-shrink:0;background:var(--navy);
  display:flex;flex-direction:column;position:fixed;left:0;top:0;bottom:0;z-index:100;overflow-y:auto;
  transition:transform var(--t);
}
.admin-main{flex:1;margin-left:240px;min-height:100vh;display:flex;flex-direction:column}
@media(max-width:900px){.admin-sidebar{transform:translateX(-100%)}.admin-sidebar.open{transform:none}.admin-main{margin-left:0}}
.sb-header{padding:22px 18px;border-bottom:1px solid rgba(255,255,255,.06)}
.sb-logo{display:flex;align-items:center;gap:10px;text-decoration:none}
.sb-logo-icon{width:36px;height:36px;border-radius:9px;background:linear-gradient(135deg,var(--sky),var(--brand-700));display:flex;align-items:center;justify-content:center;font-size:1.1rem;flex-shrink:0}
.sb-logo-name{font-family:var(--font-head);font-weight:800;color:#fff;font-size:.95rem}
.sb-logo-badge{font-size:.6rem;font-weight:700;color:rgba(255,255,255,.35);text-transform:uppercase;letter-spacing:.1em;margin-top:1px}
.sb-section{padding:16px 18px 5px;font-size:.65rem;font-weight:700;color:rgba(255,255,255,.28);text-transform:uppercase;letter-spacing:.12em}
.sb-nav{list-style:none;padding:0 10px}
.sb-nav-item a{display:flex;align-items:center;gap:10px;padding:9px 12px;border-radius:8px;color:rgba(255,255,255,.55);font-size:.85rem;font-weight:500;transition:all var(--t);text-decoration:none;margin-bottom:1px}
.sb-nav-item a:hover,.sb-nav-item a.active{background:rgba(255,255,255,.08);color:#fff}
.nav-icon{font-size:.9rem;flex-shrink:0}
.sb-nav-badge{margin-left:auto;background:var(--red);color:#fff;font-size:.62rem;font-weight:700;padding:2px 7px;border-radius:999px}
.sb-footer{margin-top:auto;padding:16px;border-top:1px solid rgba(255,255,255,.06)}
.sb-user{display:flex;align-items:center;gap:10px;margin-bottom:10px}
.sb-avatar{width:32px;height:32px;border-radius:50%;background:linear-gradient(135deg,var(--sky),var(--brand-700));display:flex;align-items:center;justify-content:center;font-weight:700;color:#fff;font-size:.82rem;flex-shrink:0}
.sb-user-name{font-weight:600;color:#fff;font-size:.85rem}
.sb-user-role{font-size:.7rem;color:rgba(255,255,255,.35)}
.sb-logout{display:block;text-align:center;padding:7px;background:rgba(255,255,255,.06);color:rgba(255,255,255,.55);border-radius:8px;font-size:.78rem;font-weight:600;transition:all var(--t);text-decoration:none}
.sb-logout:hover{background:rgba(255,255,255,.12);color:#fff}
.admin-topbar{background:var(--n0);border-bottom:1px solid var(--n100);padding:0 28px;height:60px;display:flex;align-items:center;justify-content:space-between;position:sticky;top:0;z-index:90;box-shadow:var(--sh)}
.admin-topbar-title{font-family:var(--font-head);font-weight:700;color:var(--navy);font-size:1rem}
.admin-topbar-right{display:flex;align-items:center;gap:10px}
.admin-body{padding:28px;flex:1}
.sidebar-toggle-btn{display:none;position:fixed;top:12px;left:12px;z-index:200;width:40px;height:40px;border-radius:9px;background:var(--navy);border:none;color:#fff;font-size:1rem;align-items:center;justify-content:center;cursor:pointer}
@media(max-width:900px){.sidebar-toggle-btn{display:flex}}

/* ── ADMIN CARDS ─────────────────────────────────────────── */
.stat-card-admin{background:var(--n0);border-radius:var(--r-xl);padding:22px 24px;border:1px solid var(--n100);box-shadow:var(--sh)}
.stat-card-icon{width:44px;height:44px;border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:1.3rem;margin-bottom:12px}
.stat-card-value{font-family:var(--font-head);font-size:1.8rem;font-weight:800;color:var(--navy);margin-bottom:4px;line-height:1}
.stat-card-label{font-size:.8rem;color:var(--n500);font-weight:500}
.admin-card{background:var(--n0);border-radius:var(--r-xl);border:1px solid var(--n100);box-shadow:var(--sh);overflow:hidden}
.admin-card-header{padding:16px 20px;border-bottom:1px solid var(--n100);display:flex;align-items:center;justify-content:space-between}
.admin-card-header h3{font-family:var(--font-head);font-size:.95rem;font-weight:700;color:var(--navy)}
.admin-card-body{padding:20px}
.admin-table-card{background:var(--n0);border-radius:var(--r-xl);border:1px solid var(--n100);box-shadow:var(--sh);overflow:hidden}
.table-header{padding:16px 20px;border-bottom:1px solid var(--n100);display:flex;align-items:center;justify-content:space-between}
.table-header h3{font-family:var(--font-head);font-size:.95rem;font-weight:700;color:var(--navy)}
.data-table{width:100%;border-collapse:collapse;font-size:.85rem}
.data-table th{background:var(--n50);color:var(--n500);font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.07em;padding:11px 16px;text-align:left;border-bottom:1px solid var(--n200)}
.data-table td{padding:13px 16px;border-bottom:1px solid var(--n100);color:var(--n700);vertical-align:middle}
.data-table tr:last-child td{border-bottom:none}
.data-table tr:hover td{background:var(--sky-2xl)}
.admin-form-section{background:var(--n0);border-radius:var(--r-xl);border:1px solid var(--n100);box-shadow:var(--sh);padding:28px;margin-bottom:24px}
.admin-form-section h3{font-family:var(--font-head);font-size:.95rem;font-weight:700;color:var(--navy);margin-bottom:16px;padding-bottom:12px;border-bottom:1px solid var(--n100)}
.admin-form-group{margin-bottom:16px}
.admin-form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.admin-form-label{display:block;font-size:.8rem;font-weight:600;color:var(--n600);margin-bottom:5px}
.admin-input,.admin-select,.admin-textarea{width:100%;padding:9px 12px;background:var(--n0);border:1.5px solid var(--n200);border-radius:8px;color:var(--n800);font-size:.875rem;font-family:var(--font-body);transition:border-color .15s,box-shadow .15s}
.admin-input:focus,.admin-select:focus,.admin-textarea:focus{outline:none;border-color:var(--sky);box-shadow:0 0 0 3px rgba(37,99,235,.08)}
.admin-textarea{min-height:80px;resize:vertical}
@media(max-width:640px){.admin-form-row{grid-template-columns:1fr}}
.color-swatch{width:24px;height:24px;border-radius:6px;display:inline-block;vertical-align:middle;margin-right:6px;border:1.5px solid rgba(0,0,0,.08)}

/* ── TEST SHELL (exam page) ──────────────────────────────── */
.test-shell{min-height:100svh;background:var(--n50);padding-top:70px}
.test-header{background:rgba(255,255,255,.97);backdrop-filter:blur(12px);border-bottom:1px solid var(--n200);padding:14px 0;position:sticky;top:68px;z-index:100;box-shadow:var(--sh)}
.test-progress-bar{height:3px;background:var(--n100);position:relative;overflow:hidden;border-radius:999px}
.test-progress-fill{height:100%;background:linear-gradient(90deg,var(--sky),var(--emerald));transition:width .4s var(--ease);border-radius:999px}

/* Question cards */
.q-card{background:var(--n0);border:1.5px solid var(--n100);border-radius:18px;padding:30px;margin-bottom:16px;display:none;box-shadow:var(--sh-md)}
.q-card.active{display:block;animation:fadeUp .28s var(--ease)}
.q-num{font-size:.7rem;font-weight:700;color:var(--n400);letter-spacing:.08em;text-transform:uppercase;margin-bottom:10px;display:flex;align-items:center;justify-content:space-between}
.q-text{font-family:var(--font-head);font-size:1.05rem;font-weight:600;color:var(--n900);line-height:1.55;margin-bottom:22px}

/* Options */
.opt-grid{display:grid;gap:9px}
.opt-grid-2{grid-template-columns:1fr 1fr}
.opt-btn{display:flex;align-items:center;gap:12px;padding:13px 16px;background:var(--n50);border:1.5px solid var(--n200);border-radius:11px;color:var(--n700);font-size:.875rem;cursor:pointer;transition:all var(--t);text-align:left}
.opt-btn:hover{background:var(--sky-2xl);border-color:var(--sky-xl);color:var(--navy)}
.opt-btn.selected{background:var(--sky-2xl);border-color:var(--sky);color:var(--navy)}
.opt-btn.selected .opt-dot{background:var(--sky);box-shadow:0 0 0 3px rgba(37,99,235,.2)}
.opt-dot{width:18px;height:18px;border-radius:50%;border:1.5px solid var(--n300);flex-shrink:0;transition:all var(--t)}
.likert-scale{display:flex;gap:7px;align-items:center}
.likert-btn{flex:1;padding:11px 5px;border:1.5px solid var(--n200);border-radius:10px;background:var(--n50);color:var(--n600);font-size:.78rem;font-weight:600;cursor:pointer;transition:all var(--t);text-align:center;font-family:var(--font-body)}
.likert-btn:hover{background:var(--sky-2xl);border-color:var(--sky-xl);color:var(--navy)}
.likert-btn.selected{background:var(--sky);border-color:var(--sky);color:#fff;box-shadow:var(--sh-sky)}
.nav-row{display:flex;align-items:center;justify-content:space-between;margin-top:20px;gap:12px}

/* Submit overlay */
.submit-overlay{display:none;position:fixed;inset:0;background:rgba(255,255,255,.92);z-index:9999;align-items:center;justify-content:center;backdrop-filter:blur(10px)}
.submit-overlay.show{display:flex}
.submit-card{background:var(--n0);border:1.5px solid var(--n100);border-radius:22px;padding:38px;text-align:center;max-width:400px;width:100%;box-shadow:var(--sh-xl)}

/* ── SCORE BARS ──────────────────────────────────────────── */
.score-bar{height:9px;background:var(--n100);border-radius:999px;overflow:hidden}
.score-fill{height:100%;border-radius:999px;background:linear-gradient(90deg,var(--sky),var(--emerald));transition:width 1s var(--ease)}

/* ── RESULT CARDS ────────────────────────────────────────── */
.result-card{background:var(--n0);border:1px solid var(--n100);border-radius:14px;padding:17px 20px;display:flex;align-items:center;gap:14px;text-decoration:none;color:inherit;transition:all .2s;margin-bottom:10px}
.result-card:hover{border-color:var(--sky-xl);transform:translateX(3px);box-shadow:var(--sh-md);text-decoration:none}
.result-card-icon{width:46px;height:46px;border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:1.25rem;flex-shrink:0}
.result-card-info{flex:1}
.result-card-title{font-weight:600;font-size:.9rem;color:var(--n800);margin-bottom:2px}
.result-card-date{font-size:.73rem;color:var(--n400)}

/* ── EXAM DONE ───────────────────────────────────────────── */
.exam-done-box{text-align:center;max-width:500px;margin:0 auto;padding:60px 20px}
.exam-done-icon{font-size:5rem;margin-bottom:18px}
.exam-done-title{font-family:var(--font-head);font-size:1.8rem;font-weight:800;color:var(--navy);margin-bottom:10px}

/* ── PAGINATION ──────────────────────────────────────────── */
.pagination{display:flex;gap:5px;justify-content:center;margin-top:20px;padding:16px 20px;border-top:1px solid var(--n100);flex-wrap:wrap}
.page-btn{width:36px;height:36px;border-radius:9px;display:flex;align-items:center;justify-content:center;text-decoration:none;font-weight:600;font-size:.85rem;border:1.5px solid var(--n200);color:var(--n600);background:var(--n0);transition:all .15s}
.page-btn.active,.page-btn:hover{background:var(--navy);color:#fff;border-color:var(--navy);text-decoration:none}

/* ── ENTERPRISE LAYOUT ───────────────────────────────────── */
.enterprise-layout{display:flex;min-height:100vh;background:var(--n50)}
.enterprise-sidebar{width:240px;flex-shrink:0;background:var(--navy-2);display:flex;flex-direction:column;position:fixed;left:0;top:0;bottom:0;z-index:100;overflow-y:auto;transition:transform var(--t)}
.enterprise-main{flex:1;margin-left:240px;min-height:100vh;display:flex;flex-direction:column}
@media(max-width:900px){.enterprise-sidebar{transform:translateX(-100%)}.enterprise-sidebar.open{transform:none}.enterprise-main{margin-left:0}}

/* ── BLOG ────────────────────────────────────────────────── */
.blog-content h2,.blog-content h3,.blog-content h4{font-family:var(--font-head);font-weight:700;color:var(--navy);margin:24px 0 12px;line-height:1.3}
.blog-content h2{font-size:1.4rem}
.blog-content h3{font-size:1.15rem}
.blog-content p{color:var(--n600);line-height:1.8;margin-bottom:16px}
.blog-content ul,.blog-content ol{padding-left:24px;margin-bottom:16px;color:var(--n600);line-height:1.8}
.blog-content img{width:100%;border-radius:12px;margin:16px 0}
.blog-content blockquote{border-left:3px solid var(--sky);padding:12px 20px;margin:20px 0;background:var(--sky-2xl);border-radius:0 10px 10px 0;color:var(--n700);font-style:italic}
.blog-content code{background:var(--n100);padding:2px 7px;border-radius:5px;font-size:.875em;font-family:'Consolas',monospace;color:var(--navy)}

/* ── UTILITIES ───────────────────────────────────────────── */
.font-mono{font-family:'Consolas','Courier New',monospace}
.text-center{text-align:center}
.text-sm{font-size:.875rem}
.text-xs{font-size:.75rem}
.text-muted{color:var(--n400)}
.text-danger{color:var(--red)}
.text-success{color:var(--emerald-d)}
.mt-2{margin-top:8px}
.mt-4{margin-top:16px}
.mb-4{margin-bottom:16px}
.p-4{padding:16px}
.hidden{display:none!important}
.flex{display:flex}
.items-center{align-items:center}
.gap-2{gap:8px}
.gap-4{gap:16px}
.flex-1{flex:1}
.rounded{border-radius:var(--r)}
.rounded-full{border-radius:999px}
.w-full{width:100%}
@media(max-width:768px){.auth-card{padding:32px 24px}.admin-body{padding:16px}.container{padding:0 16px}}

/* ================================================================
   UX IMPROVEMENTS v2.2 — Added for production quality
   ================================================================ */

/* ── Page Load Progress Bar ── */
#nprogress-bar{position:fixed;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,#2563eb,#93c5fd,#2563eb);z-index:9999;animation:progressIn .8s ease forwards;transform-origin:left}
@keyframes progressIn{from{transform:scaleX(0);opacity:1}to{transform:scaleX(1);opacity:0}}

/* ── Toast Notification System ── */
.toast-container{position:fixed;top:20px;right:20px;z-index:9998;display:flex;flex-direction:column;gap:10px;pointer-events:none;max-width:380px}
.toast{pointer-events:all;display:flex;align-items:flex-start;gap:12px;padding:14px 16px;background:#fff;border-radius:14px;box-shadow:0 4px 6px rgba(15,23,42,.04),0 12px 30px rgba(15,23,42,.12),0 0 0 1px rgba(15,23,42,.06);animation:toastIn .35s cubic-bezier(.34,1.56,.64,1) forwards;min-width:260px}
@keyframes toastIn{from{opacity:0;transform:translateX(20px) scale(.95)}to{opacity:1;transform:none}}
.toast.toast-out{animation:toastOut .25s ease forwards}
@keyframes toastOut{to{opacity:0;transform:translateX(20px) scale(.95);margin-top:-60px}}
.toast-icon{font-size:1.1rem;flex-shrink:0;margin-top:.05rem}
.toast-body{flex:1}
.toast-title{font-weight:600;font-size:.875rem;color:#0c1e3d;margin-bottom:2px}
.toast-msg{font-size:.8rem;color:#64748b;line-height:1.5}
.toast-close{background:none;border:none;cursor:pointer;color:#94a3b8;font-size:1.1rem;padding:0;line-height:1;flex-shrink:0;transition:color .15s}
.toast-close:hover{color:#475569}
.toast-success .toast-icon{color:#2563eb}
.toast-error   .toast-icon{color:#E21D1D}
.toast-warning .toast-icon{color:#f59e0b}
.toast-info    .toast-icon{color:#2563eb}
.toast-progress{position:absolute;bottom:0;left:0;height:2px;background:currentColor;border-radius:0 0 14px 14px;opacity:.3;animation:toastProg 4s linear forwards}
@keyframes toastProg{from{width:100%}to{width:0}}

/* ── Smooth Page Transitions ── */
.page-fade{animation:pageFadeIn .3s ease}
@keyframes pageFadeIn{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}

/* ── Better Focus Rings (accessibility) ── */
:focus-visible{outline:2px solid #2563eb;outline-offset:3px;border-radius:4px}
button:focus-visible,a:focus-visible,input:focus-visible,select:focus-visible,textarea:focus-visible{outline:2px solid #2563eb;outline-offset:2px}

/* ── Skeleton Loading ── */
.skeleton{background:linear-gradient(90deg,#f0f7ff 25%,#bfdbfe 50%,#f0f7ff 75%);background-size:200% 100%;animation:skeleton 1.5s ease infinite}
@keyframes skeleton{0%{background-position:200% 0}100%{background-position:-200% 0}}

/* ── Improved Form Focus States ── */
input[type="text"]:focus,
input[type="email"]:focus,
input[type="password"]:focus,
input[type="tel"]:focus,
input[type="number"]:focus,
select:focus,
textarea:focus{
  outline:none;
  border-color:#2563eb !important;
  box-shadow:0 0 0 3px rgba(37,99,235,.12) !important;
}

/* ── Pill/Badge improvements ── */
.pill{display:inline-flex;align-items:center;gap:4px;padding:3px 10px;border-radius:20px;font-size:.72rem;font-weight:700;letter-spacing:.03em;white-space:nowrap}
.pill-green{background:#dbeafe;color:#1a3c6e;border:1px solid #dbeafe}
.pill-blue{background:#dbeafe;color:#1d4ed8;border:1px solid #bfdbfe}
.pill-gray{background:#f0f7ff;color:#475569;border:1px solid #bfdbfe}
.pill-amber{background:#fef3c7;color:#92400e;border:1px solid #fde68a}
.pill-red{background:#FDEAEA;color:#8B1111;border:1px solid #FDD0D0}

/* ── Button Loading States ── */
.btn-loading{position:relative;pointer-events:none;opacity:.8}
.btn-loading::after{content:'';position:absolute;right:12px;top:50%;width:14px;height:14px;margin-top:-7px;border:2px solid rgba(255,255,255,.4);border-top-color:#fff;border-radius:50%;animation:spin .7s linear infinite}

/* ── Smooth hover cards ── */
.hover-lift{transition:transform .2s ease,box-shadow .2s ease}
.hover-lift:hover{transform:translateY(-2px);box-shadow:0 12px 32px rgba(15,23,42,.12)}

/* ── Animated gradient text ── */
.gradient-text{background:linear-gradient(135deg,#2563eb,#2563eb);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}

/* ── Scrollbar styling ── */
::-webkit-scrollbar{width:6px;height:6px}
::-webkit-scrollbar-track{background:transparent}
::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:3px}
::-webkit-scrollbar-thumb:hover{background:#94a3b8}

/* ── Selection color ── */
::selection{background:rgba(37,99,235,.2);color:#1d4ed8}

/* ── Table improvements ── */
.table-hover tbody tr:hover{background:#FCFCFC}
.table-hover tbody tr{transition:background .12s}

/* ── Smooth image loading ── */
img{transition:opacity .3s ease}
img.loading{opacity:0}
img.loaded{opacity:1}

/* ── Better disabled states ── */
[disabled],[disabled]:hover{opacity:.55;cursor:not-allowed;transform:none !important;box-shadow:none !important}

/* ── Responsive utilities ── */
@media(max-width:640px){
  .hide-mobile{display:none !important}
  .container{padding:0 16px}
}
@media(min-width:641px){
  .hide-desktop{display:none !important}
}

/* Override custom/legacy CSS: dropdown must never sit in flex row */
.navbar-wrap nav.navbar ul.nav-links > li.nav-dd{
  position:relative;
}
.navbar-wrap nav.navbar ul.nav-links > li.nav-dd > .nav-dd-menu{
  position:absolute !important;
  left:0 !important;
  top:100% !important;
  right:auto !important;
  margin:0 !important;
  float:none !important;
  min-width:260px !important;
  max-width:340px !important;
  max-width:min(340px,calc(100vw - 32px)) !important;
  display:none !important;
}
.navbar-wrap nav.navbar ul.nav-links > li.nav-dd:hover > .nav-dd-menu,
.navbar-wrap nav.navbar ul.nav-links > li.nav-dd:focus-within > .nav-dd-menu,
.navbar-wrap nav.navbar ul.nav-links > li.nav-dd.is-open > .nav-dd-menu{
  display:block !important;
}
@media(max-width:899px){
  .navbar-wrap nav.navbar ul.nav-links > li.nav-dd > .nav-dd-menu,
  .navbar-wrap nav.navbar ul.nav-links > li.nav-dd:hover > .nav-dd-menu,
  .navbar-wrap nav.navbar ul.nav-links > li.nav-dd:focus-within > .nav-dd-menu,
  .navbar-wrap nav.navbar ul.nav-links > li.nav-dd.is-open > .nav-dd-menu{
    display:none !important;
    visibility:hidden !important;
    pointer-events:none !important;
  }
}

/* ── Print improvements ── */
@media print{
  .navbar-wrap,.topbar,.footer{display:none}
  body{background:#fff}
  .card{box-shadow:none;border:1px solid #bfdbfe}
}

/* ================================================================
   Public Detail Pages — Blog/Portfolio
   ================================================================ */
.detail-layout{display:grid;grid-template-columns:minmax(0,1fr) 320px;gap:28px;align-items:start}
@media(max-width:980px){.detail-layout{grid-template-columns:1fr}}
.detail-content{min-width:0}
.detail-sidebar{position:sticky;top:92px}
@media(max-width:980px){.detail-sidebar{position:static;top:auto}}

.detail-panel{
  background:#fff;border:1px solid var(--n100);border-radius:var(--r-2xl);
  padding:18px;box-shadow:var(--sh);margin-bottom:14px
}
.detail-panel h4{font-family:var(--font-head);font-size:.95rem;font-weight:700;color:var(--n900);margin-bottom:10px}
.detail-kv{display:flex;flex-direction:column;gap:10px}
.detail-kv .row{display:flex;justify-content:space-between;gap:12px;font-size:.85rem;color:var(--n600)}
.detail-kv .row strong{color:var(--n900);font-weight:700}

.share-row{display:flex;flex-wrap:wrap;gap:8px}
.share-btn{
  display:inline-flex;align-items:center;gap:8px;padding:9px 12px;border-radius:12px;
  border:1.5px solid var(--n200);background:#fff;color:var(--n700);
  font-weight:700;font-size:.82rem;text-decoration:none;transition:all var(--t)
}
.share-btn:hover{border-color:var(--sky);color:var(--sky);background:var(--sky-2xl);text-decoration:none}

.related-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}
@media(max-width:980px){.related-grid{grid-template-columns:1fr 1fr}}
@media(max-width:520px){.related-grid{grid-template-columns:1fr}}
.related-card{
  display:block;background:#fff;border:1px solid var(--n100);border-radius:18px;
  overflow:hidden;box-shadow:var(--sh);text-decoration:none;color:inherit;transition:transform var(--t),box-shadow var(--t)
}
.related-card:hover{transform:translateY(-3px);box-shadow:var(--sh-lg);text-decoration:none}
.related-thumb{aspect-ratio:16/9;background:linear-gradient(135deg,var(--sky-xl),var(--sky-2xl));display:flex;align-items:center;justify-content:center;font-size:2.2rem;overflow:hidden}
.related-thumb img{width:100%;height:100%;object-fit:cover}
.related-body{padding:14px 14px 16px}
.related-title{font-family:var(--font-head);font-size:.95rem;font-weight:700;color:var(--n900);line-height:1.3;margin-bottom:6px}
.related-meta{font-size:.75rem;color:var(--n400);display:flex;gap:8px;flex-wrap:wrap}
