/*
Theme Name: AcademicHub Premium
Theme URI: https://brainydock.site
Author: Mujeeb Awan
Author URI: https://brainydock.site
Description: A premium dark, glassmorphic theme for a student knowledge archive — featuring a live document ledger, student submission with image/video upload, admin approval, and interactive motion effects. Built from scratch with PHP, CSS and JavaScript. No page builders.
Version: 2.3.0
Requires at least: 6.0
Tested up to: 6.5
Requires PHP: 7.4
License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Text Domain: academichub
Tags: education, custom-colors, custom-menu, featured-images, threaded-comments, dark
*/

@property --ang{syntax:'<angle>';initial-value:0deg;inherits:false}
:root{
  --bg:#0C0820;--bg-2:#130C2B;
  --surface:rgba(255,255,255,.045);--surface-2:rgba(255,255,255,.07);
  --border:rgba(196,173,245,.14);--border-bright:rgba(196,173,245,.32);
  --purple:#8B5CF6;--purple-bright:#A855F7;--magenta:#C026D3;
  --lilac:#C4B5FD;--lilac-soft:#DDD3FB;
  --txt:#F3F0FF;--muted:#A79EC6;--muted-2:#7E769B;--r:16px;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{font-family:"Plus Jakarta Sans",system-ui,sans-serif;background:var(--bg);color:var(--txt);line-height:1.6;-webkit-font-smoothing:antialiased;overflow-x:hidden;position:relative}
img{max-width:100%;height:auto}

.scroll-prog{position:fixed;top:0;left:0;height:3px;width:0;background:linear-gradient(90deg,#8B5CF6,#C026D3);box-shadow:0 0 14px 1px #A855F7;z-index:120}
.spot{position:fixed;inset:0;z-index:1;pointer-events:none;background:radial-gradient(460px at var(--mx,50%) var(--my,25%),rgba(168,85,247,.10),transparent 72%)}

.orbs{position:fixed;inset:0;z-index:0;pointer-events:none;overflow:hidden}
.orb{position:absolute;border-radius:50%;filter:blur(90px)}
.orb.a{width:520px;height:520px;background:radial-gradient(circle,#7C3AED,transparent 70%);top:-160px;left:-120px;opacity:.55;animation:float1 18s ease-in-out infinite}
.orb.b{width:460px;height:460px;background:radial-gradient(circle,#C026D3,transparent 70%);top:8%;right:-140px;opacity:.4;animation:float2 22s ease-in-out infinite}
.orb.c{width:600px;height:600px;background:radial-gradient(circle,#5B21B6,transparent 70%);bottom:-220px;left:30%;opacity:.35;animation:float3 26s ease-in-out infinite}
@keyframes float1{0%,100%{transform:translate(0,0)}50%{transform:translate(60px,50px)}}
@keyframes float2{0%,100%{transform:translate(0,0)}50%{transform:translate(-50px,70px)}}
@keyframes float3{0%,100%{transform:translate(0,0)}50%{transform:translate(40px,-60px)}}
.particles{position:fixed;inset:0;z-index:0;pointer-events:none;overflow:hidden}
.pt{position:absolute;width:3px;height:3px;border-radius:50%;background:#C4B5FD;box-shadow:0 0 8px 1px #A855F7;opacity:0;animation:rise linear infinite}
@keyframes rise{0%{transform:translateY(0);opacity:0}10%{opacity:.7}90%{opacity:.5}100%{transform:translateY(-110vh);opacity:0}}

.wrap{max-width:1200px;margin:0 auto;padding:0 28px;position:relative;z-index:2}
a{color:inherit;text-decoration:none}
.disp{font-family:"Space Grotesk",sans-serif}.mono{font-family:"DM Mono",monospace}
.eyebrow{font-family:"DM Mono",monospace;font-size:12px;letter-spacing:.2em;text-transform:uppercase;color:var(--lilac)}
.grad-txt{background:linear-gradient(100deg,#C4B5FD,#A855F7,#E879F9,#A855F7);background-size:200% auto;-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;animation:shine 5s linear infinite}
@keyframes shine{to{background-position:200% center}}
.caret{display:inline-block;width:3px;height:1em;background:#A855F7;margin-left:4px;vertical-align:-2px;box-shadow:0 0 10px #A855F7;animation:cb .8s steps(1) infinite}
@keyframes cb{50%{opacity:0}}

/* NAV */
.site-header{position:sticky;top:0;z-index:60;background:rgba(12,8,32,.6);backdrop-filter:blur(18px) saturate(140%);border-bottom:1px solid var(--border)}
.nav{display:flex;align-items:center;justify-content:space-between;height:76px}
.brand{display:flex;align-items:center;gap:11px;font-family:"Space Grotesk",sans-serif;font-weight:700;font-size:22px;letter-spacing:-.02em;color:#fff}
.mark{width:36px;height:36px;border-radius:11px;background:linear-gradient(145deg,#A855F7,#7C3AED);color:#fff;display:grid;place-items:center;font-size:19px;box-shadow:0 0 22px -2px rgba(168,85,247,.8)}
.mark b{font-family:"Space Grotesk",sans-serif;font-weight:700}
.navlinks{display:flex;gap:34px;align-items:center;list-style:none}
.navlinks a{font-size:15px;color:var(--muted);font-weight:600;transition:color .2s}
.navlinks a:hover{color:#fff}
.nav-cta{display:flex;align-items:center;gap:14px}
.ghost{font-size:15px;font-weight:700;color:var(--txt)}
.btn{font-family:"Plus Jakarta Sans";font-weight:700;font-size:15px;padding:11px 22px;border-radius:12px;border:none;cursor:pointer;transition:transform .15s ease,box-shadow .25s ease;display:inline-flex;align-items:center;gap:9px;position:relative;overflow:hidden;text-align:center}
.btn-purple{background:linear-gradient(120deg,#8B5CF6,#A855F7);color:#fff;box-shadow:0 0 24px -4px rgba(168,85,247,.7)}
.btn-purple:hover{box-shadow:0 0 36px 0 rgba(168,85,247,.95)}
.btn-purple::after{content:"";position:absolute;top:0;left:-120%;width:60%;height:100%;background:linear-gradient(100deg,transparent,rgba(255,255,255,.45),transparent);transform:skewX(-20deg);transition:left .6s}
.btn-purple:hover::after{left:140%}
.btn-glass{background:var(--surface-2);color:#fff;box-shadow:inset 0 0 0 1px var(--border-bright);backdrop-filter:blur(8px)}
.btn-glass:hover{box-shadow:inset 0 0 0 1px var(--purple),0 0 22px -6px rgba(168,85,247,.6)}
.menu-btn{display:none;background:none;border:none;cursor:pointer;color:#fff}

/* HERO */
.hero{position:relative;padding:84px 0 92px;overflow:hidden}
.grid-floor{position:absolute;left:-10%;right:-10%;bottom:-2px;height:360px;z-index:0;background-image:linear-gradient(rgba(168,85,247,.16) 1px,transparent 1px),linear-gradient(90deg,rgba(168,85,247,.16) 1px,transparent 1px);background-size:48px 48px;transform:perspective(420px) rotateX(62deg);transform-origin:bottom center;-webkit-mask:linear-gradient(transparent,#000 65%);mask:linear-gradient(transparent,#000 65%);opacity:.45;animation:gridmove 5s linear infinite}
@keyframes gridmove{to{background-position:0 48px}}
.hero-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:60px;align-items:center;position:relative;z-index:2}
.hero-grid>*{min-width:0}
.badge{display:inline-flex;align-items:center;gap:9px;background:var(--surface);border:1px solid var(--border);border-radius:100px;padding:7px 14px 7px 9px;font-size:13px;color:var(--lilac);font-weight:600;backdrop-filter:blur(8px);margin-bottom:24px}
.badge .b-dot{width:8px;height:8px;border-radius:50%;background:#A855F7;box-shadow:0 0 10px 1px #A855F7;animation:cb 1.4s steps(1) infinite}
.hero h1{font-family:"Space Grotesk",sans-serif;font-weight:700;font-size:clamp(42px,5.6vw,66px);line-height:1.04;letter-spacing:-.03em;margin-bottom:22px;color:#fff;min-height:1.04em}
.lede{font-size:19px;color:var(--muted);max-width:484px;margin-bottom:34px}
.search{display:flex;align-items:center;gap:10px;background:var(--surface-2);border:1px solid var(--border-bright);border-radius:16px;padding:8px 8px 8px 18px;max-width:510px;backdrop-filter:blur(12px);box-shadow:0 8px 30px -10px rgba(0,0,0,.5);transition:box-shadow .3s,border-color .3s}
.search:focus-within{border-color:var(--purple);box-shadow:0 0 0 4px rgba(139,92,246,.15),0 8px 30px -8px rgba(124,58,237,.6)}
.search svg{flex:0 0 auto;color:var(--muted)}
.search input{flex:1;border:none;outline:none;font-family:"Plus Jakarta Sans";font-size:16px;color:#fff;background:transparent}
.search input::placeholder{color:var(--muted-2)}
.search .btn{padding:12px 20px}
.hero-meta{display:flex;align-items:center;gap:24px;margin-top:28px;flex-wrap:wrap}
.pill{display:flex;align-items:center;gap:8px;font-size:14px;color:var(--muted);font-weight:600}
.pill .dot{width:7px;height:7px;border-radius:50%;background:#34D399;box-shadow:0 0 8px 1px #34D399}
.avstack{display:flex}
.avstack span{width:30px;height:30px;border-radius:50%;border:2px solid var(--bg);margin-left:-9px;display:grid;place-items:center;font-size:12px;font-weight:800;color:#fff}
.avstack span:first-child{margin-left:0}

/* LEDGER */
.ledger-float{animation:bob 7s ease-in-out infinite;perspective:1000px}
@keyframes bob{0%,100%{transform:translateY(0)}50%{transform:translateY(-12px)}}
.ledger-wrap{position:relative;border-radius:24px;padding:1.5px;background:conic-gradient(from var(--ang),transparent 0%,#A855F7 18%,#E879F9 30%,#C026D3 42%,transparent 60%,transparent 100%);animation:spin 6s linear infinite;transform-style:preserve-3d;transition:transform .15s ease;will-change:transform}
@keyframes spin{to{--ang:360deg}}
.ledger{position:relative;background:linear-gradient(165deg,#1a1138,#150e2e);border-radius:23px;padding:24px;overflow:hidden;box-shadow:0 0 60px -12px rgba(124,58,237,.5),inset 0 1px 0 rgba(255,255,255,.08)}
.ledger::after{content:"";position:absolute;left:0;right:0;bottom:0;height:80px;background:linear-gradient(transparent,#150e2e);pointer-events:none;z-index:3;border-radius:0 0 23px 23px}
.ledger-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:18px;position:relative;z-index:4}
.ledger-head .ttl{color:#fff;font-family:"DM Mono",monospace;font-size:12px;letter-spacing:.14em;text-transform:uppercase;opacity:.6}
.live{display:flex;align-items:center;gap:7px;font-family:"DM Mono",monospace;font-size:11px;letter-spacing:.1em;color:var(--lilac);text-transform:uppercase}
.live .blink{width:7px;height:7px;border-radius:50%;background:#A855F7;box-shadow:0 0 10px 1px #A855F7;animation:cb 1.5s steps(1) infinite}
.ledger-track{display:flex;flex-direction:column;gap:11px;height:336px}
.ledger-track.anim{animation:roll 22s linear infinite}
@keyframes roll{from{transform:translateY(0)}to{transform:translateY(-50%)}}
.ledger-wrap:hover .ledger-track.anim{animation-play-state:paused}
.doc{display:flex;align-items:center;gap:14px;background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.08);border-radius:13px;padding:13px 15px;flex:0 0 auto;min-width:0;transition:background .2s,border-color .2s}
.doc:hover{background:rgba(168,85,247,.14);border-color:var(--border-bright)}
.doc-ic{width:38px;height:38px;border-radius:10px;display:grid;place-items:center;flex:0 0 auto;font-family:"DM Mono",monospace;font-size:11px;font-weight:500;color:#fff;box-shadow:0 0 16px -4px currentColor}
.doc-body{min-width:0;flex:1;overflow:hidden}
.doc-body .t{color:#fff;font-size:14.5px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.doc-body .m{color:var(--muted-2);font-size:12px;font-family:"DM Mono",monospace;margin-top:2px}
.doc-rt{font-family:"DM Mono",monospace;font-size:12px;color:#34D399;flex:0 0 auto}

/* STATS */
.stats{border-top:1px solid var(--border);border-bottom:1px solid var(--border);background:rgba(255,255,255,.02)}
.stats .wrap{display:grid;grid-template-columns:repeat(3,1fr);gap:0}
.stat{padding:44px 28px;text-align:center;border-right:1px solid var(--border)}
.stat:last-child{border-right:none}
.stat .num{font-family:"Space Grotesk",sans-serif;font-weight:700;font-size:48px;letter-spacing:-.03em;line-height:1;background:linear-gradient(180deg,#fff,#C4B5FD);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}
.stat .lbl{margin-top:9px;font-family:"DM Mono",monospace;font-size:12px;letter-spacing:.12em;text-transform:uppercase;color:var(--muted)}

/* SECTION */
.sec{padding:100px 0}
.sec-head{max-width:640px;margin-bottom:50px}
.sec-head.center{margin:0 auto 58px;text-align:center}
.sec h2,.sec-head h2{font-family:"Space Grotesk",sans-serif;font-weight:700;font-size:clamp(31px,3.8vw,46px);line-height:1.08;letter-spacing:-.025em;margin:14px 0 14px;color:#fff}
.sec-head p{font-size:18px;color:var(--muted)}

/* BROWSE */
.fields{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;perspective:1000px}
.field{background:var(--surface);border:1px solid var(--border);border-radius:var(--r);padding:26px 24px;cursor:pointer;position:relative;overflow:hidden;backdrop-filter:blur(10px);transform-style:preserve-3d;transition:box-shadow .28s,border-color .28s,background .28s,transform .12s ease;will-change:transform}
.field::before{content:"";position:absolute;inset:0;background:radial-gradient(200px circle at var(--gx,50%) var(--gy,50%),rgba(168,85,247,.22),transparent 60%);opacity:0;transition:opacity .3s;z-index:0}
.field:hover{border-color:var(--border-bright);background:var(--surface-2);box-shadow:0 18px 44px -16px rgba(124,58,237,.7)}
.field:hover::before{opacity:1}
.field>*{position:relative;z-index:1}
.field .fic{width:48px;height:48px;border-radius:13px;display:grid;place-items:center;margin-bottom:18px;font-size:23px}
.field h3{font-family:"Space Grotesk",sans-serif;font-weight:600;font-size:21px;letter-spacing:-.01em;color:#fff}
.field .cnt{margin-top:6px;font-family:"DM Mono",monospace;font-size:12.5px;color:var(--muted)}
.field .arrow{position:absolute;right:22px;bottom:22px;color:var(--muted);opacity:0;transform:translateX(-6px);transition:.25s}
.field:hover .arrow{opacity:1;transform:translateX(0);color:var(--lilac)}

/* FEATURED */
.feat{position:relative;background:linear-gradient(165deg,rgba(124,58,237,.16),rgba(192,38,211,.08));border:1px solid var(--border-bright);border-radius:30px;padding:66px 0;margin:0 28px;overflow:hidden;backdrop-filter:blur(8px)}
.feat::before{content:"";position:absolute;width:500px;height:500px;background:radial-gradient(circle,rgba(168,85,247,.3),transparent 70%);filter:blur(60px);top:-200px;right:-100px}
.feat .wrap{max-width:1144px}
.feat .eyebrow{color:var(--lilac)}
.car{position:relative}
.car-view{overflow:hidden;padding:4px}
.car-track{display:flex;gap:22px;transition:transform .55s cubic-bezier(.6,.04,.2,1)}
.card{flex:0 0 calc((100% - 44px)/3);background:rgba(255,255,255,.06);border:1px solid var(--border);border-radius:18px;padding:24px;position:relative;overflow:hidden;transition:border-color .25s,background .25s,box-shadow .25s,transform .25s;backdrop-filter:blur(10px)}
.card::before{content:"";position:absolute;inset:0;background:radial-gradient(220px circle at var(--gx,50%) var(--gy,50%),rgba(232,121,249,.18),transparent 60%);opacity:0;transition:opacity .3s}
.card:hover{background:rgba(255,255,255,.1);border-color:var(--border-bright);box-shadow:0 0 36px -10px rgba(168,85,247,.6);transform:translateY(-4px)}
.card:hover::before{opacity:1}
.card>*{position:relative;z-index:1}
.card-top{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:18px}
.tag{font-family:"DM Mono",monospace;font-size:11px;letter-spacing:.08em;text-transform:uppercase;color:var(--lilac);border:1px solid var(--border-bright);padding:4px 9px;border-radius:7px;background:rgba(168,85,247,.1)}
.rate{display:flex;align-items:center;gap:5px;font-size:13px;color:#fff;font-weight:700}
.star{color:#FBBF24}
.card h3{font-family:"Space Grotesk",sans-serif;font-weight:600;font-size:20px;line-height:1.25;letter-spacing:-.01em;margin-bottom:10px;color:#fff}
.card .desc{font-size:14px;color:var(--muted);margin-bottom:20px;min-height:42px}
.card-foot{display:flex;align-items:center;justify-content:space-between;padding-top:16px;border-top:1px solid rgba(255,255,255,.1)}
.uploader{display:flex;align-items:center;gap:9px}
.uploader .ua{width:28px;height:28px;border-radius:50%;display:grid;place-items:center;font-size:11px;font-weight:800;color:#fff}
.uploader .un{font-size:13px;color:rgba(255,255,255,.85);font-weight:600}
.dl{font-family:"DM Mono",monospace;font-size:12px;color:var(--muted-2)}
.car-nav{display:flex;gap:11px;justify-content:flex-end;margin-top:30px}
.car-btn{width:48px;height:48px;border-radius:13px;background:rgba(255,255,255,.07);border:1px solid var(--border-bright);color:#fff;cursor:pointer;display:grid;place-items:center;transition:.2s;backdrop-filter:blur(8px)}
.car-btn:hover{background:linear-gradient(120deg,#8B5CF6,#A855F7);border-color:transparent;box-shadow:0 0 22px -4px rgba(168,85,247,.8)}
.car-btn:disabled{opacity:.25;cursor:not-allowed}
.car-btn:disabled:hover{background:rgba(255,255,255,.07);box-shadow:none}

/* HOW */
.steps{display:grid;grid-template-columns:repeat(3,1fr);gap:0}
.step{padding:0 34px;position:relative}
.step:not(:last-child)::after{content:"";position:absolute;right:0;top:8px;bottom:8px;width:1px;background:var(--border)}
.step .no{font-family:"Space Grotesk",sans-serif;font-weight:700;font-size:16px;color:#fff;display:grid;place-items:center;margin-bottom:18px;width:44px;height:44px;border-radius:50%;background:linear-gradient(145deg,#8B5CF6,#7C3AED);box-shadow:0 0 22px -4px rgba(168,85,247,.8)}
.step h3{font-family:"Space Grotesk",sans-serif;font-weight:600;font-size:22px;letter-spacing:-.01em;margin-bottom:10px;color:#fff}
.step p{color:var(--muted);font-size:15.5px}

/* CTA */
.cta{margin:0 28px 100px}
.cta-inner{position:relative;background:linear-gradient(135deg,#7C3AED,#A855F7 55%,#C026D3);border-radius:30px;padding:76px 56px;text-align:center;overflow:hidden;box-shadow:0 0 70px -16px rgba(168,85,247,.8)}
.cta-inner::before{content:"";position:absolute;inset:0;background:radial-gradient(560px 320px at 50% -20%,rgba(255,255,255,.3),transparent 60%)}
.cta-inner::after{content:"";position:absolute;width:300px;height:300px;background:radial-gradient(circle,rgba(255,255,255,.25),transparent 70%);filter:blur(40px);bottom:-120px;left:-60px;animation:float2 14s ease-in-out infinite}
.cta-inner>*{position:relative;z-index:1}
.cta h2{font-family:"Space Grotesk",sans-serif;font-weight:700;color:#fff;font-size:clamp(32px,4.2vw,48px);letter-spacing:-.025em;line-height:1.06;margin-bottom:18px}
.cta p{color:rgba(255,255,255,.9);font-size:18px;max-width:480px;margin:0 auto 32px}
.cta-btns{display:flex;gap:14px;justify-content:center;flex-wrap:wrap}
.btn-white{background:#fff;color:#7C3AED}
.btn-white:hover{box-shadow:0 16px 30px -10px rgba(0,0,0,.4)}
.btn-ghost-w{background:rgba(255,255,255,.12);color:#fff;box-shadow:inset 0 0 0 1.5px rgba(255,255,255,.45);backdrop-filter:blur(8px)}
.btn-ghost-w:hover{background:rgba(255,255,255,.2)}

/* FOOTER */
.site-footer{border-top:1px solid var(--border);padding:66px 0 36px;background:var(--bg-2)}
.foot-grid{display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr;gap:40px;margin-bottom:48px}
.foot-about{max-width:300px}
.foot-about p{color:var(--muted);font-size:14.5px;margin-top:16px}
.foot-col h4{font-family:"DM Mono",monospace;font-size:12px;letter-spacing:.12em;text-transform:uppercase;color:#fff;margin-bottom:16px}
.foot-col a{display:block;color:var(--muted);font-size:14.5px;margin-bottom:11px;transition:color .2s}
.foot-col a:hover{color:var(--lilac)}
.foot-col ul{list-style:none;padding:0;margin:0}
.foot-col li{margin:0}
.foot-bot{display:flex;justify-content:space-between;align-items:center;padding-top:28px;border-top:1px solid var(--border);flex-wrap:wrap;gap:14px}
.foot-bot p{font-size:13.5px;color:var(--muted-2);font-family:"DM Mono",monospace}

/* SUBMIT FORM + GENERIC CONTENT */
.page-shell{padding:64px 0 100px;position:relative;z-index:2}
.page-head{max-width:680px;margin:0 auto 40px;text-align:center}
.page-head h1{font-family:"Space Grotesk",sans-serif;font-weight:700;font-size:clamp(32px,4.4vw,50px);letter-spacing:-.025em;color:#fff;margin-bottom:14px}
.page-head p{color:var(--muted);font-size:18px}
.form-card{max-width:680px;margin:0 auto;background:linear-gradient(165deg,rgba(255,255,255,.07),rgba(255,255,255,.02));border:1px solid var(--border-bright);border-radius:22px;padding:36px;backdrop-filter:blur(14px);box-shadow:0 0 60px -16px rgba(124,58,237,.5)}
.field-row{margin-bottom:20px}
.field-row label{display:block;font-size:14px;font-weight:600;color:var(--lilac);margin-bottom:8px;font-family:"DM Mono",monospace;letter-spacing:.04em}
.field-row input[type=text],.field-row input[type=email],.field-row select,.field-row textarea{width:100%;background:rgba(255,255,255,.05);border:1px solid var(--border);border-radius:12px;padding:13px 15px;color:#fff;font-family:"Plus Jakarta Sans";font-size:15px;outline:none;transition:border-color .2s,box-shadow .2s}
.field-row input:focus,.field-row select:focus,.field-row textarea:focus{border-color:var(--purple);box-shadow:0 0 0 3px rgba(139,92,246,.18)}
.field-row textarea{min-height:110px;resize:vertical}
.field-row select option{background:#1a1138;color:#fff}
.file-drop{border:1.5px dashed var(--border-bright);border-radius:14px;padding:26px;text-align:center;background:rgba(255,255,255,.03);transition:border-color .2s,background .2s;cursor:pointer}
.file-drop:hover{border-color:var(--purple);background:rgba(139,92,246,.08)}
.file-drop .fd-ic{font-size:30px;margin-bottom:8px}
.file-drop small{display:block;color:var(--muted-2);margin-top:6px;font-size:12.5px}
.file-drop input[type=file]{display:block;margin:12px auto 0;color:var(--muted)}
.two-col{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.notice{padding:14px 18px;border-radius:12px;margin:0 auto 26px;max-width:680px;font-size:14.5px;font-weight:600}
.notice-success{background:rgba(52,211,153,.12);border:1px solid rgba(52,211,153,.4);color:#6EE7B7}
.notice-error{background:rgba(248,113,113,.12);border:1px solid rgba(248,113,113,.4);color:#FCA5A5}

.entry{max-width:760px;margin:0 auto;position:relative;z-index:2}
.entry h1.entry-title{font-family:"Space Grotesk",sans-serif;font-weight:700;font-size:clamp(30px,4vw,46px);letter-spacing:-.025em;color:#fff;margin-bottom:14px}
.entry-meta{font-family:"DM Mono",monospace;font-size:13px;color:var(--muted);margin-bottom:28px;display:flex;gap:16px;flex-wrap:wrap}
.entry-content{color:var(--muted);font-size:16.5px;line-height:1.8}
.entry-content a{color:var(--lilac);text-decoration:underline}
.entry-content h2,.entry-content h3{color:#fff;font-family:"Space Grotesk",sans-serif;margin:28px 0 12px}
.dl-bar{margin:30px 0;display:flex;gap:14px;flex-wrap:wrap;align-items:center}

.archive-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;position:relative;z-index:2}

/* form optional labels + file chips */
.opt{color:var(--muted-2);font-weight:500;font-family:"Plus Jakarta Sans";text-transform:none;letter-spacing:0;font-size:12.5px}
.file-list{display:flex;flex-wrap:wrap;gap:8px;margin-top:12px}
.file-chip{font-family:"DM Mono",monospace;font-size:12px;color:var(--lilac);background:rgba(168,85,247,.12);border:1px solid var(--border-bright);padding:5px 10px;border-radius:8px;max-width:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}

/* single: image gallery */
.gal{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin-bottom:24px}
.gal-item{display:block;border-radius:14px;overflow:hidden;border:1px solid var(--border);aspect-ratio:4/3;background:rgba(255,255,255,.03)}
.gal-item img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .3s}
.gal-item:hover img{transform:scale(1.05)}

/* single: download list */
.dl-list{display:flex;flex-direction:column;gap:10px;margin-top:8px}
.dl-row{display:flex;align-items:center;gap:14px;background:var(--surface);border:1px solid var(--border);border-radius:13px;padding:14px 16px;transition:border-color .2s,background .2s}
.dl-row:hover{border-color:var(--border-bright);background:var(--surface-2)}
.dl-ext{flex:0 0 auto;min-width:48px;text-align:center;font-size:11px;color:#fff;background:linear-gradient(145deg,#8B5CF6,#7C3AED);padding:6px 8px;border-radius:8px}
.dl-name{flex:1;min-width:0;color:var(--txt);font-size:14.5px;font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.dl-go{flex:0 0 auto;color:var(--lilac);font-size:13.5px;font-weight:700}

/* single: category tags */
.entry-cats{display:flex;flex-wrap:wrap;gap:10px;margin-top:30px;padding-top:24px;border-top:1px solid var(--border)}
.entry-cats .tag{text-decoration:none}
.entry-cats .tag:hover{border-color:var(--purple);color:#fff}

/* pagination */
.ah-pager,.navigation .nav-links{display:inline-flex;gap:8px;flex-wrap:wrap;justify-content:center}
.page-numbers{display:inline-grid;place-items:center;min-width:42px;height:42px;padding:0 12px;border-radius:11px;background:var(--surface);border:1px solid var(--border);color:var(--muted);font-weight:700;font-size:14.5px;text-decoration:none;transition:.2s}
.page-numbers:hover{border-color:var(--border-bright);color:#fff;background:var(--surface-2)}
.page-numbers.current{background:linear-gradient(120deg,#8B5CF6,#A855F7);color:#fff;border-color:transparent;box-shadow:0 0 18px -4px rgba(168,85,247,.7)}
.page-numbers.dots{background:transparent;border:none}

/* RESPONSIVE */
@media(max-width:940px){
  .hero-grid{grid-template-columns:1fr;gap:44px}
  .ledger-float{max-width:560px;margin:0 auto;width:100%}
  .fields{grid-template-columns:repeat(2,1fr)}
  .card{flex:0 0 calc((100% - 22px)/2)}
  .steps{grid-template-columns:1fr;gap:40px}
  .step{padding:0}.step:not(:last-child)::after{display:none}
  .foot-grid{grid-template-columns:1fr 1fr}
  .archive-grid{grid-template-columns:repeat(2,1fr)}
  .sec{padding:78px 0}
}
@media(max-width:600px){
  .wrap{padding:0 18px}
  .navlinks,.nav-cta .ghost{display:none}
  .menu-btn{display:grid;place-items:center}
  .nav{height:64px}
  .brand{font-size:19px;gap:9px}
  .mark{width:32px;height:32px;font-size:17px}
  .nav-cta .btn{padding:9px 15px;font-size:13.5px}
  .hero{padding:46px 0 58px}
  .hero h1{font-size:33px;line-height:1.08;margin-bottom:18px}
  .lede{font-size:16.5px;margin-bottom:26px}
  .search{flex-wrap:wrap;padding:10px 12px;gap:10px}
  .search svg{order:1}
  .search input{order:2;flex:1 1 60%;padding:4px 4px}
  .search .btn{order:3;flex:1 1 100%;justify-content:center;padding:12px}
  .badge{font-size:11.5px;margin-bottom:20px}
  .hero-meta{gap:12px;margin-top:22px}
  .ledger{padding:18px}
  .ledger-track{height:300px}
  .grid-floor{height:220px}
  .stats .wrap{grid-template-columns:repeat(3,1fr)}
  .stat{padding:26px 6px}
  .stat .num{font-size:30px}
  .stat .lbl{font-size:9.5px;letter-spacing:.06em;margin-top:6px}
  .sec{padding:60px 0}
  .sec-head{margin-bottom:34px}
  .fields{grid-template-columns:1fr;gap:14px}
  .field{padding:22px 20px}
  .car-track{gap:14px}
  .card{flex:0 0 100%}
  .feat,.cta{margin-left:12px;margin-right:12px}
  .feat{padding:42px 0;border-radius:22px}
  .cta{margin-bottom:64px}
  .cta-inner{padding:48px 22px;border-radius:22px}
  .steps{gap:30px}
  .foot-grid{grid-template-columns:1fr 1fr;gap:26px}
  .foot-about{grid-column:1 / -1;max-width:none}
  .two-col{grid-template-columns:1fr}
  .archive-grid{grid-template-columns:1fr}
  .form-card{padding:22px;border-radius:18px}
  .page-shell{padding:44px 0 70px}
  .gal{grid-template-columns:1fr 1fr}
}
@media(max-width:380px){
  .stat .num{font-size:25px}
  .hero h1{font-size:30px}
  .foot-grid{grid-template-columns:1fr}
}
@media(prefers-reduced-motion:reduce){
  *{animation:none!important;transition:none!important;scroll-behavior:auto!important}
  .caret{display:none}
}

/* ===== ledger title overflow — hard safety (keeps long titles inside the box) ===== */
.hero-grid>*,.ledger-float,.ledger-wrap,.ledger,.ledger-track,.doc,.doc-body{min-width:0;max-width:100%}
.doc{overflow:hidden}
.doc-body{overflow:hidden}
.doc-body .t{display:block;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%}
