/* ═══════════════════════════════════════════════════════════
   apply.css — NEWS REPORT Journalist Application v4
   Modern · Authentic · Professional · Mobile & PC
   ═══════════════════════════════════════════════════════════ */

/* ── Google Fonts import ─── */
@import url('https://fonts.googleapis.com/css2?family=Poppins:wght@300;400;500;600;700;800;900&family=Space+Grotesk:wght@400;500;600;700&display=swap');

/* ═══════════════════════════════════════════════════
   CSS VARIABLES
   ═══════════════════════════════════════════════════ */
:root {
  /* ── DARK MODE (pure black) ── */
  --bg:        #000000;
  --bg2:       #050505;
  --sur:       #0a0a0a;
  --sur2:      #111111;
  --sur3:      #181818;
  --bdr:       #1f1f1f;
  --bdr2:      #2a2a2a;
  --bdr3:      #333333;

  /* ── Brand ── */
  --red:       #dd0000;
  --red2:      #ff2020;
  --red3:      #ff4444;
  --rdim:      rgba(221,0,0,.09);
  --rdim2:     rgba(221,0,0,.16);
  --rbdr:      rgba(221,0,0,.28);
  --rbdr2:     rgba(221,0,0,.55);

  /* ── Text ── */
  --txt:       #f5f5f5;
  --txt2:      #888888;
  --txt3:      #444444;
  --txt4:      #666666;

  /* ── Input ── */
  --inp:       #070707;
  --inp-bdr:   #222222;

  /* ── Status ── */
  --grn:       #00c853;
  --gdim:      rgba(0,200,83,.09);
  --gbdr:      rgba(0,200,83,.3);
  --org:       #ff9100;
  --odim:      rgba(255,145,0,.09);
  --obdr:      rgba(255,145,0,.3);
  --blue:      #2979ff;
  --bdim:      rgba(41,121,255,.09);
  --bbdr:      rgba(41,121,255,.3);

  /* ── Shadows ── */
  --sh:        0 12px 40px rgba(0,0,0,.8), 0 2px 8px rgba(0,0,0,.5);
  --sh2:       0 4px 24px rgba(0,0,0,.5);
  --sh3:       0 1px 8px rgba(0,0,0,.4);

  /* ── Social brand colours ── */
  --fb:        #1877f2;
  --tw:        #000000;
  --ig-from:   #f58529; --ig-via: #dd2a7b; --ig-to: #8134af;
  --yt:        #ff0000;
  --wa:        #25d366;
  --tg:        #2aabee;
  --li:        #0a66c2;

  /* ── Layout ── */
  --hh:        50px;
  --fh:        65px;
  --rad:       14px;
  --rad2:      10px;
  --rad3:      7px;
  --rad4:      20px;
}

/* ── LIGHT MODE ── */
[data-theme=light] {
  --bg:        #f7f7f7;
  --bg2:       #efefef;
  --sur:       #ffffff;
  --sur2:      #fafafa;
  --sur3:      #f2f2f2;
  --bdr:       #e5e5e5;
  --bdr2:      #d8d8d8;
  --bdr3:      #cccccc;
  --txt:       #0a0a0a;
  --txt2:      #555555;
  --txt3:      #aaaaaa;
  --txt4:      #888888;
  --inp:       #fdfdfd;
  --inp-bdr:   #e0e0e0;
  --rdim:      rgba(221,0,0,.06);
  --rdim2:     rgba(221,0,0,.12);
  --rbdr:      rgba(221,0,0,.22);
  --sh:        0 12px 40px rgba(0,0,0,.08), 0 2px 8px rgba(0,0,0,.04);
  --sh2:       0 4px 24px rgba(0,0,0,.07);
  --sh3:       0 1px 8px rgba(0,0,0,.05);
  --tw:        #1d9bf0;
}

/* ═══════════════════════════════════════════════════
   RESET
   ═══════════════════════════════════════════════════ */
*, *::before, *::after { margin:0; padding:0; box-sizing:border-box; }
html { scroll-behavior:smooth; -webkit-text-size-adjust:100%; }
body {
  font-family:'Poppins', 'Space Grotesk', sans-serif;
  background:var(--bg);
  color:var(--txt);
  min-height:100vh;
  display:flex;
  flex-direction:column;
  overflow-x:hidden;
  font-size:15px;
  line-height:1.6;
  padding-top:var(--hh);
  padding-bottom:var(--fh);
  transition:background .3s, color .3s;
}

/* Subtle dot-grid bg — dark only */
body::after {
  content:'';
  position:fixed; inset:0; z-index:0; pointer-events:none;
  background-image:radial-gradient(circle, rgba(255,255,255,.03) 1px, transparent 1px);
  background-size:28px 28px;
  opacity:1;
  transition:opacity .3s;
}
[data-theme=light] body::after { opacity:0; }

/* ═══════════════════════════════════════════════════
   STICKY HEADER
   ═══════════════════════════════════════════════════ */
.app-header {
  position:fixed;
  top:0; left:0; right:0;
  height:var(--hh);
  z-index:900;
  background:var(--sur);
  border-bottom:1px solid var(--bdr);
  box-shadow:0 1px 30px rgba(0,0,0,.5);
  transition:background .3s, border-color .3s;
}
[data-theme=light] .app-header { box-shadow:0 1px 16px rgba(0,0,0,.09); }

/* Animated red top line */
.app-header::before {
  content:'';
  position:absolute; top:0; left:0; right:0; height:3px;
  background:linear-gradient(90deg,
    transparent 0%,
    var(--red) 20%,
    var(--red2) 40%,
    #ff6600 50%,
    var(--red2) 60%,
    var(--red) 80%,
    transparent 100%);
  background-size:200% 100%;
  animation:shimmer 4s linear infinite;
}
@keyframes shimmer { 0%{background-position:200% 0} 100%{background-position:-200% 0} }

.header-inner {
  width:100%; height:100%;
  display:flex;
  align-items:center;
  justify-content:space-between;
  padding:0 5px;
  position:relative;
}

/* Left — circle logo */
.header-logo-link {
  display:flex; align-items:center;
  flex-shrink:0; text-decoration:none;
  width:44px; z-index:1;
}
.header-logo-circle {
  width:38px; height:38px; border-radius:50%;
  object-fit:cover;
  border:2px solid var(--rbdr);
  box-shadow:0 0 14px rgba(221,0,0,.22);
  transition:border-color .25s, box-shadow .25s, transform .25s;
}
.header-logo-link:hover .header-logo-circle {
  border-color:var(--red);
  box-shadow:0 0 22px rgba(221,0,0,.45);
  transform:scale(1.07);
}

/* Center — logo2 banner */
.header-logo-banner-wrap {
  position:absolute;
  left:50%; top:50%;
  transform:translate(-50%,-50%);
  display:flex; align-items:center;
  pointer-events:none;
}
.header-logo-banner {
  height:34px; width:auto; max-width:280px;
  object-fit:contain; display:block;
}

/* Right — theme toggle */
.theme-toggle {
  display:flex; align-items:center; gap:7px;
  background:var(--sur2);
  border:1px solid var(--bdr2);
  border-radius:50px;
  padding: 5px 10px;
  font-family:'Poppins', sans-serif;
  font-size:12px; font-weight:600;
  color:var(--txt2); cursor:pointer;
  transition:all .25s; flex-shrink:0;
  z-index:1;
}
.theme-toggle:hover {
  border-color:var(--red); color:var(--red);
  background:var(--rdim);
}
.theme-toggle i { font-size:13px; }

/* ═══════════════════════════════════════════════════
   PAGE HERO — full width, below header
   ═══════════════════════════════════════════════════ */
.page-hero {
  width:100%;
  background:var(--sur2);
  padding:5px 5px;
  text-align:center;
  position:relative; z-index:1; overflow:hidden;
}

.hero-eyebrow {
  display:inline-flex; align-items:center; gap:7px;
  font-size:15px; font-weight:700; letter-spacing:2.5px;
  text-transform:uppercase; color:var(--red);
  margin-bottom:14px; position:relative; z-index:1;
}
.hero-eyebrow::before,
.hero-eyebrow::after {
  content:'';
  display:inline-block; width:28px; height:1px;
  background:var(--red); opacity:.5;
}

.hero-title {
  font-size:30px; font-weight:800; letter-spacing:-.4px; line-height:1.15;
  margin-bottom:12px; position:relative; z-index:1;
  font-family:'Space Grotesk', sans-serif;
}
.hero-title span { color:var(--red); }

.hero-desc {
  font-size:14px; color:var(--txt2); line-height:1.85;
  max-width:620px; margin:0 auto 24px; position:relative; z-index:1;
}

.hero-badges {
  display:flex; justify-content:center; gap:10px; flex-wrap:wrap;
  position:relative; z-index:1;
}
.hbadge {
  display:inline-flex; align-items:center; gap:7px;
  padding:6px 16px; border-radius:50px;
  background:var(--rdim); border:1px solid var(--rbdr);
  font-size:11px; font-weight:600; color:var(--txt2); letter-spacing:.2px;
  transition:all .2s;
}
.hbadge i { color:var(--red); font-size:11px; }
.hbadge:hover { background:var(--rdim2); color:var(--txt); border-color:rgba(221,0,0,.45); }

/* ═══════════════════════════════════════════════════
   PAGE BODY — full width, 20px padding
   ═══════════════════════════════════════════════════ */
.page-body {
  width:100%;
  flex:1;
  padding:5px 5px;
  position:relative; z-index:1;
}

/* ═══════════════════════════════════════════════════
   STATE CARDS (Closed / Blocked / Success)
   ═══════════════════════════════════════════════════ */
.state-card {
  background:var(--sur); border:1px solid var(--bdr);
  border-radius:var(--rad); padding:44px 36px; text-align:center;
  box-shadow:var(--sh2); max-width:600px; margin:0 auto 32px;
  position:relative; overflow:hidden;
}
.state-card::before {
  content:''; position:absolute; top:0; left:0; right:0; height:3px;
  background:linear-gradient(90deg, var(--red), var(--red2), var(--red3), var(--red2), var(--red));
  background-size:200% 100%;
  animation:shimmer 4s linear infinite;
}
.success-card::before {
  background:linear-gradient(90deg, var(--grn), #00ff88, var(--grn));
  animation:none;
}

.state-card-icon {
  width:80px; height:80px; border-radius:50%;
  display:flex; align-items:center; justify-content:center;
  font-size:30px; margin:0 auto 18px;
  animation:popIn .5s cubic-bezier(.175,.885,.32,1.275);
}
.state-card-icon.red   { background:var(--rdim); border:2px solid var(--rbdr); color:var(--red); }
.state-card-icon.green { background:var(--gdim); border:2px solid var(--gbdr); color:var(--grn); }

@keyframes popIn { from{transform:scale(0) rotate(-15deg);opacity:0} to{transform:scale(1) rotate(0deg);opacity:1} }

.state-card-label {
  display:inline-flex; align-items:center; gap:6px;
  font-size:10px; font-weight:700; letter-spacing:2px;
  text-transform:uppercase; padding:5px 14px;
  border-radius:50px; margin-bottom:14px;
}
.state-card-label.red   { background:var(--rdim); border:1px solid var(--rbdr); color:var(--red); }
.state-card-label.green { background:var(--gdim); border:1px solid var(--gbdr); color:var(--grn); }

.state-card-title { font-size:22px; font-weight:800; margin-bottom:12px; line-height:1.3; font-family:'Space Grotesk', sans-serif; }
.state-card-body  { font-size:14px; color:var(--txt2); line-height:1.85; margin-bottom:24px; }
.state-card-note  { font-size:13px; color:var(--txt2); margin-bottom:14px; display:flex; align-items:center; justify-content:center; gap:7px; }
.state-card-note i { color:var(--blue); }

.state-back-link {
  display:inline-flex; align-items:center; gap:8px;
  color:var(--txt2); font-size:13px; font-weight:600;
  border:1.5px solid var(--bdr2); padding:10px 22px;
  border-radius:50px; text-decoration:none; transition:all .25s; margin-top:10px;
}
.state-back-link:hover { border-color:var(--red); color:var(--red); background:var(--rdim); }

.ref-number-badge {
  display:inline-flex; align-items:center; gap:9px;
  background:var(--rdim); border:1px solid var(--rbdr);
  border-radius:50px; padding:10px 24px;
  font-size:15px; font-weight:700; color:var(--red);
  margin-bottom:14px; letter-spacing:.5px;
  font-family:'Space Grotesk', sans-serif;
}
.ref-linked-notice {
  display:inline-flex; align-items:center; gap:9px;
  background:var(--gdim); border:1px solid var(--gbdr);
  border-radius:var(--rad3); padding:10px 16px;
  font-size:13px; color:var(--grn); margin-bottom:20px;
}
.success-steps {
  display:flex; align-items:center; justify-content:center;
  gap:10px; flex-wrap:wrap; margin:20px 0 8px;
}
.sstep { display:flex; flex-direction:column; align-items:center; gap:6px; }
.sstep-ic {
  width:40px; height:40px; border-radius:50%;
  background:var(--rdim); border:1.5px solid var(--rbdr);
  display:flex; align-items:center; justify-content:center;
  font-size:14px; color:var(--red);
}
.sstep-ic.done { background:var(--gdim); border-color:var(--gbdr); color:var(--grn); }
.sstep span { font-size:11px; font-weight:600; color:var(--txt2); }
.sstep-line { width:32px; height:2px; background:var(--bdr2); border-radius:2px; margin-top:-12px; }

/* Contact info strip */
.info-strip {
  display:grid; grid-template-columns:1fr 1fr;
  gap:10px; margin:0 auto 24px; text-align:left;
}
.istrip-item {
  display:flex; align-items:center; gap:11px;
  background:var(--sur2); border:1px solid var(--bdr);
  border-radius:var(--rad2); padding:12px 14px;
  text-decoration:none; color:inherit; transition:all .25s;
}
.istrip-item:hover { border-color:var(--red); transform:translateY(-1px); box-shadow:var(--sh3); }
.istrip-ic {
  width:36px; height:36px; border-radius:var(--rad3); flex-shrink:0;
  background:var(--rdim); border:1px solid var(--rbdr);
  display:flex; align-items:center; justify-content:center;
  font-size:14px; color:var(--red);
}
.istrip-ic.green { background:var(--gdim); border-color:var(--gbdr); color:var(--grn); }
.istrip-ic.blue  { background:var(--bdim); border-color:var(--bbdr); color:var(--blue); }
.istrip-lbl { font-size:9.5px; font-weight:700; color:var(--txt3); letter-spacing:1px; text-transform:uppercase; }
.istrip-val { font-size:13px; font-weight:600; color:var(--txt); margin-top:2px; word-break:break-all; }

/* Dup warning banner */
.dup-warning-banner {
  display:flex; align-items:flex-start; gap:14px;
  background:rgba(221,0,0,.07); border:1.5px solid rgba(221,0,0,.3);
  border-radius:var(--rad2); padding:16px 20px; margin-bottom:20px;
}
.dwb-icon { font-size:22px; color:var(--red); flex-shrink:0; padding-top:1px; }
.dwb-title { font-size:14px; font-weight:700; color:var(--red); margin-bottom:4px; }
.dwb-msg { font-size:13px; color:var(--txt2); line-height:1.7; }

/* ═══════════════════════════════════════════════════
   STEP NAVIGATOR
   ═══════════════════════════════════════════════════ */
.step-nav {
  display:flex;
  background:var(--sur2); border:1px solid var(--bdr);
  border-radius:var(--rad); padding:5px;
  margin-bottom:22px; gap:3px;
}
.step-btn {
  flex:1; display:flex; flex-direction:column; align-items:center;
  gap:4px; padding:5px; border:none; border-radius:var(--rad2);
  background:transparent; color:var(--txt3); cursor:pointer;
  font-family:'Poppins', sans-serif; transition:all .25s;
}
.step-btn .sn {
  font-size:9px; font-weight:700; letter-spacing:.5px;
  text-transform:uppercase; white-space:nowrap;
}
.step-btn .si { font-size:16px; line-height:1; }
.step-btn .sv {
  width:20px; height:20px; border-radius:50%;
  background:var(--bdr2); font-size:9px; font-weight:800;
  display:flex; align-items:center; justify-content:center;
  color:var(--txt3); transition:all .25s;
}
.step-btn.active { color:#fff; background:var(--red); }
.step-btn.active .sv { background:rgba(255,255,255,.22); color:#fff; }
.step-btn.done { color:var(--grn); }
.step-btn.done .sv { background:var(--gdim); color:var(--grn); border:1px solid var(--gbdr); }
.step-btn:hover:not(.active) { color:var(--txt); }
.step-btn:hover:not(.active) .sv { background:var(--rdim); color:var(--red); }
.step-connector { width:1px; background:var(--bdr); align-self:stretch; flex-shrink:0; margin:6px 0; }

/* ═══════════════════════════════════════════════════
   FORM CARDS
   ═══════════════════════════════════════════════════ */
.card {
  background:var(--sur); border:1px solid var(--bdr);
  border-radius:var(--rad); padding:12px 10px;
  margin-bottom:16px; box-shadow:var(--sh3); transition:border-color .25s;
}
.card:hover { border-color:var(--bdr2); }
.card-hd {
  display:flex; align-items:center; gap:13px;
  margin-bottom:22px; padding-bottom:16px; border-bottom:1px solid var(--bdr);
}
.card-hd-ic {
  width:42px; height:42px; border-radius:var(--rad2);
  background:var(--rdim); border:1px solid var(--rbdr);
  display:flex; align-items:center; justify-content:center;
  font-size:17px; color:var(--red); flex-shrink:0;
}
.card-hd-title { font-size:15px; font-weight:700; font-family:'Space Grotesk', sans-serif; }
.card-hd-sub   { font-size:12px; color:var(--txt2); margin-top:2px; }

/* ── Form grid ────────────────────────────────────────── */
.g2 { display:grid; grid-template-columns:1fr 1fr; gap:16px; }
.fg { display:flex; flex-direction:column; gap:7px; }
.fg.full { grid-column:1/-1; }

.fl {
  font-size:10px; font-weight:700; letter-spacing:1.2px;
  text-transform:uppercase; color:var(--txt2);
  display:flex; align-items:center; gap:5px;
}
.fli { color:var(--red); font-size:10px; }
.req { color:var(--red); }

.fi-wrap { position:relative; display:flex; align-items:center; }
.fi-ic {
  position:absolute; left:13px; font-size:13px;
  color:var(--txt3); pointer-events:none; z-index:1; transition:color .2s;
}
.fi {
  width:100%;
  background:var(--inp); border:1.5px solid var(--inp-bdr);
  border-radius:var(--rad2);
  padding:12px 13px 12px 40px;
  font-family:'Poppins', sans-serif; font-size:14px; color:var(--txt);
  outline:none; transition:border-color .2s, box-shadow .2s;
  -webkit-appearance:none; appearance:none;
}
textarea.fi { padding:12px 13px; resize:vertical; min-height:90px; }
select.fi   { cursor:pointer; }
.fi::placeholder { color:var(--txt3); }
.fi:focus { border-color:var(--red); box-shadow:0 0 0 3px var(--rdim); }
.fi-wrap:focus-within .fi-ic { color:var(--red); }

[data-theme=light] .fi { background:var(--inp); border-color:var(--inp-bdr); }

.ref-input-wrap { position:relative; }
.ref-status { margin-top:6px; font-size:12px; line-height:1.5; }
.ref-checking { color:var(--txt2); }
.ref-found    { color:var(--grn); display:flex; align-items:flex-start; gap:7px; flex-wrap:wrap; }
.ref-notfound { color:var(--org); display:flex; align-items:center; gap:7px; }

/* ── Note / Error boxes ──────────────────────────── */
.note {
  display:flex; align-items:flex-start; gap:10px;
  padding:11px 15px; border-radius:var(--rad3);
  background:var(--bdim); border:1px solid var(--bbdr);
  font-size:13px; color:var(--txt2); margin-bottom:18px; line-height:1.7;
}
.n-ic { color:var(--blue); font-size:14px; flex-shrink:0; margin-top:1px; }

.err-box {
  background:var(--rdim); border:1px solid var(--rbdr);
  border-radius:var(--rad); padding:16px 18px; margin-bottom:20px;
}
.err-title {
  font-size:13px; font-weight:700; color:var(--red);
  margin-bottom:10px; display:flex; align-items:center; gap:8px;
}
.err-list { list-style:none; display:flex; flex-direction:column; gap:6px; }
.err-list li { font-size:13px; color:var(--txt2); display:flex; align-items:center; gap:8px; }
.err-list li i { color:var(--red); font-size:11px; }

/* ── Section panels ─────────────────────────────── */
.sec-panel { display:none; }
.sec-panel.on { display:block; }

/* ── Nav buttons ────────────────────────────────── */
.sec-nav {
  display:flex; align-items:center; justify-content:space-between;
  gap:12px; margin-top:8px; margin-bottom:22px;
}
.btn {
  display:inline-flex; align-items:center; gap:8px;
  padding:12px 24px; border-radius:var(--rad2);
  font-family:'Poppins', sans-serif; font-size:14px;
  font-weight:600; border:none; cursor:pointer; transition:all .25s; white-space:nowrap;
}
.btn-primary {
  background:linear-gradient(135deg, var(--red) 0%, #aa0000 100%);
  color:#fff; box-shadow:0 4px 18px rgba(221,0,0,.35);
}
.btn-primary:hover { transform:translateY(-2px); box-shadow:0 7px 26px rgba(221,0,0,.5); }
.btn-secondary { background:var(--sur2); color:var(--txt2); border:1.5px solid var(--bdr2); }
.btn-secondary:hover { border-color:var(--red); color:var(--red); background:var(--rdim); }
.btn-submit { padding:13px 28px; font-size:15px; }

/* ═══════════════════════════════════════════════════
   PHOTOGRAPHS & DOCUMENTS — Enhanced, Modern
   ═══════════════════════════════════════════════════ */

/* Section heading for photos */
.photo-section-title {
  font-size:13px; font-weight:700; color:var(--txt2);
  letter-spacing:1.5px; text-transform:uppercase;
  margin-bottom:16px; padding-bottom:10px;
  border-bottom:1px solid var(--bdr);
  display:flex; align-items:center; gap:9px;
}
.photo-section-title i { color:var(--red); font-size:14px; }

/* Photo grid */
.photo-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:14px; }
.photo-item { display:flex; flex-direction:column; gap:8px; }
.photo-item.wide { grid-column:span 2; }

/* Label above each upload */
.photo-label {
  font-size:11px; font-weight:700; color:var(--txt2);
  letter-spacing:1px; text-transform:uppercase;
  display:flex; align-items:center; gap:6px;
}
.photo-label i { color:var(--red); font-size:11px; }

/* The card itself */
.photo-card {
  background:var(--sur2);
  border:2px dashed var(--bdr2);
  border-radius:var(--rad);
  aspect-ratio:2/1; overflow:hidden;
  position:relative; transition:all .25s; cursor:pointer;
}
.photo-card.wide { aspect-ratio:16/9; }
.photo-card:hover {
  border-color:var(--red); border-style:solid;
  box-shadow:0 0 0 3px var(--rdim), var(--sh3);
  transform:translateY(-1px);
}
.photo-card.has-photo {
  border-style:solid; border-color:var(--grn);
  box-shadow:0 0 0 2px var(--gdim);
}
.photo-card.has-photo:hover {
  border-color:var(--grn);
  box-shadow:0 0 0 3px rgba(0,200,83,.15), var(--sh3);
}

/* Preview img */
.photo-preview-img {
  width:100%; height:100%; object-fit:cover;
  display:none; position:absolute; inset:0;
  transition:transform .3s;
}
.photo-card.has-photo:hover .photo-preview-img { transform:scale(1.04); }

/* Hover overlay with action buttons */
.photo-preview-overlay {
  position:absolute; inset:0;
  background:linear-gradient(180deg, rgba(0,0,0,.0) 0%, rgba(0,0,0,.75) 100%);
  display:none; flex-direction:column;
  align-items:center; justify-content:flex-end;
  padding:12px; gap:7px;
}
.photo-card.has-photo:hover .photo-preview-overlay { display:flex; }
.po-btn {
  width:100%; background:rgba(255,255,255,.15);
  backdrop-filter:blur(6px);
  border:1px solid rgba(255,255,255,.3);
  color:#fff; padding:8px 14px; border-radius:var(--rad3);
  font-size:12px; font-family:'Poppins', sans-serif; cursor:pointer;
  transition:all .15s; display:flex; align-items:center; justify-content:center; gap:6px;
}
.po-btn:hover { background:rgba(255,255,255,.28); }

/* Empty placeholder */
.photo-placeholder {
  position:absolute; inset:0; display:flex; flex-direction:column;
  align-items:center; justify-content:center; gap:8px; padding:14px;
  transition:all .2s;
}
.photo-card:hover .photo-placeholder { opacity:.7; }
.ph-ic {
  width:44px; height:44px; border-radius:50%;
  background:var(--rdim); border:1.5px solid var(--rbdr);
  display:flex; align-items:center; justify-content:center;
  font-size:18px; color:var(--red); flex-shrink:0;
  transition:all .25s;
}
.photo-card:hover .ph-ic {
  background:var(--rdim2); transform:scale(1.1);
}
.ph-main { font-size:11.5px; font-weight:600; color:var(--txt2); text-align:center; line-height:1.4; }
.ph-sub  { font-size:10px; color:var(--txt3); text-align:center; }

/* Status below card */
.photo-status {
  font-size:11px; font-weight:600; color:var(--txt3);
  min-height:16px; display:flex; align-items:center; gap:5px;
}
.photo-status.ok { color:var(--grn); }
.photo-status i  { font-size:11px; }

/* Documents section uses same grid but has a document icon style */
.doc-upload-area {
  display:flex; flex-direction:column; gap:10px;
}
.doc-item {
  display:flex; align-items:center; gap:14px;
  background:var(--sur2); border:1.5px dashed var(--bdr2);
  border-radius:var(--rad2); padding:14px 16px;
  cursor:pointer; transition:all .25s; position:relative; overflow:hidden;
}
.doc-item:hover {
  border-color:var(--red); border-style:solid;
  background:var(--rdim); transform:translateX(2px);
}
.doc-item.has-doc {
  border-style:solid; border-color:var(--grn); background:var(--gdim);
}
.doc-item.has-doc:hover { border-color:var(--grn); background:rgba(0,200,83,.12); }
.doc-ic {
  width:44px; height:44px; border-radius:var(--rad3); flex-shrink:0;
  background:var(--rdim); border:1px solid var(--rbdr);
  display:flex; align-items:center; justify-content:center;
  font-size:20px; color:var(--red); transition:all .25s;
}
.doc-item.has-doc .doc-ic { background:var(--gdim); border-color:var(--gbdr); color:var(--grn); }
.doc-info { flex:1; min-width:0; }
.doc-title { font-size:13px; font-weight:700; color:var(--txt); margin-bottom:2px; }
.doc-sub   { font-size:11.5px; color:var(--txt2); }
.doc-status { font-size:11px; font-weight:600; color:var(--txt3); flex-shrink:0; }
.doc-item.has-doc .doc-status { color:var(--grn); }

.hidden-input { display:none; }

/* ── Review table ─────────────────────────────── */
.review-table { width:100%; border-collapse:collapse; font-size:13.5px; }
.review-table td { padding:9px 12px; border-bottom:1px solid var(--bdr); }
.review-table td:first-child { color:var(--txt2); font-weight:600; white-space:nowrap; width:36%; }
.review-photos { display:flex; flex-wrap:wrap; gap:8px; }
.review-photo-badge {
  display:inline-flex; align-items:center; gap:7px;
  background:var(--gdim); border:1px solid var(--gbdr);
  border-radius:50px; padding:4px 12px 4px 7px;
  font-size:12px; font-weight:600; color:var(--grn);
}
.review-photo-badge i { font-size:12px; }

.turnstile-wrap { display:flex; justify-content:center; margin:20px 0 16px; }
.terms-txt { font-size:12px; color:var(--txt3); text-align:center; line-height:1.8; }
.divider { height:1px; background:var(--bdr); margin:20px 0; }

/* ═══════════════════════════════════════════════════
   FIXED FOOTER — full width, always at bottom
   ═══════════════════════════════════════════════════ */
.app-footer {
  position:fixed;
  bottom:0; left:0; right:0;
  height:var(--fh);
  z-index:800;
  background:var(--sur);
  border-top:1px solid var(--bdr);
  box-shadow:0 -2px 24px rgba(0,0,0,.4);
}
[data-theme=light] .app-footer { box-shadow:0 -1px 12px rgba(0,0,0,.07); }

.footer-inner {
  width:100%; height:100%;
  display:flex; align-items:center;
  justify-content:center;
  padding:0 05px;
}

.footer-content {
  display:flex; 
  flex-direction:column; 
  align-items:center; 
  gap:3px;
}

/* Left: circle logo + social icons (now centered) */
.footer-left { 
  display:flex; 
  align-items:center; 
  gap:12px; 
}

.footer-logo-link {
  display:flex; align-items:center;
  text-decoration:none; flex-shrink:0;
}
.footer-logo-circle {
  width:32px; height:32px; border-radius:50%;
  object-fit:cover; border:2px solid var(--bdr2);
  transition:all .25s;
}
.footer-logo-link:hover .footer-logo-circle {
  border-color:var(--red); box-shadow:0 0 12px rgba(221,0,0,.35);
  transform:scale(1.08);
}

/* Social icons — brand colours */
.footer-socials { display:flex; align-items:center; gap:6px; }
.fsoc {
  width:29px; height:29px; border-radius:50%;
  border:1px solid var(--bdr2); background:var(--sur2);
  display:flex; align-items:center; justify-content:center;
  font-size:12px; color:var(--txt2); text-decoration:none;
  transition:all .2s;
}

/* Brand colour hover states */
.fsoc.fsoc-fb:hover  { background:#1877f2; border-color:#1877f2; color:#fff; box-shadow:0 3px 10px rgba(24,119,242,.4); }
.fsoc.fsoc-tw:hover  { background:#000; border-color:#000; color:#fff; box-shadow:0 3px 10px rgba(0,0,0,.4); }
[data-theme=light] .fsoc.fsoc-tw:hover { background:#1d9bf0; border-color:#1d9bf0; }
.fsoc.fsoc-ig:hover  { background:linear-gradient(45deg, #f58529, #dd2a7b, #8134af); border-color:#dd2a7b; color:#fff; box-shadow:0 3px 10px rgba(221,42,123,.4); }
.fsoc.fsoc-yt:hover  { background:#ff0000; border-color:#ff0000; color:#fff; box-shadow:0 3px 10px rgba(255,0,0,.4); }
.fsoc.fsoc-wa:hover  { background:#25d366; border-color:#25d366; color:#fff; box-shadow:0 3px 10px rgba(37,211,102,.4); }
.fsoc.fsoc-tg:hover  { background:#2aabee; border-color:#2aabee; color:#fff; box-shadow:0 3px 10px rgba(42,171,238,.4); }
.fsoc.fsoc-gl:hover  { background:var(--red); border-color:var(--red); color:#fff; box-shadow:0 3px 10px rgba(221,0,0,.4); }

/* Copyright text - centered below */
.footer-copy { 
  font-size:12px; 
  color:var(--txt2);
  margin:0;
  text-align:center;
}

/* ═══════════════════════════════════════════════════
   CAMERA MODAL
   ═══════════════════════════════════════════════════ */
.cam-modal {
  display:none; position:fixed; inset:0; z-index:9999;
  background:#000; flex-direction:column;
  align-items:center; justify-content:center; padding:16px;
}
.cam-modal.open { display:flex; }
.cam-wrap { position:relative; width:100%; max-width:460px; border-radius:16px; overflow:hidden; }
.cam-video { width:100%; display:block; border-radius:16px; background:#111; }
.cam-overlay { position:absolute; inset:0; display:flex; align-items:center; justify-content:center; pointer-events:none; }
.cam-guide { border:2px solid rgba(255,255,255,.6); border-radius:10px; box-shadow:0 0 0 9999px rgba(0,0,0,.5); }
.cam-canvas { display:none; }
.cam-actions { display:flex; align-items:center; justify-content:center; gap:24px; margin-top:22px; padding:0 16px; }
.cam-snap {
  width:68px; height:68px; border-radius:50%; background:var(--red);
  border:3px solid rgba(255,255,255,.3); color:#fff; font-size:22px;
  cursor:pointer; transition:all .2s; display:flex; align-items:center; justify-content:center;
}
.cam-snap:hover { transform:scale(1.1); box-shadow:0 0 28px rgba(221,0,0,.7); }
.cam-flip, .cam-close-btn {
  width:50px; height:50px; border-radius:50%;
  background:rgba(255,255,255,.1); border:1px solid rgba(255,255,255,.2);
  color:#fff; font-size:16px; cursor:pointer; transition:all .2s;
  display:flex; align-items:center; justify-content:center;
}
.cam-flip:hover, .cam-close-btn:hover { background:rgba(255,255,255,.22); }

/* ═══════════════════════════════════════════════════
   RESPONSIVE — MOBILE FIRST
   ═══════════════════════════════════════════════════ */
@media(max-width:768px) {
  body { font-size:14px; }
  .page-hero { padding:5px 5px; }
  .hero-title { font-size:24px; }
  .hero-desc  { font-size:13.5px; }
  .card-hd-title { font-size:14px; }
  .fi { font-size:14px; }
}

@media(max-width:640px) {
  :root { --hh:50px; --fh:65px; }
  .page-hero  { padding:5px 5px; }
  .hero-title { font-size:22px; }
  .hero-desc  { font-size:13px; }
  .hero-eyebrow { font-size:15px; letter-spacing:2px; }
  .page-body  { padding:5px 5px; }
  .card       { padding:12px 10px; }
  .g2         { grid-template-columns:1fr; }
  .fg.full    { grid-column:1; }
  .photo-grid { grid-template-columns:1fr 1fr; }
  .photo-item.wide { grid-column:span 2; }
  .step-btn .sn { display:none; }
  .sec-nav    { flex-direction:column-reverse; gap:10px; }
  .btn        { width:100%; justify-content:center; }
  .state-card { padding:30px 18px; }
  .info-strip { grid-template-columns:1fr; }
  .footer-inner { padding:0 14px; gap:10px; }
  .footer-contacts a span { display:none; } /* icon only on mobile */
  .header-logo-banner { max-width:180px; height:26px; }
  .hero-badges { gap:7px; }
  .hbadge { font-size:10px; padding:5px 12px; }
}

@media(max-width:420px) {
  .page-hero { padding:5px 5px; }
  .page-body { padding:5px 5px; }
  .hero-title { font-size:20px; }
  .photo-grid { grid-template-columns:1fr; }
  .photo-item.wide { grid-column:1; }
  .footer-socials .fsoc:nth-child(n+7) { display:none; }
}

/* ═══════════════════════════════════════════════════
   SCROLLBAR — modern minimal
   ═══════════════════════════════════════════════════ */
::-webkit-scrollbar { width:5px; height:5px; }
::-webkit-scrollbar-track { background:var(--bg2); }
::-webkit-scrollbar-thumb { background:var(--bdr2); border-radius:4px; }
::-webkit-scrollbar-thumb:hover { background:var(--red); }

/* ═══════════════════════════════════════════════════
   SELECTION
   ═══════════════════════════════════════════════════ */
::selection { background:var(--rdim2); color:var(--red); }