:root{
  --blue:#003f91;--blue-2:#005bea;--deep:#061a3f;--navy:#001f5c;--orange:#ff7a18;--orange-2:#ff9f1c;--gold:#ffd447;--sky:#eaf4ff;--ink:#08172f;--muted:#64748b;--line:#dbe7fb;--card:rgba(255,255,255,.88);--white:#fff;--green:#16a34a;--red:#ef4444;--shadow:0 18px 50px rgba(0,40,120,.13);--shadow-soft:0 10px 30px rgba(15,23,42,.08);--radius:24px
}
*{box-sizing:border-box}html{scroll-behavior:smooth}body{margin:0;font-family:Inter,ui-sans-serif,system-ui,-apple-system,Segoe UI,Arial,sans-serif;background:radial-gradient(circle at 12% 10%,rgba(255,122,24,.15),transparent 30%),radial-gradient(circle at 88% 4%,rgba(0,91,234,.18),transparent 34%),linear-gradient(180deg,#f6fbff 0%,#fff 48%,#f2f7ff 100%);color:var(--ink);min-height:100vh}a{color:inherit;text-decoration:none}img,video{max-width:100%}.wrap{width:min(1180px,94vw);margin:auto}.mini-wrap{width:min(980px,94vw);margin:auto}.topnav{position:sticky;top:0;z-index:30;background:rgba(0,31,92,.9);backdrop-filter:blur(16px);border-bottom:1px solid rgba(255,255,255,.12);box-shadow:0 8px 30px rgba(0,22,70,.20)}.topnav-inner{height:70px;display:flex;align-items:center;justify-content:space-between;gap:18px}.brand{display:flex;align-items:center;gap:12px;color:#fff;font-weight:950;letter-spacing:.02em}.brand-badge{width:38px;height:38px;border-radius:13px;background:linear-gradient(135deg,#fff,#dbeafe);display:grid;place-items:center;color:var(--blue);box-shadow:inset 0 0 0 1px rgba(0,63,145,.12)}.brand small{display:block;font-size:12px;font-weight:800;color:#bfd7ff;margin-top:1px}.navlinks{display:flex;gap:8px;align-items:center}.navlinks a,.pill{display:inline-flex;align-items:center;justify-content:center;gap:8px;border-radius:999px;padding:10px 14px;color:#fff;font-weight:800;font-size:14px;border:1px solid rgba(255,255,255,.12);background:rgba(255,255,255,.06)}.navlinks a:hover,.pill:hover{background:rgba(255,255,255,.14)}.nav-cta{background:linear-gradient(135deg,var(--orange),var(--orange-2))!important;color:#fff!important;border:0!important;box-shadow:0 10px 26px rgba(255,122,24,.35)}.hero{position:relative;isolation:isolate;padding:28px 0 108px}.hero:before{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(0,31,92,.12),rgba(255,255,255,0));z-index:-2}.hero-grid{display:grid;grid-template-columns:1.1fr .9fr;gap:24px;align-items:stretch}.hero-card{min-height:520px;border-radius:34px;overflow:hidden;box-shadow:var(--shadow);position:relative;border:1px solid rgba(255,255,255,.65);background:url('/assets/hero.png') center/cover no-repeat}.hero-card:after{content:"";position:absolute;inset:0;background:linear-gradient(90deg,rgba(0,25,73,.72),rgba(0,25,73,.16) 48%,rgba(0,25,73,.06));}.hero-copy{position:absolute;inset:auto 24px 26px 24px;z-index:2;color:#fff;max-width:680px}.eyebrow{display:inline-flex;align-items:center;gap:8px;border-radius:999px;padding:9px 12px;background:rgba(255,255,255,.16);border:1px solid rgba(255,255,255,.28);backdrop-filter:blur(10px);font-weight:900;font-size:13px}.hero h1{font-size:clamp(38px,6vw,76px);line-height:.92;margin:18px 0 12px;letter-spacing:-.06em;text-shadow:0 14px 36px rgba(0,0,0,.34)}.hero p{font-size:clamp(16px,2.2vw,22px);line-height:1.5;margin:0;color:#e9f2ff;text-shadow:0 8px 24px rgba(0,0,0,.32)}.side-panel{display:flex;flex-direction:column;gap:16px}.glass-card,.card{background:var(--card);border:1px solid rgba(219,231,251,.95);border-radius:var(--radius);box-shadow:var(--shadow-soft);backdrop-filter:blur(12px);padding:24px}.quick-card{flex:1;display:flex;flex-direction:column;justify-content:space-between;background:linear-gradient(180deg,rgba(255,255,255,.9),rgba(234,244,255,.82));}.quick-card h2,.card h2,.card h1{letter-spacing:-.035em;color:var(--deep)}.checklist{display:grid;gap:12px;margin:18px 0}.check{display:flex;gap:10px;align-items:flex-start;color:#17305f}.check:before{content:"✓";flex:0 0 22px;width:22px;height:22px;border-radius:8px;display:grid;place-items:center;background:rgba(255,122,24,.14);color:var(--orange);font-weight:950}.stats-row{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}.stat{border-radius:20px;padding:14px;background:#fff;border:1px solid var(--line)}.stat b{display:block;font-size:22px;color:var(--blue)}.upload-shell{margin-top:-74px;position:relative;z-index:5}.upload-layout{display:grid;grid-template-columns:.85fr 1.15fr;gap:18px}.upload-info{background:linear-gradient(160deg,#fff,#eef6ff);}.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px}.field{display:flex;flex-direction:column;gap:8px;margin-bottom:14px}.field label{font-weight:900;color:#17305f;font-size:14px}.input,textarea,select{width:100%;border:1px solid #d4e2f7;border-radius:16px;padding:14px 15px;font:inherit;background:#fff;outline:none;transition:.18s box-shadow,.18s border-color}.input:focus,textarea:focus,select:focus{border-color:var(--blue-2);box-shadow:0 0 0 4px rgba(0,91,234,.12)}.file-drop{border:2px dashed #9fc0f5;background:linear-gradient(180deg,#f8fbff,#fff);border-radius:22px;padding:22px;text-align:center}.file-drop input{background:#fff}.hint{color:var(--muted);font-size:14px;line-height:1.5}.notice{background:#f4f8ff;border:1px solid #dbeafe;border-radius:18px;padding:14px 16px;margin:12px 0}.success{background:#eafaf0;border-color:#b8f2cc;color:#14532d}.error{background:#fff1f2;border-color:#fecdd3;color:#7f1d1d}.agree-box{display:flex!important;gap:12px;align-items:flex-start;background:#fff!important}.agree-box input{margin-top:4px}.btn{border:0;border-radius:16px;padding:13px 18px;font-weight:950;text-decoration:none;display:inline-flex;align-items:center;justify-content:center;gap:9px;cursor:pointer;transition:transform .16s ease,box-shadow .16s ease,background .16s ease;font-size:15px}.btn:hover{transform:translateY(-1px)}.btn.primary{background:linear-gradient(135deg,var(--orange),var(--orange-2));color:white;box-shadow:0 12px 26px rgba(255,122,24,.28)}.btn.blue{background:linear-gradient(135deg,var(--blue),var(--blue-2));color:white;box-shadow:0 12px 26px rgba(0,91,234,.22)}.btn.ghost{background:#fff;color:var(--blue);border:1px solid var(--line)}.btn.danger{background:#fee2e2;color:#991b1b}.section{padding:36px 0}.features{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}.feature-icon{width:42px;height:42px;border-radius:15px;display:grid;place-items:center;background:linear-gradient(135deg,#eaf4ff,#fff);border:1px solid var(--line);font-size:22px}.gallery-hero{padding:36px 0 24px}.gallery-head{display:flex;justify-content:space-between;gap:16px;align-items:flex-end;flex-wrap:wrap}.tabs{display:flex;gap:10px;flex-wrap:wrap;margin:18px 0}.tab{border:1px solid var(--line);background:#fff;border-radius:999px;padding:10px 14px;font-weight:850;color:#17305f}.slot{margin:26px 0}.slot-title{display:flex;align-items:center;gap:12px;margin-bottom:14px}.slot-title h2{font-size:24px;color:var(--deep);margin:0;letter-spacing:-.04em}.slot-count{font-weight:900;color:var(--blue);background:#eaf4ff;border-radius:999px;padding:6px 10px}.media-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(190px,1fr));gap:16px}.media{background:white;border:1px solid var(--line);border-radius:22px;overflow:hidden;box-shadow:var(--shadow-soft);transition:transform .18s ease,box-shadow .18s ease}.media:hover{transform:translateY(-3px);box-shadow:var(--shadow)}.media-preview{position:relative;display:block;background:#dbeafe}.media img,.media video{width:100%;aspect-ratio:1/1;object-fit:cover;display:block;-webkit-user-select:none;user-select:none;-webkit-touch-callout:none}.media-kind{position:absolute;right:10px;top:10px;border-radius:999px;padding:6px 9px;background:rgba(0,31,92,.82);color:#fff;font-size:12px;font-weight:950}.media-body{padding:13px}.media-body strong{color:#102a59}.media-actions{display:grid;grid-template-columns:1fr;gap:8px;margin-top:12px}.viewer{max-width:980px;margin:auto}.viewer-media{background:#061a3f;border-radius:26px;padding:10px;box-shadow:var(--shadow)}.viewer-media img,.viewer-media video{width:100%;border-radius:18px;display:block;-webkit-user-select:none;user-select:none;-webkit-touch-callout:none}.footer-note{margin-top:30px;border-radius:24px;background:linear-gradient(135deg,#eaf4ff,#fff);border:1px solid var(--line);padding:18px;display:flex;gap:14px;align-items:center}.adminbar{background:linear-gradient(135deg,var(--navy),var(--deep));color:#fff;box-shadow:0 10px 30px rgba(0,31,92,.18)}.adminbar .wrap{min-height:68px;display:flex;align-items:center;justify-content:space-between;gap:14px;flex-wrap:wrap}.adminbar a{color:#fff;opacity:.92}.admin-shell{display:grid;grid-template-columns:250px 1fr;gap:22px;padding:24px 0}.sidebar{background:linear-gradient(180deg,var(--navy),#061a3f);color:#fff;border-radius:26px;padding:18px;box-shadow:var(--shadow);min-height:620px}.sidebar .brand{margin-bottom:22px}.side-link{display:flex;align-items:center;gap:10px;padding:12px 13px;border-radius:15px;color:#dbeafe;margin:4px 0;font-weight:850}.side-link:hover,.side-link.active{background:rgba(255,255,255,.12);color:#fff}.admin-main{min-width:0}.admin-title{display:flex;align-items:center;justify-content:space-between;gap:14px;flex-wrap:wrap;margin-bottom:16px}.stat-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:18px}.table-card{background:#fff;border:1px solid var(--line);border-radius:24px;box-shadow:var(--shadow-soft);overflow:hidden}.table{width:100%;border-collapse:collapse;background:white}.table th,.table td{padding:14px;border-bottom:1px solid #eaf0fb;text-align:left;font-size:14px;vertical-align:middle}.table th{background:#f8fbff;color:#17305f;font-size:12px;text-transform:uppercase;letter-spacing:.05em}.table tr:hover td{background:#fbfdff}.admin-thumb{width:76px;height:76px;object-fit:cover;border-radius:16px;border:1px solid var(--line)}.badge{border-radius:999px;padding:6px 10px;font-weight:950;font-size:12px;display:inline-flex}.pending{background:#fff7d6;color:#8a4b00}.approved{background:#dcfce7;color:#166534}.hidden{background:#e5e7eb;color:#374151}.deleted{background:#fee2e2;color:#991b1b}.bulkbar{position:sticky;bottom:16px;z-index:10;margin-top:16px;background:rgba(255,255,255,.92);backdrop-filter:blur(14px);border:1px solid var(--line);border-radius:22px;padding:14px;box-shadow:var(--shadow);display:flex;gap:10px;align-items:center;flex-wrap:wrap}.login-page{min-height:100vh;display:grid;place-items:center;padding:24px;background:radial-gradient(circle at 25% 20%,rgba(255,122,24,.18),transparent 32%),linear-gradient(135deg,#eaf4ff,#fff)}.login-card{width:min(520px,94vw)}.animate-in{animation:rise .55s ease both}@keyframes rise{from{opacity:0;transform:translateY(14px)}to{opacity:1;transform:none}}@media(max-width:900px){.hero-grid,.upload-layout,.admin-shell{grid-template-columns:1fr}.side-panel{display:none}.features,.stat-grid{grid-template-columns:1fr 1fr}.sidebar{min-height:0}.navlinks{display:none}.hero-card{min-height:520px}.upload-shell{margin-top:-56px}}@media(max-width:640px){.topnav-inner{height:auto;padding:12px 0}.brand-badge{width:34px;height:34px}.hero{padding-top:18px}.hero-card{min-height:460px;border-radius:26px}.hero-copy{inset:auto 18px 20px 18px}.form-grid,.features,.stats-row{grid-template-columns:1fr}.card,.glass-card{padding:18px;border-radius:22px}.media-grid{grid-template-columns:repeat(2,1fr);gap:12px}.table-card{overflow:auto}.table{min-width:820px}.bulkbar{align-items:stretch}.bulkbar .input,.bulkbar .btn{width:100%;max-width:none!important}.footer-note{align-items:flex-start}.adminbar .wrap{padding:10px 0}}

/* === Patch 2026-05-20: QR modal, mobile hamburger, compact downloads, steps above upload === */
.nav-toggle{display:none;border:1px solid rgba(255,255,255,.18);background:rgba(255,255,255,.1);color:#fff;width:42px;height:42px;border-radius:14px;font-size:22px;font-weight:950;line-height:1;cursor:pointer}
.nav-button{font:inherit;cursor:pointer}
.navlinks button{appearance:none;-webkit-appearance:none}
.navlinks a,.navlinks button,.pill{display:inline-flex;align-items:center;justify-content:center;gap:8px;border-radius:999px;padding:10px 14px;color:#fff;font-weight:800;font-size:14px;border:1px solid rgba(255,255,255,.12);background:rgba(255,255,255,.06)}
.compact-hero{padding:22px 0 24px}.hero-card-wide{min-height:520px}.steps-section{padding:0 0 22px}.steps-above{margin-top:0}.no-overlap{margin-top:0}.hero-card-wide .hero-copy{max-width:720px}.footer-note{margin-bottom:28px}.quick-card .checklist .check:nth-child(3){display:none}
.download-icon-btn{width:36px;height:36px;border-radius:12px;display:inline-grid;place-items:center;margin-left:auto;background:#fff;color:var(--blue);border:1px solid var(--line);box-shadow:0 8px 18px rgba(0,40,120,.12);font-size:17px;font-weight:950;transition:transform .16s ease,box-shadow .16s ease}.download-icon-btn:hover{transform:translateY(-1px);box-shadow:0 12px 26px rgba(0,40,120,.18)}.media-actions{display:flex;justify-content:flex-end;align-items:center;margin-top:8px}
.modal-backdrop{position:fixed;inset:0;z-index:100;display:none;align-items:center;justify-content:center;padding:22px;background:rgba(3,12,30,.62);backdrop-filter:blur(10px)}.modal-backdrop.open{display:flex}.modal-card{width:min(390px,94vw);background:#fff;border:1px solid var(--line);border-radius:28px;padding:24px;box-shadow:0 28px 80px rgba(0,20,80,.32);text-align:center;position:relative;animation:rise .2s ease both}.modal-card h2{margin:8px 0 6px;color:var(--deep);letter-spacing:-.03em}.modal-close{position:absolute;right:14px;top:14px;width:36px;height:36px;border-radius:12px;border:1px solid var(--line);background:#fff;color:var(--muted);font-size:24px;line-height:1;cursor:pointer}.qr-image{width:260px;max-width:100%;height:auto;border-radius:18px;border:1px solid var(--line);padding:10px;background:#fff;margin:16px auto 18px;display:block}
@media(max-width:900px){.topnav-inner{position:relative}.nav-toggle{display:inline-grid;place-items:center;flex:0 0 auto}.navlinks{display:none;position:absolute;left:3vw;right:3vw;top:calc(100% + 10px);background:rgba(0,31,92,.98);border:1px solid rgba(255,255,255,.16);box-shadow:0 18px 50px rgba(0,22,70,.28);border-radius:22px;padding:12px;flex-direction:column;align-items:stretch;gap:8px}.navlinks.open{display:flex}.navlinks a,.navlinks button{width:100%;border-radius:16px;padding:13px 14px}.compact-hero{padding-top:16px}.hero-card-wide{min-height:420px}.upload-shell.no-overlap{margin-top:0}.steps-above{grid-template-columns:1fr 1fr 1fr;gap:12px}.steps-above .card{padding:16px}.steps-above h3{font-size:16px}.steps-above .hint{font-size:13px}}
@media(max-width:640px){.brand small{font-size:12px}.compact-hero{padding-bottom:18px}.hero-card-wide{min-height:380px}.steps-above{grid-template-columns:1fr}.steps-above .card{display:grid;grid-template-columns:54px 1fr;column-gap:14px;align-items:start}.steps-above .card h3{margin:4px 0 4px}.steps-above .card p{grid-column:2;margin:0}.feature-icon{grid-row:1 / span 2}.modal-card{padding:20px}.qr-image{width:235px}.download-icon-btn{width:34px;height:34px;border-radius:11px}}

/* === Patch 3: video previews + admin overlay upload === */
.media-preview video{width:100%;aspect-ratio:1/1;object-fit:cover;display:block;background:#061a3f;border:0}
.admin-video-thumb{width:140px;height:90px;object-fit:cover;border-radius:16px;border:1px solid var(--line);background:#061a3f;display:block}
.soft-sep{border:0;border-top:1px solid var(--line);margin:24px 0}
.overlay-preview-box{min-height:120px;border:1px dashed #b7cef5;border-radius:18px;background:linear-gradient(135deg,#f8fbff,#fff);display:grid;place-items:center;padding:16px;margin-bottom:14px;overflow:hidden}
.overlay-preview-box img{max-width:100%;max-height:120px;object-fit:contain;background:linear-gradient(45deg,#f1f5f9 25%,transparent 25%),linear-gradient(-45deg,#f1f5f9 25%,transparent 25%),linear-gradient(45deg,transparent 75%,#f1f5f9 75%),linear-gradient(-45deg,transparent 75%,#f1f5f9 75%);background-size:20px 20px;background-position:0 0,0 10px,10px -10px,-10px 0;border-radius:12px;padding:8px}
@media(max-width:640px){.admin-video-thumb{width:110px;height:76px}.overlay-preview-box{min-height:96px}}
