/* === DESIGN TOKENS — PLAYBILL LIGHT THEME === */
:root {
  /* Light backgrounds (cream paper feel) */
  --bg: #FAF6E8;            /* main cream */
  --bg2: #FFFCF0;           /* warm paper */
  --bg3: #FFFFFF;           /* pure white cards */
  --bg4: #F0E9CD;           /* darker cream / hover */
  --bg-dark: #0A0A0A;       /* black bars (navbar, footer, CTA) */
  --bg-dark-soft: #1A1A1A;

  /* Iconic Playbill colors */
  --yellow: #FED141;
  --yellow-deep: #E8B800;
  --red: #B91C1C;
  --red-deep: #991B1B;

  /* Text */
  --text: #0A0A0A;
  --text2: #3A3A3A;
  --text3: #6B6B6B;
  --text-on-dark: #FAF6E8;

  /* Borders */
  --border: #0A0A0A;        /* strong black for editorial cards */
  --border2: #4A4A4A;
  --border-light: #D4CDB1;  /* subtle cream divider */

  /* Compatibility aliases (so existing classes still work) */
  --accent: #FED141;
  --accent-dim: rgba(254,209,65,0.20);
  --green: #166534;
  --blue: #1E3A8A;
  --purple: #6B21A8;
  --orange: #C2410C;
  --danger: #B91C1C;
  --success: #166534;

  /* Typography */
  --font: 'Inter', -apple-system, BlinkMacSystemFont, sans-serif;
  --font-display: 'Playfair Display', Georgia, 'Times New Roman', serif;

  /* Editorial sharper corners */
  --r: 3px;
  --r-sm: 2px;
  --r-lg: 4px;
  --r-xl: 6px;

  --shadow: 0 4px 0 var(--border), 0 8px 24px rgba(10,10,10,.07);
  --shadow-sm: 0 2px 0 var(--border);

  --t: 180ms ease;
  --sidebar-w: 280px;
  --header-h: 168px;
}

/* === RESET === */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:var(--font);background:var(--bg);color:var(--text);line-height:1.65;-webkit-font-smoothing:antialiased}
a{color:inherit;text-decoration:none}
button{cursor:pointer;font-family:var(--font)}
img,svg{display:block;max-width:100%}
ul{list-style:none}
h1,h2,h3,h4,h5,h6{font-family:var(--font-display);font-weight:700;line-height:1.15;letter-spacing:-.015em;color:var(--text)}

/* === BUTTONS === */
.btn{display:inline-flex;align-items:center;gap:.5rem;padding:.75rem 1.5rem;border-radius:var(--r);font-size:.8125rem;font-weight:700;border:2px solid var(--border);transition:all var(--t);white-space:nowrap;line-height:1.2;cursor:pointer;text-transform:uppercase;letter-spacing:.1em;font-family:var(--font)}
.btn-primary{background:var(--yellow);color:var(--text);border-color:var(--border)}
.btn-primary:hover{background:var(--text);color:var(--yellow)}
.btn-secondary{background:transparent;color:var(--text);border-color:var(--border)}
.btn-secondary:hover{background:var(--text);color:var(--bg)}
.btn-ghost{background:transparent;color:var(--text2);border:none;padding:.5rem .75rem;text-transform:none;letter-spacing:0;font-weight:500}
.btn-ghost:hover{color:var(--text)}
.btn-danger{background:transparent;color:var(--red);border-color:var(--red);padding:.375rem .75rem;font-size:.6875rem}
.btn-danger:hover{background:var(--red);color:var(--bg)}
.btn-lg{padding:1rem 2.25rem;font-size:.9375rem}
.btn-sm{padding:.375rem .75rem;font-size:.6875rem}

/* === FORMS === */
.form-group{margin-bottom:1.25rem}
.form-row{display:grid;gap:1rem;margin-bottom:1.25rem}
.form-row.cols-2{grid-template-columns:repeat(2,1fr)}
.form-row.cols-3{grid-template-columns:repeat(3,1fr)}
label{display:block;font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--text2);margin-bottom:.5rem}
input[type=text],input[type=email],input[type=tel],input[type=date],input[type=number],input[type=url],input[type=password],textarea,select{
  display:block;width:100%;padding:.75rem 1rem;background:var(--bg3);border:1.5px solid var(--text2);
  border-radius:var(--r-sm);color:var(--text);font-family:var(--font);font-size:.9375rem;line-height:1.5;
  transition:border-color var(--t),box-shadow var(--t);outline:none}
input:focus,textarea:focus,select:focus{border-color:var(--red);box-shadow:0 0 0 3px rgba(185,28,28,.12)}
input::placeholder,textarea::placeholder{color:var(--text3)}
textarea{resize:vertical;min-height:96px}
select{appearance:none;cursor:pointer;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%230A0A0A' stroke-width='2'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right .75rem center;padding-right:2.5rem}
select option{background:var(--bg3)}
.hint{font-size:.75rem;color:var(--text3);margin-top:.375rem;font-style:italic}

/* === CARDS === */
.card{background:var(--bg3);border:2px solid var(--border);border-radius:var(--r);padding:1.75rem}
.card+.card{margin-top:1rem}
.card-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1.25rem;padding-bottom:1rem;border-bottom:1.5px solid var(--border)}
.card-title{font-family:var(--font-display);font-size:1.25rem;font-weight:700}

/* === DIVIDER === */
.divider{height:1.5px;background:var(--border);margin:1.5rem 0}

/* === BADGE === */
.badge{display:inline-flex;align-items:center;padding:.25rem .625rem;border-radius:0;font-size:.6875rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;border:1.5px solid var(--border)}
.badge-teal{background:var(--yellow);color:var(--text);border-color:var(--text)}
.badge-green{background:transparent;color:var(--green);border-color:var(--green)}

/* ========== LANDING PAGE ========== */

/* Navbar — Playbill-style yellow banner + white nav row */
.navbar{position:fixed;top:0;left:0;right:0;z-index:100;display:flex;flex-direction:column;background:transparent;border-bottom:none;transition:none}
.navbar.scrolled{}
.navbar-banner{background:var(--yellow);padding:1.5rem 1.75rem 1.125rem;text-align:center;border-bottom:3px solid var(--text);position:relative}
.navbar-brand{display:inline-flex;align-items:center;gap:.625rem;font-family:var(--font-display);font-size:clamp(1.875rem,5vw,3rem);font-weight:900;color:var(--text);text-transform:uppercase;letter-spacing:.06em;line-height:1}
.brand-icon{display:none}
.navbar-tagline{font-size:.6875rem;font-weight:700;text-transform:uppercase;letter-spacing:.22em;color:var(--text);margin-top:.625rem;font-family:var(--font)}
.navbar-nav-row{background:var(--bg2);border-bottom:2px solid var(--text)}
.nav-container{max-width:1280px;margin:0 auto;padding:0 1.75rem;display:flex;align-items:center;gap:1.5rem;width:100%;min-height:52px}
.navbar-nav{display:flex;align-items:center;gap:.25rem;flex:1;justify-content:center;flex-wrap:wrap}
.nav-item{position:relative}
.nav-btn{display:flex;align-items:center;gap:.375rem;padding:.625rem .875rem;font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:var(--text);border-radius:0;transition:all var(--t);cursor:pointer;border:none;background:none}
.nav-btn:hover,.nav-btn.open{color:var(--red);background:transparent}
.nav-chevron{transition:transform var(--t)}
.nav-item:hover .nav-chevron{transform:rotate(180deg)}
.nav-dropdown{position:absolute;top:calc(100% + 8px);left:50%;transform:translateX(-50%) translateY(-6px);min-width:220px;background:var(--bg3);border:2px solid var(--text);border-radius:0;padding:.5rem;box-shadow:5px 5px 0 var(--yellow);opacity:0;visibility:hidden;transition:all var(--t);z-index:200}
.nav-item:hover .nav-dropdown{opacity:1;visibility:visible;transform:translateX(-50%) translateY(0)}
.nav-dropdown a{display:block;padding:.625rem .875rem;font-size:.8125rem;font-weight:500;color:var(--text);border-radius:0;transition:all var(--t);text-transform:none;letter-spacing:0;text-align:left}
.nav-dropdown a:hover{background:var(--yellow);color:var(--text)}
.navbar-actions{display:flex;align-items:center;gap:.625rem;flex-shrink:0}
.navbar-actions .btn{padding:.5rem 1rem;font-size:.6875rem}
.navbar-actions .btn-secondary{color:var(--text);border-color:var(--text)}
.navbar-actions .btn-secondary:hover{background:var(--text);color:var(--bg2)}

/* Hero — newspaper headline style */
.hero{padding:calc(var(--header-h) + 5rem) 0 5rem;position:relative;overflow:hidden;text-align:center;background:var(--bg)}
.hero::before{content:'';position:absolute;left:0;right:0;top:var(--header-h);height:1px;background:transparent;pointer-events:none}
.container{max-width:1280px;margin:0 auto;padding:0 1.75rem}
.hero-badge{display:inline-flex;align-items:center;gap:.5rem;padding:.5rem 1rem;background:var(--text);color:var(--yellow);border:none;border-radius:0;font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.15em;margin-bottom:1.5rem}
.hero h1{font-family:var(--font-display);font-size:clamp(2.75rem,7vw,5.5rem);font-weight:900;line-height:1.02;letter-spacing:-.025em;margin-bottom:1.5rem;max-width:900px;margin-left:auto;margin-right:auto;color:var(--text)}
.gradient-text{background:none;-webkit-background-clip:initial;-webkit-text-fill-color:var(--red);background-clip:initial;color:var(--red);font-style:italic}
.hero p{font-size:1.1875rem;color:var(--text2);max-width:620px;margin:0 auto 2rem;line-height:1.65}
.hero-actions{display:flex;align-items:center;justify-content:center;gap:1rem;flex-wrap:wrap}
.hero-trust{margin-top:3rem;display:flex;align-items:center;justify-content:center;gap:2.5rem;color:var(--text3);font-size:.8125rem;flex-wrap:wrap;text-transform:uppercase;letter-spacing:.1em;font-weight:600}
.hero-trust-item{display:flex;align-items:center;gap:.5rem}

/* Preview mockup — light/editorial */
.hero-preview{margin-top:4rem;max-width:920px;margin-left:auto;margin-right:auto}
.preview-inner{background:var(--bg3);border:2px solid var(--border);border-radius:var(--r);padding:1.5rem;box-shadow:8px 8px 0 var(--yellow)}
.preview-bar{display:flex;align-items:center;gap:.75rem;margin-bottom:1.25rem;padding-bottom:1rem;border-bottom:1.5px solid var(--border)}
.preview-dots{display:flex;gap:6px}
.preview-dots span{width:12px;height:12px;border-radius:50%;border:1px solid var(--text)}
.preview-dots span:nth-child(1){background:var(--red)}
.preview-dots span:nth-child(2){background:var(--yellow)}
.preview-dots span:nth-child(3){background:var(--bg3)}
.preview-label{font-size:.75rem;color:var(--text2);margin:0 auto;font-weight:600;text-transform:uppercase;letter-spacing:.08em}
.preview-grid{display:grid;grid-template-columns:160px 1fr;gap:1rem;min-height:200px}
.preview-sidebar-mock{background:var(--bg);border:1px solid var(--border);border-radius:var(--r-sm);padding:.75rem}
.pmock-item{padding:.375rem .625rem;border-radius:0;font-size:.75rem;color:var(--text2);margin-bottom:2px;font-weight:500}
.pmock-item.act{background:var(--yellow);color:var(--text);font-weight:700}
.preview-fields{display:flex;flex-direction:column;gap:.625rem}
.pfield-row{display:grid;grid-template-columns:1fr 1fr;gap:.625rem}
.pfield{background:var(--bg);border:1px solid var(--border);border-radius:var(--r-sm);padding:.625rem}
.pfield-label{font-size:9px;color:var(--text3);text-transform:uppercase;letter-spacing:.08em;margin-bottom:.25rem;font-weight:700}
.pfield-val{font-size:.8125rem;color:var(--text);font-weight:500}
.pfield-bar{height:6px;background:var(--bg4);border-radius:0;overflow:hidden;margin-top:.5rem;border:1px solid var(--border)}
.pfield-fill{height:100%;width:15%;background:var(--yellow);border-radius:0}

/* Sections */
.section{padding:5rem 0;background:var(--bg)}
.section-alt{background:var(--bg2);border-top:2px solid var(--border);border-bottom:2px solid var(--border)}
.section-header{text-align:center;margin-bottom:4rem}
.section-tag{display:inline-block;font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.18em;color:var(--red);margin-bottom:1rem;padding-bottom:.375rem;border-bottom:2px solid var(--red)}
.section-title{font-family:var(--font-display);font-size:clamp(2rem,4.5vw,3.25rem);font-weight:900;letter-spacing:-.025em;margin-bottom:1rem;color:var(--text);line-height:1.1}
.section-desc{font-size:1.125rem;color:var(--text2);max-width:580px;margin:0 auto;line-height:1.65}

/* Features grid — editorial cards with yellow top stripe */
.features-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:1.75rem}
.feature-card{background:var(--bg3);border:2px solid var(--border);border-radius:var(--r);padding:2rem 1.5rem 1.75rem;transition:all var(--t);position:relative;overflow:hidden}
.feature-card::before{content:'';position:absolute;top:0;left:0;right:0;height:6px;background:var(--yellow);opacity:1}
.feature-card:hover{transform:translate(-3px,-3px);box-shadow:6px 6px 0 var(--text)}
.feature-icon{width:52px;height:52px;border-radius:0;border:2px solid var(--border);background:var(--yellow);display:flex;align-items:center;justify-content:center;font-size:24px;margin-bottom:1.25rem}
.icon-teal,.icon-blue,.icon-green,.icon-purple,.icon-orange{background:var(--yellow)}
.feature-card h3{font-family:var(--font-display);font-size:1.25rem;font-weight:700;margin-bottom:.5rem}
.feature-card p{font-size:.9375rem;color:var(--text2);line-height:1.65}

/* Stats — black band with yellow numbers */
.stats-section{padding:4rem 0;background:var(--bg-dark);color:var(--text-on-dark);border-top:4px solid var(--yellow);border-bottom:4px solid var(--yellow)}
.stats-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:2rem;text-align:center}
.stat-number{font-family:var(--font-display);font-size:clamp(3rem,7vw,5rem);font-weight:900;color:var(--yellow);line-height:1;margin-bottom:.75rem;letter-spacing:-.02em;background:none;-webkit-background-clip:initial;-webkit-text-fill-color:var(--yellow);background-clip:initial}
.stat-label{font-size:.875rem;color:var(--text-on-dark);line-height:1.55}

/* Steps */
.steps-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:2.5rem;position:relative}
.steps-grid::before{content:'';position:absolute;top:36px;left:calc(100%/6);right:calc(100%/6);height:2px;background:var(--text);z-index:0}
.step{text-align:center;position:relative;z-index:1}
.step-num{width:72px;height:72px;border-radius:50%;background:var(--yellow);border:3px solid var(--text);display:flex;align-items:center;justify-content:center;font-family:var(--font-display);font-size:1.625rem;font-weight:900;color:var(--text);margin:0 auto 1.25rem;position:relative;z-index:1}
.step h3{font-family:var(--font-display);font-size:1.25rem;font-weight:700;margin-bottom:.5rem}
.step p{font-size:.9375rem;color:var(--text2);line-height:1.65}

/* CTA — dramatic black box */
.cta-section{padding:6rem 0;text-align:center;position:relative;overflow:hidden;background:var(--bg)}
.cta-section::before{content:'';position:absolute;inset:0;background:none;pointer-events:none}
.cta-box{background:var(--bg-dark);color:var(--text-on-dark);border:2px solid var(--border);border-radius:var(--r);padding:4.5rem 2rem;max-width:760px;margin:0 auto;box-shadow:8px 8px 0 var(--yellow);position:relative}
.cta-box h2{font-family:var(--font-display);font-size:clamp(2rem,4.5vw,3rem);font-weight:900;margin-bottom:1.25rem;color:var(--yellow);line-height:1.1}
.cta-box p{font-size:1.125rem;color:var(--text-on-dark);margin-bottom:2rem;opacity:.92}
.cta-box .btn-primary{background:var(--yellow);color:var(--text);border-color:var(--yellow)}
.cta-box .btn-primary:hover{background:var(--bg);color:var(--text);border-color:var(--bg)}

/* Categories */
.cats-two-col{display:grid;grid-template-columns:1fr 1fr;gap:4rem;align-items:center}
.cats-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1rem}
.cat-card{background:var(--bg3);border:2px solid var(--border);border-radius:var(--r);padding:1.25rem;display:flex;align-items:center;gap:1rem;transition:all var(--t)}
.cat-card:hover{transform:translate(-2px,-2px);box-shadow:4px 4px 0 var(--yellow)}
.cat-icon{font-size:28px;flex-shrink:0;width:48px;height:48px;background:var(--yellow);border:2px solid var(--border);display:flex;align-items:center;justify-content:center}
.cat-info h3{font-family:var(--font-display);font-size:1.0625rem;font-weight:700;margin-bottom:.25rem}
.cat-info p{font-size:.8125rem;color:var(--text2)}

/* Footer — black bar */
.footer{background:var(--bg-dark);color:var(--text-on-dark);border-top:4px solid var(--yellow);padding:4rem 0 2rem}
.footer-grid{display:grid;grid-template-columns:2fr repeat(4,1fr);gap:2rem;margin-bottom:3rem}
.footer-brand h2{font-family:var(--font-display);font-size:1.5rem;font-weight:900;margin-bottom:.75rem;color:var(--yellow);text-transform:uppercase;letter-spacing:.04em}
.footer-brand p{font-size:.875rem;color:var(--text-on-dark);max-width:240px;line-height:1.7;opacity:.85}
.footer-col h4{font-size:.75rem;font-weight:700;margin-bottom:1rem;color:var(--yellow);text-transform:uppercase;letter-spacing:.12em;font-family:var(--font)}
.footer-col li{margin-bottom:.625rem}
.footer-col a{font-size:.875rem;color:var(--text-on-dark);transition:color var(--t);opacity:.85}
.footer-col a:hover{color:var(--yellow);opacity:1}
.footer-bottom{border-top:1px solid var(--border2);padding-top:1.5rem;display:flex;align-items:center;justify-content:space-between;font-size:.75rem;color:var(--text-on-dark);opacity:.7}
.footer-badges{display:flex;gap:.75rem}
.footer-badge{padding:.25rem .625rem;border:1px solid var(--text-on-dark);border-radius:0;font-size:.6875rem;color:var(--text-on-dark);text-transform:uppercase;letter-spacing:.08em;font-weight:600;opacity:.85}

/* ========== DASHBOARD ========== */

.app-wrap{display:flex;min-height:100vh;background:var(--bg)}

/* Sidebar — cream with black brand bar */
.app-sidebar{width:var(--sidebar-w);flex-shrink:0;background:var(--bg2);border-right:2px solid var(--border);position:fixed;top:0;left:0;bottom:0;display:flex;flex-direction:column;overflow-y:auto;z-index:50}
.sb-head{padding:1.5rem 1.25rem 1.25rem;border-bottom:2px solid var(--border);background:var(--bg-dark);color:var(--text-on-dark)}
.sb-brand{display:flex;align-items:center;gap:.75rem;margin-bottom:1rem}
.sb-brand .logo{font-family:var(--font-display);font-size:1.125rem;font-weight:900;color:var(--yellow);text-transform:uppercase;letter-spacing:.04em}
.sb-brand .brand-icon{width:32px;height:32px;font-size:16px}
.sb-user{display:flex;align-items:center;gap:.75rem;padding:.625rem .875rem;background:var(--bg-dark-soft);border:1px solid var(--yellow);border-radius:var(--r-sm);cursor:pointer;transition:background var(--t)}
.sb-user:hover{background:var(--bg-dark-soft);border-color:var(--bg)}
.avatar{width:36px;height:36px;border-radius:50%;background:var(--yellow);border:2px solid var(--bg);display:flex;align-items:center;justify-content:center;font-weight:900;font-size:.875rem;color:var(--text);flex-shrink:0;font-family:var(--font-display)}
.user-name{font-size:.875rem;font-weight:700;color:var(--text-on-dark)}
.user-email{font-size:.75rem;color:var(--text-on-dark);opacity:.7}
.sb-progress{padding:1rem 1.25rem;border-bottom:1.5px solid var(--border-light);background:var(--bg2)}
.prog-label{font-size:.6875rem;color:var(--text2);display:flex;justify-content:space-between;margin-bottom:.5rem;text-transform:uppercase;letter-spacing:.08em;font-weight:700}
.prog-bar{height:6px;background:var(--bg4);border-radius:0;overflow:hidden;border:1px solid var(--border)}
.prog-fill{height:100%;background:var(--yellow);border-radius:0;transition:width .4s ease;width:0%}
.sb-nav{flex:1;padding:.75rem;overflow-y:auto}
.sb-section-label{font-size:.6875rem;font-weight:700;text-transform:uppercase;letter-spacing:.12em;color:var(--text3);padding:.75rem .625rem .5rem}
.sb-link{display:flex;align-items:center;gap:.75rem;padding:.5625rem .75rem;border-radius:var(--r-sm);font-size:.875rem;color:var(--text2);transition:all var(--t);cursor:pointer;border:none;background:none;width:100%;text-align:left;margin-bottom:2px;position:relative;font-weight:500}
.sb-link:hover{background:var(--bg4);color:var(--text)}
.sb-link.active{background:var(--yellow);color:var(--text);font-weight:700}
.sb-link.active::before{content:'';position:absolute;left:0;top:4px;bottom:4px;width:4px;background:var(--text);border-radius:0}
.sb-link .icon{font-size:15px;width:20px;text-align:center;flex-shrink:0}
.sb-check{margin-left:auto;width:18px;height:18px;border-radius:50%;border:2px solid var(--text2);display:flex;align-items:center;justify-content:center;font-size:10px;flex-shrink:0;transition:all var(--t);background:var(--bg3)}
.sb-check.done{background:var(--text);border-color:var(--text);color:var(--yellow)}
.sb-foot{padding:1rem 1.25rem;border-top:1.5px solid var(--border-light);display:flex;flex-direction:column;gap:.5rem}

/* Main area */
.app-main{margin-left:var(--sidebar-w);flex:1;display:flex;flex-direction:column;min-height:100vh;background:var(--bg)}
.app-header{position:sticky;top:0;z-index:40;background:var(--bg2);border-bottom:2px solid var(--border);padding:0 2rem;height:64px;display:flex;align-items:center;justify-content:space-between}
.breadcrumb{display:flex;align-items:center;gap:.5rem;font-size:.75rem;color:var(--text2);text-transform:uppercase;letter-spacing:.1em;font-weight:600}
.breadcrumb .crumb-current{color:var(--text);font-weight:700}
.header-actions{display:flex;align-items:center;gap:.75rem}
.app-content{flex:1;padding:2.5rem 2rem;max-width:920px}

/* Panels */
.panel{display:none}
.panel.active{display:block;animation:fadeUp .2s ease}
@keyframes fadeUp{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}
.panel-head{margin-bottom:2.5rem;padding-bottom:1.25rem;border-bottom:2px solid var(--border)}
.panel-head h1{font-family:var(--font-display);font-size:2.25rem;font-weight:900;letter-spacing:-.025em;margin-bottom:.5rem;line-height:1.1}
.panel-head p{font-size:1rem;color:var(--text2);line-height:1.65}

/* Dynamic list entries */
.entry{background:var(--bg3);border:2px solid var(--border);border-radius:var(--r);padding:1.5rem;margin-bottom:1.25rem;position:relative}
.entry-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1rem;padding-bottom:.875rem;border-bottom:1.5px solid var(--border-light)}
.entry-title{font-family:var(--font-display);font-size:1.0625rem;font-weight:700}
.entry-timestamps{display:flex;gap:.75rem;flex-wrap:wrap;font-size:.6875rem;color:var(--text3);margin-top:.875rem;padding-top:.625rem;border-top:1.5px solid var(--border-light);text-transform:uppercase;letter-spacing:.06em;font-weight:600}
.rec-dot{width:10px;height:10px;background:var(--red);border-radius:50%;animation:recPulse 1s ease-in-out infinite;flex-shrink:0}
@keyframes recPulse{0%,100%{opacity:1}50%{opacity:.2}}
.rec-status{display:flex;align-items:center;gap:.625rem;color:var(--red);font-weight:700;font-size:.875rem;margin-bottom:1rem;text-transform:uppercase;letter-spacing:.08em}
.rec-timer{font-variant-numeric:tabular-nums}
.rec-item{background:var(--bg3);border:2px solid var(--border);border-radius:var(--r);padding:1rem;margin-bottom:.75rem}
.rec-item-head{display:flex;align-items:flex-start;justify-content:space-between;gap:1rem}
.rec-item-title{font-family:var(--font-display);font-size:1rem;font-weight:700}
.rec-item-meta{font-size:.75rem;color:var(--text2);margin-top:.25rem}
.add-entry{display:flex;align-items:center;justify-content:center;gap:.5rem;padding:1rem;border:2px dashed var(--text2);border-radius:var(--r);font-size:.8125rem;color:var(--text2);background:transparent;cursor:pointer;width:100%;transition:all var(--t);margin-top:.75rem;text-transform:uppercase;letter-spacing:.08em;font-weight:600}
.add-entry:hover{border-color:var(--text);color:var(--text);background:var(--bg4)}

/* Toast */
.toast{position:fixed;bottom:1.5rem;right:1.5rem;background:var(--bg-dark);border:2px solid var(--yellow);border-radius:var(--r);padding:.875rem 1.5rem;font-size:.8125rem;color:var(--yellow);box-shadow:4px 4px 0 var(--yellow);display:flex;align-items:center;gap:.5rem;z-index:999;opacity:0;transform:translateY(8px);transition:all .3s ease;pointer-events:none;text-transform:uppercase;letter-spacing:.08em;font-weight:700}
.toast.show{opacity:1;transform:translateY(0)}

/* Responsive */
@media(max-width:1024px){.footer-grid{grid-template-columns:1fr 1fr;gap:2rem}.steps-grid{grid-template-columns:1fr}.steps-grid::before{display:none}.stats-grid{grid-template-columns:1fr;gap:2.5rem}.cats-two-col{grid-template-columns:1fr}}
@media(max-width:768px){.navbar-nav{display:none}.hero h1{font-size:2.5rem}.features-grid{grid-template-columns:1fr}.footer-grid{grid-template-columns:1fr 1fr}.app-main{margin-left:0}.app-sidebar{transform:translateX(-100%);transition:transform var(--t)}.app-sidebar.open{transform:translateX(0)}.app-content{padding:1.5rem 1.25rem}.form-row.cols-2,.form-row.cols-3{grid-template-columns:1fr}.cats-grid{grid-template-columns:1fr}.nav-container{padding:0 1rem;gap:1rem}.navbar-brand{font-size:1.125rem}}
@media(max-width:480px){.hero-actions{flex-direction:column}.footer-grid{grid-template-columns:1fr}.hero-trust{gap:1rem}}

/* === DIGITAL ACCORDION === */
.digital-grid{display:grid;grid-template-columns:1fr 1fr;gap:1rem;margin-bottom:1.5rem}
.dig-cat{background:var(--bg3);border:2px solid var(--border);border-radius:var(--r);overflow:hidden;transition:all var(--t)}
.dig-cat.open{box-shadow:4px 4px 0 var(--yellow)}
.dig-cat-btn{display:flex;align-items:center;gap:.875rem;padding:1rem 1.25rem;width:100%;background:none;border:none;color:var(--text);cursor:pointer;font-family:var(--font-display);font-size:1rem;font-weight:700;transition:background var(--t);text-align:left}
.dig-cat-btn:hover{background:var(--bg4)}
.dig-cat-icon{width:28px;height:28px;border-radius:0;background:var(--yellow);border:1.5px solid var(--text);color:var(--text);display:flex;align-items:center;justify-content:center;font-size:18px;font-weight:700;flex-shrink:0;transition:transform var(--t);user-select:none;line-height:1}
.dig-cat.open .dig-cat-icon{transform:rotate(45deg)}
.dig-cat-body{display:none;padding:1rem 1.25rem 1.25rem;border-top:1.5px solid var(--border);animation:fadeUp .15s ease;background:var(--bg2)}
.dig-cat.open .dig-cat-body{display:block}
@media(max-width:768px){.digital-grid{grid-template-columns:1fr}}

/* === LOGIN PAGE === */
.login-icon{width:64px;height:64px;background:var(--yellow);border:2px solid var(--text);border-radius:0;display:flex;align-items:center;justify-content:center;font-size:32px;margin:0 auto 1.25rem}
