
:root{
  --bg:#0b1020;           /* deep navy */
  --bg-soft:#0e1630;      /* softer navy */
  --card:#0f1b3d;         /* card blue */
  --border:rgba(255,255,255,.14);
  --text:#f8fbff;
  --muted:#b9c6e4;
  --accent:#ef233c;       /* vivid red */
  --accent-2:#2f6df6;     /* vibrant blue */
  --maxw:1100px;
  --radius:18px;
  --shadow:0 10px 30px rgba(0,0,0,.35);
}
@media (prefers-color-scheme: light){
  :root{
    --bg:#f6f8ff;
    --bg-soft:#eef2ff;
    --card:#ffffff;
    --border:#c7d2fe;
    --text:#0b1020;
    --muted:#34435e;
    --accent:#d90429;
    --accent-2:#1f4be5;
    --shadow:0 12px 28px rgba(2,6,23,.10);
  }
}
*{box-sizing:border-box}
html,body{margin:0;padding:0;background:linear-gradient(180deg, var(--bg) 0%, var(--bg-soft) 100%);color:var(--text);font:16px/1.6 Inter, ui-sans-serif, system-ui, -apple-system, "Segoe UI", Roboto, Helvetica, Arial, "Apple Color Emoji","Segoe UI Emoji", "Segoe UI Symbol";}
a{color:var(--accent-2);text-decoration:none}
a:hover{text-decoration:underline}
.container{max-width:var(--maxw);margin:0 auto;padding:24px}
header{position:sticky;top:0;z-index:50;background:rgba(11,16,32,.7);backdrop-filter:saturate(160%) blur(10px);border-bottom:1px solid var(--border)}
.nav{display:flex;align-items:center;justify-content:space-between;gap:16px}
.brand{display:flex;align-items:center;gap:12px}
.brand h1{font-size:22px;margin:0;letter-spacing:.2px}
.badge{display:inline-flex;align-items:center;gap:8px;border:1px solid var(--border);padding:8px 12px;border-radius:999px;background:linear-gradient(135deg, rgba(239,35,60,.12), rgba(47,109,246,.12));}
.nav a{margin:0 8px}
.hero{padding:36px 0 8px}
.hero h2{font-size:40px;letter-spacing:.3px;margin:.2rem 0}
.hero p{max-width:800px;font-size:18px;color:var(--muted)}
.btn{
  display:inline-flex;align-items:center;gap:10px;padding:12px 16px;border-radius:14px;
  border:1px solid var(--border);
  background:linear-gradient(135deg, var(--accent), var(--accent-2));
  color:#fff;font-weight:600;box-shadow:var(--shadow)
}
.btn.ghost{background:transparent;color:var(--text)}
.page-wrap{max-width:var(--maxw);margin:0 auto;padding:24px}
.page-title{font-size:34px;margin:20px 0 10px;text-align:center}
.grid{display:grid;gap:16px}
@media(min-width:860px){.grid.cols-3{grid-template-columns:repeat(3,1fr)} .grid.cols-2{grid-template-columns:repeat(2,1fr)}}
.card{background:linear-gradient(180deg, rgba(255,255,255,.04), rgba(255,255,255,.02));border:1px solid var(--border);border-radius:var(--radius);padding:20px;box-shadow:var(--shadow)}
.card h3{margin-top:0}
.kpis{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}
.kpi{background:linear-gradient(135deg, rgba(47,109,246,.16), rgba(239,35,60,.16));padding:16px;border-radius:14px;border:1px solid var(--border);text-align:center}
footer{border-top:1px solid var(--border);margin-top:24px}
footer .container{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap}
/* Forms & tables */
.input, select, input[type="number"], input[type="text"], input[type="date"]{
  width:100%;padding:10px 12px;border-radius:12px;border:1px solid var(--border);background:rgba(255,255,255,.06);color:var(--text)
}
label{font-weight:600}
button{cursor:pointer}
table{width:100%;border-collapse:collapse}
th,td{padding:10px;border-bottom:1px solid var(--border);text-align:left}
tr:hover td{background:rgba(255,255,255,.03)}
.actions{display:flex;gap:8px;flex-wrap:wrap}
/* Autopay Map */
.map{display:grid;grid-template-columns:repeat(31,1fr);gap:4px;margin-top:8px}
.dot{height:16px;border-radius:6px;background:rgba(255,255,255,.12);border:1px solid var(--border);position:relative}
.dot span{position:absolute;top:-22px;left:50%;transform:translateX(-50%);font-size:11px;color:var(--muted)}
.dot.full{background:linear-gradient(135deg, var(--accent-2), var(--accent));}
.dot.hollow{background:transparent;border:2px dashed var(--accent-2)}
.dot.today{outline:2px solid var(--accent);}
.legend{display:flex;gap:10px;align-items:center;margin-top:8px;color:var(--muted)}
.legend .swatch{width:14px;height:14px;border-radius:4px}
/* Cookie banner */
#cookie-banner{position:fixed;left:0;right:0;bottom:0;z-index:999;background:rgba(11,16,32,.94);color:#fff;padding:12px 16px;display:none;box-shadow:0 -10px 26px rgba(0,0,0,.35)}
#cookie-banner .wrap{max-width:var(--maxw);margin:0 auto;display:flex;gap:12px;align-items:center;justify-content:space-between;flex-wrap:wrap}
#cookie-banner p{margin:0;opacity:.95}
#cookie-banner a{color:#8bb2ff;text-decoration:underline}
#cookie-accept{border:1px solid rgba(255,255,255,.35);background:transparent;color:#fff;border-radius:10px;padding:8px 12px;cursor:pointer}
@media (prefers-color-scheme: light){
  #cookie-banner{background:#111827;color:#fff}
  #cookie-banner a{color:#1f4be5}
}
/* Chips */
.chip{display:inline-flex;align-items:center;gap:6px;padding:6px 10px;border-radius:999px;border:1px solid var(--border);background:rgba(255,255,255,.06);font-size:12px}
.status-paid{background:linear-gradient(135deg,#16a34a,#22c55e);color:#001e08}
.status-due{background:linear-gradient(135deg,#f97316,#ef4444);color:#250000}
/* Utilities */
.center{text-align:center}
.mono{font-family:ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace}
.hidden{display:none}

@media(min-width:860px){.grid.cols-7{grid-template-columns:repeat(7,1fr)}}

/* === UI Clean Pass === */
:root{
  --elev:0 8px 20px rgba(0,0,0,.18);
  --elev-2:0 16px 40px rgba(0,0,0,.22);
}
body{letter-spacing:.1px}
.card{box-shadow:var(--elev)}
.card:hover{transform:translateY(-1px);box-shadow:var(--elev-2);transition:all .15s ease}
.btn,.chip{transition:transform .12s ease, box-shadow .12s ease}
.btn:hover,.chip:hover{transform:translateY(-1px)}
.btn:focus,.chip:focus,.input:focus,select:focus{outline:2px solid var(--accent-2); outline-offset:2px}
.input, select, input[type="number"], input[type="text"], input[type="date"]{backdrop-filter:saturate(140%) blur(3px)}
.header-blur{backdrop-filter:saturate(160%) blur(10px)}
.nav a{padding:8px 10px;border-radius:10px}
.nav a:hover{background:rgba(255,255,255,.06)}
.hero h2{line-height:1.2}
.hero .actions .btn.ghost{border-color:rgba(255,255,255,.22)}
.kpi .mono{opacity:.9}
table tbody tr:nth-child(odd){background:rgba(255,255,255,.02)}
table tbody tr:hover{background:rgba(255,255,255,.05)}
th{font-weight:700}
#thisweek li{margin:6px 0}
.dot{border-radius:8px}
#calendar-grid .card{padding:12px}
#calendar-grid .chip{margin-top:6px}
footer .container{opacity:.96}
/* Density option */
:root[data-density="compact"] .card{padding:16px}
:root[data-density="compact"] .grid{gap:10px}
/* Better mobile spacing */
@media (max-width:720px){
  .nav{gap:10px}
  .nav a{padding:6px 8px}
  .hero h2{font-size:32px}
  .page-title{font-size:28px}
}

.muted{opacity:.8}


/* === Brand header polish === */
.header-brand{display:flex;align-items:center;gap:12px}
.logo-mark{width:38px;height:38px;border-radius:12px;display:grid;place-items:center;
  background: linear-gradient(135deg, var(--accent-2), var(--accent));
  color:#fff;font-weight:800;font-size:18px;letter-spacing:.5px;box-shadow:0 6px 18px rgba(0,0,0,.2)}
.brand-text{display:flex;flex-direction:column;line-height:1}
.brand-title{font-size:18px;font-weight:800;letter-spacing:.3px}
.brand-tag{font-size:12px;opacity:.9}
@media (min-width:900px){
  .brand-title{font-size:20px}
  .brand-tag{font-size:13px}
}
/* keep nav spacing tight next to brand */
header .container, header .wrap, header nav{gap:16px}

ol.list{padding-left:20px}


/* === Blog page polish === */
.post article.card{line-height:1.65}
.post h2,.post h3{margin-top:12px}
.post p{margin:10px 0}
.post ul,.post ol{margin:10px 0 10px 18px}
.post hr.soft{border:0;border-top:1px solid var(--border);opacity:.6;margin:20px 0}
.post .meta{opacity:.8;margin-bottom:8px}
/* Ensure blog cards on index look identical to site cards */
.blog-grid .card{display:block;text-decoration:none}

.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}
