/* ── DASHBOARD SPECIFIC STYLES (extracted from index.html) ── */

/* ── GEO-TIME ── */
.geo-time-widget { position:fixed; top:50%; right:24px; transform:translateY(-50%); z-index:10000; display:flex; flex-direction:column; align-items:center; gap:0; background:rgba(8,15,24,0.82); backdrop-filter:var(--blur-strong); border:1px solid rgba(0,255,136,0.15); border-left:2px solid rgba(0,255,136,0.32); border-radius:16px; padding:20px 16px; min-width:120px; box-shadow:0 12px 48px rgba(0,0,0,0.55),0 0 0 1px rgba(0,255,136,0.05),inset 0 1px 0 rgba(255,255,255,0.04); animation:slideInRight 0.5s ease-out both; cursor:pointer; user-select:none; }
.geo-time-widget:hover { border-left-color:rgba(0,255,136,0.6); box-shadow:0 12px 48px rgba(0,0,0,0.55),0 0 0 1px rgba(0,255,136,0.12),inset 0 1px 0 rgba(255,255,255,0.04); }

/* ── MICRO CALENDAR ── */
#microCal { position:fixed; top:50%; right:168px; transform:translateY(-50%); z-index:9999; background:rgba(8,15,24,0.92); backdrop-filter:var(--blur-strong); border:1px solid rgba(0,255,136,0.18); border-right:2px solid rgba(0,255,136,0.32); border-radius:16px; padding:16px 14px; min-width:196px; box-shadow:0 12px 48px rgba(0,0,0,0.65),0 0 0 1px rgba(0,255,136,0.06); display:none; animation:mcalIn 0.2s ease-out both; }
#microCal.open { display:block; }
@keyframes mcalIn { from { opacity:0; transform:translateY(-50%) translateX(10px); } to { opacity:1; transform:translateY(-50%) translateX(0); } }
.mcal-header { display:flex; align-items:center; justify-content:space-between; margin-bottom:12px; }
.mcal-month { font-family:'JetBrains Mono',monospace; font-size:0.72rem; font-weight:700; color:var(--gym); text-transform:uppercase; letter-spacing:2px; }
.mcal-grid { display:grid; grid-template-columns:repeat(7,1fr); gap:2px; }
.mcal-dow { font-family:'JetBrains Mono',monospace; font-size:0.44rem; font-weight:700; color:var(--text-muted); text-align:center; padding:3px 0; text-transform:uppercase; letter-spacing:1px; }
.mcal-dow.sun,.mcal-dow.sat { color:rgba(0,255,136,0.45); }
.mcal-day { font-family:'JetBrains Mono',monospace; font-size:0.6rem; text-align:center; padding:4px 2px; border-radius:6px; color:var(--text-secondary); line-height:1; }
.mcal-day.empty { color:transparent; }
.mcal-day.today { background:var(--gym); color:#000; font-weight:700; box-shadow:0 0 8px rgba(0,255,136,0.5); border-radius:6px; }
.mcal-day.sun,.mcal-day.sat { color:rgba(0,255,136,0.55); }
.gt-clock { display:flex; flex-direction:column; align-items:center; border-right:none; border-bottom:1px solid rgba(255,255,255,0.08); padding-right:0; padding-bottom:14px; width:100%; }
.gt-time { font-family:'JetBrains Mono',monospace; font-size:1.4rem; font-weight:700; color:var(--text-primary); line-height:1; letter-spacing:2px; text-shadow:0 0 18px rgba(0,255,136,0.35); }
.gt-date { font-size:0.52rem; text-transform:uppercase; letter-spacing:2px; color:var(--text-muted); margin-top:6px; text-align:center; }
.gt-loc { display:flex; flex-direction:column; align-items:center; gap:5px; padding-top:14px; width:100%; }
.gt-city { font-size:0.72rem; font-weight:600; color:var(--gym); text-transform:uppercase; letter-spacing:1px; display:flex; align-items:center; gap:5px; justify-content:center; }
.gt-city i { font-size:0.65rem; animation:pulse 2s infinite; }
.gt-coords { font-family:'JetBrains Mono',monospace; font-size:0.48rem; color:var(--text-muted); letter-spacing:1px; opacity:0.7; text-align:center; }

/* ── STATS BAR ── */
.stats-bar { display:flex; gap:12px; align-items:stretch; }
.sbar-pill { flex:1; min-width:0; padding:18px 10px; text-align:center; transition:filter 0.3s ease, transform 0.3s cubic-bezier(0.2,0.9,0.4,1.1); cursor:default; position:relative; }
.sbar-pos { position:absolute; top:6px; left:8px; font-family:'JetBrains Mono',monospace; font-size:0.44rem; font-weight:700; color:rgba(255,255,255,0.3); letter-spacing:0.5px; pointer-events:none; line-height:1; }
/* GYM – hexagon – green */
.sbar-gym     { clip-path:polygon(25% 0%,75% 0%,100% 50%,75% 100%,25% 100%,0% 50%); background:linear-gradient(155deg,rgba(0,255,0,0.22) 0%,rgba(0,200,60,0.08) 100%); filter:drop-shadow(0 0 10px rgba(0,255,0,0.22)); padding:20px 22px; }
/* READ – parallelogram (right-lean) – yellow */
.sbar-read    { clip-path:polygon(10% 0%,100% 0%,90% 100%,0% 100%); background:linear-gradient(155deg,rgba(255,240,0,0.2) 0%,rgba(200,180,0,0.07) 100%); filter:drop-shadow(0 0 10px rgba(255,240,0,0.18)); }
/* PLANNING – shield (pointed bottom) – silver */
.sbar-mscript { clip-path:polygon(0% 0%,100% 0%,100% 68%,50% 100%,0% 68%); background:linear-gradient(155deg,rgba(200,210,230,0.2) 0%,rgba(160,170,190,0.07) 100%); filter:drop-shadow(0 0 10px rgba(200,210,230,0.16)); padding:16px 10px 28px; }
/* EARLY WAKE – pentagon (pointed top) – violet */
.sbar-wake    { clip-path:polygon(50% 0%,100% 32%,83% 100%,17% 100%,0% 32%); background:linear-gradient(155deg,rgba(138,43,226,0.28) 0%,rgba(100,20,180,0.1) 100%); filter:drop-shadow(0 0 10px rgba(138,43,226,0.32)); padding:22px 12px 16px; }
/* FOCUS HRS – trapezoid (wider top) – red */
.sbar-focus   { clip-path:polygon(6% 0%,94% 0%,100% 100%,0% 100%); background:linear-gradient(155deg,rgba(255,40,40,0.22) 0%,rgba(200,0,0,0.08) 100%); filter:drop-shadow(0 0 10px rgba(255,40,40,0.25)); }
/* PERFECT – octagon – gold */
.sbar-perfect { clip-path:polygon(26% 0%,74% 0%,100% 26%,100% 74%,74% 100%,26% 100%,0% 74%,0% 26%); background:linear-gradient(155deg,rgba(255,217,102,0.24) 0%,rgba(220,160,0,0.08) 100%); filter:drop-shadow(0 0 10px rgba(255,217,102,0.26)); padding:18px 18px; }
.sbar-gym:hover     { transform:translateY(-3px); filter:drop-shadow(0 4px 18px rgba(0,255,0,0.65)); }
.sbar-read:hover    { transform:translateY(-3px); filter:drop-shadow(0 4px 18px rgba(255,240,0,0.58)); }
.sbar-mscript:hover { transform:translateY(-3px); filter:drop-shadow(0 4px 18px rgba(200,210,230,0.5)); }
.sbar-wake:hover    { transform:translateY(-3px); filter:drop-shadow(0 4px 18px rgba(138,43,226,0.68)); }
.sbar-focus:hover   { transform:translateY(-3px); filter:drop-shadow(0 4px 18px rgba(255,40,40,0.68)); }
.sbar-perfect:hover { transform:translateY(-3px); filter:drop-shadow(0 4px 18px rgba(255,217,102,0.62)); }
.pv { font-family:'Space Grotesk',monospace; font-size:1.9rem; font-weight:600; color:var(--pc,var(--text-primary)); line-height:1; }
.pl { font-size:0.6rem; font-weight:600; text-transform:uppercase; letter-spacing:2px; color:var(--text-muted); margin-top:6px; }

/* ── MONTH BRICKS ── */
.month-label { font-size:0.65rem; color:var(--text-muted); text-align:center; margin-top:32px; letter-spacing:3.5px; text-transform:uppercase; font-weight:600; text-shadow: 0 0 12px rgba(0, 255, 136, 0.12); }
.month-track { display:flex; gap:20px; margin:16px auto 0; justify-content:center; flex-wrap:wrap; max-width:1040px; }
.month-group { display:flex; flex-direction:column; align-items:stretch; gap:10px; background:rgba(10, 20, 32, 0.42); backdrop-filter:var(--blur-strong); border:1px solid rgba(255,255,255,0.06); border-radius:22px; padding:20px 18px; min-width:184px; box-shadow:0 12px 36px rgba(0,0,0,0.48), inset 0 1px 0 rgba(255,255,255,0.03); transition:all 0.35s cubic-bezier(0.2,0.9,0.3,1.1); }
.month-group:hover { border-color:rgba(0, 255, 136, 0.28); box-shadow:0 12px 40px rgba(0, 255, 136, 0.08), 0 0 1px rgba(0, 255, 136, 0.15); transform:translateY(-2px); }
.mg-header { display:flex; justify-content:space-between; align-items:center; width:100%; border-bottom:1px solid rgba(255,255,255,0.06); padding-bottom:10px; margin-bottom:4px; }
.mg-label { font-family:'Space Grotesk',monospace; font-size:0.65rem; letter-spacing:2px; text-transform:uppercase; color:var(--text-secondary); font-weight:700; }
.mg-radial-progress { position:relative; width:22px; height:22px; display:flex; align-items:center; justify-content:center; }
.mg-radial-svg { width:22px; height:22px; transform:rotate(-90deg); }
.mg-radial-svg circle { fill:none; stroke-width:3.5; }
.mg-radial-svg .radial-bg { stroke:rgba(255,255,255,0.07); }
.mg-radial-svg .radial-stroke { stroke:var(--gym); stroke-linecap:round; transition:stroke-dasharray 0.8s ease-out; }
.mg-progress-text { position:absolute; font-family:'Space Grotesk',monospace; font-size:0.42rem; font-weight:700; color:var(--text-primary); pointer-events:none; }
.mg-grid { display:grid; grid-template-columns:repeat(7,11px); gap:5px 4px; justify-content:center; }
.brick { width:11px; height:13px; background:rgba(255,255,255,0.04); clip-path:polygon(50% 0%, 100% 25%, 100% 75%, 50% 100%, 0% 75%, 0% 25%); transition:all 0.3s cubic-bezier(0.4,0,0.2,1); cursor:pointer; }
.brick:hover { transform:scale(1.3) rotate(5deg); filter:brightness(1.22); z-index:5; }
.brick-spacer { width:11px; height:13px; visibility:hidden; }
.brick.score-1 { background:#ff4b2b; filter:drop-shadow(0 0 3px rgba(255,75,43,0.5)); }
.brick.score-2 { background:#ff9000; filter:drop-shadow(0 0 3px rgba(255,144,0,0.5)); }
.brick.score-3 { background:#007aff; filter:drop-shadow(0 0 3px rgba(0,122,255,0.5)); }
.brick.score-4 { background:#00ff00; filter:drop-shadow(0 0 5px rgba(0,255,0,0.6)); }
.brick.is-past { background:rgba(255,255,255,0.11); }
.brick.today { background:#00ff88; transform:scale(1.25); animation:brickTodayPulse 2s ease-in-out infinite alternate; z-index:3; filter:drop-shadow(0 0 6px rgba(0,255,136,0.8)); }
@keyframes brickTodayPulse {
    0% { transform:scale(1.15) rotate(0deg); filter:drop-shadow(0 0 3px rgba(0,255,136,0.5)); }
    100% { transform:scale(1.35) rotate(3deg); filter:drop-shadow(0 0 10px rgba(0,255,136,0.95)); }
}

/* ── TIMELINE ── */
.timeline-container { background:var(--glass-card); backdrop-filter:var(--blur-strong); border:1px solid var(--glass-border); border-radius:24px; padding:32px 32px 24px; margin-bottom:28px; position:relative; box-shadow:var(--shadow-smooth), 0 0 0 0.5px rgba(0,255,0,0.04); }
.timeline-header { display:flex; justify-content:space-between; align-items:center; margin-bottom:24px; }
.timeline-title { font-size:0.78rem; letter-spacing:2.5px; text-transform:uppercase; color:var(--text-muted); font-weight:600; }
.timeline-status { font-family:'Space Grotesk',monospace; font-size:1.05rem; font-weight:600; color:var(--gym); text-shadow:0 0 14px rgba(var(--gym-rgb),0.35); }
.tl-bar-wrap { position:relative; }
.tl-bar { display:flex; height:62px; border-radius:12px; overflow:hidden; box-shadow:inset 0 1px 0 rgba(255,255,255,0.07), 0 6px 28px rgba(0,0,0,0.5); }
.tl-seg { display:flex; align-items:center; justify-content:center; overflow:hidden; flex-shrink:0; transition:filter 0.15s; cursor:default; flex-direction:column; gap:3px; }
.tl-seg:hover { filter:brightness(1.22); }
.tl-seg-lbl { font-size:0.5rem; font-weight:700; letter-spacing:1.2px; text-transform:uppercase; white-space:nowrap; pointer-events:none; }
.tl-seg-icon { font-size:0.85rem; pointer-events:none; line-height:1; }
.tl-indicator { position:absolute; top:-6px; bottom:-6px; width:3px; transform:translateX(-50%); background:#fff; border-radius:3px; box-shadow:0 0 12px #fff, 0 0 28px rgba(255,255,255,0.5); z-index:10; transition:left 0.5s cubic-bezier(0.4,0,0.2,1); pointer-events:none; }
.tl-ticks { position:relative; height:22px; margin-top:8px; }
.tl-tick { position:absolute; transform:translateX(-50%); font-family:'Space Grotesk',monospace; font-size:0.47rem; color:rgba(127,143,164,0.7); letter-spacing:0.5px; white-space:nowrap; }
.tl-tick::before { content:''; position:absolute; top:-5px; left:50%; transform:translateX(-50%); width:1px; height:4px; background:rgba(255,255,255,0.2); }

/* ── WIDGETS ── */
.widgets-row { display:grid; grid-template-columns:repeat(4,1fr); gap:20px; margin-bottom:20px; }
.wc-lbl { font-size:0.65rem; font-weight:500; text-transform:uppercase; letter-spacing:2.5px; color:var(--text-muted); margin-bottom:12px; }
.wc-val { font-size:1.9rem; font-weight:700; font-family:'Space Grotesk',monospace; line-height:1; }
.wc-sub { font-size:0.52rem; opacity:0.5; margin-top:6px; letter-spacing:0.5px; }

/* ── WIDGET: TODAY ── */
.wcard-today { position:relative; background:linear-gradient(180deg,rgba(0,180,255,0.12) 0%,rgba(0,60,140,0.06) 100%); border:1px solid rgba(0,180,255,0.22); border-top:2px solid #00b4ff; border-radius:20px; padding:24px 16px 20px; text-align:center; transition:all 0.25s ease; box-shadow:0 4px 24px rgba(0,180,255,0.07); overflow:hidden; }
.wcard-today::after { content:''; position:absolute; top:0; left:-60%; width:40%; height:2px; background:linear-gradient(90deg,transparent,rgba(0,212,255,0.8),transparent); animation:today-scan 4s ease-in-out infinite; }
@keyframes today-scan { 0%{left:-40%} 100%{left:140%} }
.wcard-today:hover { transform:translateY(-4px); box-shadow:0 12px 36px rgba(0,180,255,0.16); border-color:rgba(0,180,255,0.5); }
.wcard-today .wc-lbl { color:rgba(0,180,255,0.6); }
.wcard-today .wc-val { background:linear-gradient(135deg,#00d4ff,#0080ff); -webkit-background-clip:text; background-clip:text; color:transparent; }

/* ── WIDGET: MISSION DAY ── */
.wcard-mission { position:relative; background:linear-gradient(135deg,rgba(255,149,0,0.13) 0%,rgba(200,60,0,0.06) 100%); border:1px solid rgba(255,149,0,0.22); border-radius:20px; clip-path:polygon(0 0,calc(100% - 22px) 0,100% 22px,100% 100%,0 100%); padding:24px 16px 20px; text-align:center; transition:all 0.25s ease; box-shadow:0 4px 24px rgba(255,100,0,0.07); }
.wcard-mission:hover { transform:translateY(-4px); box-shadow:0 12px 36px rgba(255,130,0,0.18); background:linear-gradient(135deg,rgba(255,149,0,0.22) 0%,rgba(200,60,0,0.12) 100%); }
.wcard-mission .wc-lbl { color:rgba(255,149,0,0.6); }
.wcard-mission .wc-val { background:linear-gradient(135deg,#ffb347,#ff6000); -webkit-background-clip:text; background-clip:text; color:transparent; }

/* ── WIDGET: MISSION ARC ── */
.wcard-arc { position:relative; background:rgba(168,85,247,0.07); border:1px solid rgba(168,85,247,0.18); border-left:3px solid #a855f7; border-radius:4px 20px 20px 4px; padding:24px 16px 20px; text-align:center; transition:all 0.25s ease; box-shadow:0 4px 24px rgba(168,85,247,0.07),-3px 0 18px rgba(168,85,247,0.12); }
.wcard-arc:hover { transform:translateY(-4px); border-left-color:#c084fc; box-shadow:0 12px 36px rgba(168,85,247,0.18),-4px 0 28px rgba(168,85,247,0.22); background:rgba(168,85,247,0.13); }
.wcard-arc .wc-lbl { color:rgba(168,85,247,0.65); }
.wcard-arc .wc-val { background:linear-gradient(135deg,#c084fc,#7c3aed); -webkit-background-clip:text; background-clip:text; color:transparent; }

/* ── WIDGET: TOP QUEST ── */
.wcard-quest { position:relative; background:linear-gradient(145deg,rgba(0,255,0,0.07) 0%,rgba(0,180,80,0.04) 100%); border:1px solid rgba(0,255,0,0.16); border-radius:24px 4px 24px 4px; padding:24px 16px 20px; text-align:center; transition:all 0.25s ease; box-shadow:0 4px 24px rgba(0,255,0,0.05); }
.wcard-quest:hover { transform:translateY(-4px); border-color:rgba(0,255,0,0.4); box-shadow:0 12px 36px rgba(0,255,0,0.12); background:linear-gradient(145deg,rgba(0,255,0,0.13) 0%,rgba(0,180,80,0.08) 100%); }
.wcard-quest .wc-lbl { color:rgba(0,255,0,0.55); }
.wcard-quest .wc-val { background:linear-gradient(135deg,#00ff00,#00cc66); -webkit-background-clip:text; background-clip:text; color:transparent; }

/* ── COUNTDOWN ── */
.countdown-row { display:grid; grid-template-columns:repeat(3,1fr); gap:14px; margin-bottom:28px; }
.cd-card { position:relative; background:rgba(12,18,26,0.72); backdrop-filter:var(--blur-strong); border:1px solid rgba(255,255,255,0.07); border-radius:var(--radius-md); padding:28px 20px 22px; text-align:center; overflow:hidden; transition:transform 0.22s ease,border-color 0.22s ease; }
.cd-card::before { content:''; position:absolute; top:0;left:0;right:0; height:3px; background:var(--cd-color); box-shadow:0 0 18px var(--cd-color); }
.cd-card::after { content:''; position:absolute; top:3px;left:50%;transform:translateX(-50%); width:60%;height:80px; background:radial-gradient(ellipse at top,var(--cd-glow) 0%,transparent 70%); pointer-events:none; }
.cd-card:hover { transform:translateY(-4px); border-color:var(--cd-color); }
.cd-card-days  { --cd-color:#ff9000; --cd-glow:rgba(255,144,0,0.18); }
.cd-card-weeks { --cd-color:#a78bfa; --cd-glow:rgba(167,139,250,0.18); }
.cd-card-work  { --cd-color:#4bc0c0; --cd-glow:rgba(75,192,192,0.18); }
.cd-eyebrow { font-size:0.48rem; font-weight:600; text-transform:uppercase; letter-spacing:3px; color:var(--text-muted); margin-bottom:16px; }
.cd-val { font-family:'Space Grotesk',monospace; font-size:3.2rem; font-weight:700; line-height:1; color:var(--cd-color); text-shadow:0 0 28px var(--cd-glow); letter-spacing:-2px; }
.cd-unit { font-family:'Space Grotesk',monospace; font-size:0.65rem; font-weight:600; text-transform:uppercase; letter-spacing:3px; color:var(--cd-color); opacity:0.7; margin-top:10px; }
.cd-rule { width:28px; height:1px; background:var(--cd-color); opacity:0.3; margin:10px auto; }
.cd-sub { font-size:0.48rem; color:var(--text-muted); letter-spacing:1.5px; text-transform:uppercase; }

/* ── INTEL ── */
.intel-row { display:grid; grid-template-columns:1fr 1fr; gap:20px; margin-bottom:28px; }
.intel-card { background:var(--glass-card); backdrop-filter:var(--blur-strong); border:1px solid var(--glass-border); border-radius:var(--radius-xl); padding:24px; text-align:center; transition:all 0.4s cubic-bezier(0.175,0.885,0.32,1.275); position:relative; overflow:hidden; box-shadow:var(--shadow-smooth); cursor:pointer; }
.intel-card:hover { transform:translateY(-4px); background:rgba(255,255,255,0.05); }
.intel-card i { font-size:1.6rem; margin-bottom:12px; display:block; color:var(--card-accent); }
.intel-card h4 { font-size:0.6rem; letter-spacing:2px; text-transform:uppercase; color:var(--text-muted); margin-bottom:8px; }
.val-group { display:flex; align-items:baseline; justify-content:center; gap:4px; margin-bottom:4px; }
.intel-card .val { font-family:'Space Grotesk',monospace; font-size:2.8rem; font-weight:700; color:var(--text-primary); }
.intel-card .sep { font-size:1.2rem; color:var(--text-muted); opacity:0.5; }
.intel-card .total { font-family:'Space Grotesk',monospace; font-size:1.2rem; color:var(--text-muted); }
.intel-card .unit { font-size:0.6rem; letter-spacing:1.5px; text-transform:uppercase; color:var(--text-muted); margin-bottom:16px; }
.progress-container { width:100%; height:6px; background:rgba(255,255,255,0.05); border-radius:10px; overflow:hidden; margin-top:10px; }
.progress-bar { height:100%; width:0%; transition:width 0.6s cubic-bezier(0.4,0,0.2,1),background-color 0.4s; border-radius:10px; }
.pg-green { background:#00ff00; box-shadow:0 0 10px rgba(0,255,0,0.4); }
.pg-purple { background:#a78bfa; box-shadow:0 0 10px rgba(167,139,250,0.4); }
.pg-red { background:#ff4b2b; box-shadow:0 0 10px rgba(255,75,43,0.4); }
.ic-work { --card-accent:var(--gym); }
.ic-focus { --card-accent:var(--focus); }

/* ── NAV BAR ── */
.nav-bar { display:flex; justify-content:space-between; align-items:center; margin-bottom:28px; background:rgba(12,20,28,0.5); backdrop-filter:blur(20px); padding:6px 20px; border-radius:100px; border:1px solid rgba(255,255,255,0.08); }
.nav-range { font-weight:500; font-size:0.85rem; letter-spacing:-0.2px; }
.nav-btns { display:flex; gap:12px; }
.nav-btn { width:40px; height:40px; background:rgba(20,30,42,0.6); backdrop-filter:blur(8px); border:1px solid rgba(255,255,255,0.15); border-radius:60px; color:var(--text-primary); cursor:pointer; transition:0.2s; }
.nav-btn:hover:not(:disabled) { background:var(--gym); border-color:var(--gym); color:#0a1018; transform:scale(0.94); }
.nav-today { background:var(--gym); border:none; border-radius:40px; padding:0 28px; font-weight:700; font-size:0.7rem; letter-spacing:1px; text-transform:uppercase; color:#0a1018; cursor:pointer; transition:0.2s; box-shadow:0 2px 8px rgba(61,214,140,0.3); }

/* ── WEEK BLOCKS ── */
#weeksContainer { display:flex; flex-direction:column; gap:42px; }
.week-block { background:rgba(18,28,38,0.48); backdrop-filter:blur(20px); border:1px solid rgba(255,255,255,0.05); border-left:3px solid var(--week-color,rgba(255,255,255,0.08)); border-radius:var(--radius-xl); overflow:hidden; box-shadow:0 15px 35px -12px rgba(0,0,0,0.5); transition:all 0.3s; }
.week-head { display:flex; justify-content:space-between; align-items:center; padding:16px 24px; background:rgba(0,0,0,0.28); border-bottom:1px solid rgba(255,255,255,0.06); }
.week-head::before { display:none; }
.wh-label { font-size:0.9rem; font-weight:600; color:var(--week-color,var(--gym)); letter-spacing:-0.2px; }
.wh-range { font-size:0.7rem; color:var(--text-secondary); margin-top:2px; }
.btn-export { background:rgba(0,0,0,0.45); backdrop-filter:blur(5px); border:1px solid rgba(255,255,255,0.15); border-radius:40px; padding:5px 15px; font-size:0.7rem; font-weight:500; color:var(--text-secondary); cursor:pointer; transition:0.2s; }
.btn-export:hover { background:var(--gym); color:#0a1018; border-color:var(--gym); }
.wh-pills { display:flex; gap:12px; }
.wh-pill { background:rgba(0,0,0,0.4); backdrop-filter:blur(4px); padding:4px 12px; border-radius:30px; font-size:0.65rem; font-weight:500; }
.days-grid { display:grid; grid-template-columns:repeat(7,1fr); }
.day-col { padding:14px 8px; min-height:160px; border-right:1px solid rgba(255,255,255,0.03); cursor:pointer; transition:all 0.2s ease; position:relative; }
.day-col:hover { background:rgba(61,214,140,0.12); backdrop-filter:blur(5px); }
.day-col.is-today { background:radial-gradient(ellipse at 30% 0%,rgba(61,214,140,0.2),transparent); border-left:1px solid var(--gym); }
.day-col.is-past { background:rgba(0,255,0,0.08); }
.day-col.is-perfect { background:linear-gradient(145deg,rgba(255,217,102,0.08),rgba(255,205,126,0.04)); border-bottom:2px solid var(--perfect); }
.dc-dow { font-size:0.6rem; font-weight:600; text-transform:uppercase; letter-spacing:1.2px; color:var(--text-muted); }
.dc-num { font-family:'Space Grotesk',monospace; font-size:1.4rem; font-weight:600; color:var(--text-primary); }
.day-col.is-today .dc-num { color:var(--gym); text-shadow:0 0 5px rgba(61,214,140,0.6); }
.dc-meta { font-size:0.55rem; color:var(--text-muted); }
.dc-today-tag { font-size:0.55rem; color:var(--gym); font-weight:500; margin-top:2px; }
.dc-chips { display:flex; flex-direction:column; gap:5px; margin-top:12px; }
.chip { display:flex; align-items:center; gap:6px; padding:3px 8px; border-radius:40px; font-size:0.6rem; font-weight:500; backdrop-filter:blur(8px); width:fit-content; }
.chip-gym   { background:rgba(61,214,140,0.22);  color:#b0ffcf; }
.chip-read  { background:rgba(255,205,126,0.22); color:#ffdfaa; }
.chip-mscript { background:rgba(123,179,255,0.22); color:#b9d6ff; }
.chip-wake  { background:rgba(255,170,102,0.22); color:#ffce9e; }
.chip-focus { background:rgba(255,123,107,0.22); color:#ffbcae; }
.chip-energy-low    { background:rgba(255,75,43,0.22);   color:#ffb3a3; }
.chip-energy-medium { background:rgba(255,215,0,0.22);   color:#ffe47a; }
.chip-energy-high   { background:rgba(61,214,140,0.22);  color:#b0ffcf; }
.week-foot { display:grid; grid-template-columns:repeat(6,1fr); background:rgba(0,0,0,0.35); backdrop-filter:blur(8px); border-top:1px solid rgba(255,255,255,0.04); text-align:center; padding:10px 0; }
.wf-v { font-family:monospace; font-size:1rem; font-weight:600; }
.wf-l { font-size:0.55rem; text-transform:uppercase; color:var(--text-muted); }

/* ── LEGEND ── */
.legend { margin-top:38px; background:rgba(20,30,42,0.5); backdrop-filter:blur(20px); border-radius:80px; padding:12px 28px; display:flex; flex-wrap:wrap; gap:24px; justify-content:center; border:1px solid rgba(255,255,255,0.06); }
.leg-item { display:flex; align-items:center; gap:8px; font-size:0.7rem; font-weight:500; }
.leg-sw { width:9px; height:9px; border-radius:3px; }

/* ── MODAL ── */
.overlay { position:fixed; inset:0; background:rgba(5,10,18,0.7); backdrop-filter:blur(20px); display:none; justify-content:center; align-items:center; z-index:1000; opacity:0; transition:opacity 0.3s cubic-bezier(0.2,0.9,0.4,1.1); }
.overlay.open { display:flex; opacity:1; }
.modal { background:rgba(22,32,48,0.85); backdrop-filter:blur(32px); border:1px solid rgba(255,255,255,0.2); border-radius:48px; padding:32px 28px; width:90%; max-width:460px; box-shadow:0 30px 60px rgba(0,0,0,0.5),0 0 0 0.5px rgba(255,255,255,0.05); transform:scale(0.96) translateY(12px); transition:transform 0.35s cubic-bezier(0.2,0.9,0.3,1.2),opacity 0.25s; opacity:0; }
.overlay.open .modal { transform:scale(1) translateY(0); opacity:1; }
.modal-top { display:flex; justify-content:space-between; margin-bottom:28px; border-bottom:1px solid rgba(255,255,255,0.1); padding-bottom:16px; }
.modal-lbl { font-size:0.6rem; letter-spacing:2.5px; color:var(--gym); text-transform:uppercase; }
.modal-date { font-weight:600; font-size:1.1rem; margin-top:4px; }
.m-close { background:rgba(255,255,255,0.08); border:1px solid rgba(255,255,255,0.2); border-radius:40px; width:38px; height:38px; cursor:pointer; color:#cddfee; transition:0.2s; }
.m-close:hover { background:var(--focus); border-color:var(--focus); color:white; }
.tog-grid { display:grid; grid-template-columns:1fr 1fr; gap:16px; margin-bottom:28px; }
.m-tog { background:rgba(12,20,32,0.6); backdrop-filter:blur(12px); border:1px solid rgba(255,255,255,0.12); border-radius:32px; padding:18px 8px; text-align:center; cursor:pointer; transition:all 0.2s ease; }
.m-tog.on { border-color:var(--tc,var(--gym)); background:rgba(var(--tc-rgb,0,255,0),0.18); box-shadow:0 0 12px rgba(var(--tc-rgb,0,255,0),0.3); transform:scale(0.98); color:var(--tc); }
.m-tog.on i { color:var(--tc); }
.m-tog i { font-size:1.8rem; margin-bottom:6px; display:block; }
.tg-gym  { --tc:var(--gym);    --tc-rgb:var(--gym-rgb); }
.tg-read { --tc:var(--read);   --tc-rgb:var(--read-rgb); }
.tg-ms   { --tc:var(--mscript);--tc-rgb:var(--mscript-rgb); }
.tg-wake { --tc:var(--wake);   --tc-rgb:var(--wake-rgb); }
.focus-lbl { font-size:0.6rem; letter-spacing:1.5px; display:block; margin-bottom:8px; color:var(--focus); }
.focus-inp { width:100%; background:rgba(8,14,22,0.7); border:1px solid rgba(255,255,255,0.2); border-radius:60px; padding:14px; font-family:monospace; font-size:1.1rem; text-align:center; color:white; outline:none; transition:0.2s; }
.focus-inp:focus { border-color:var(--focus); box-shadow:0 0 12px rgba(var(--focus-rgb),0.3); }
.m-save { width:100%; background:var(--gym); border:none; border-radius:60px; padding:14px; font-weight:700; letter-spacing:1.5px; text-transform:uppercase; margin-top:24px; cursor:pointer; transition:0.2s; color:#0a1018; font-size:0.75rem; }
.m-save:hover { filter:brightness(1.08); transform:scale(0.97); }
.notes-divider { border:none; border-top:1px solid rgba(255,255,255,0.08); margin:20px 0 16px; }
.note-field { margin-bottom:12px; }
.note-label { font-size:0.6rem; letter-spacing:1.5px; display:block; margin-bottom:6px; color:var(--text-secondary); text-transform:uppercase; }
.note-inp { width:100%; background:rgba(8,14,22,0.7); border:1px solid rgba(255,255,255,0.12); border-radius:16px; padding:10px 14px; font-family:'Inter',sans-serif; font-size:0.78rem; color:white; outline:none; resize:none; transition:0.2s; height:54px; line-height:1.4; }
.note-inp:focus { border-color:rgba(255,255,255,0.28); background:rgba(12,20,32,0.9); }
.note-inp::placeholder { color:rgba(127,143,164,0.45); font-style:italic; }
.reset-btn { background:transparent; border:1px solid rgba(255,140,110,0.4); color:#ffaa99; padding:10px 26px; border-radius:60px; cursor:pointer; margin-top:40px; font-size:0.7rem; transition:0.2s; }
.reset-btn:hover { border-color:var(--focus); color:var(--focus); }

/* ── ENERGY LEVEL ── */
.energy-section { margin-bottom:20px; }
.energy-lbl { font-size:0.6rem; letter-spacing:1.5px; display:block; margin-bottom:8px; color:var(--text-secondary); text-transform:uppercase; }
.energy-lbl i { color:#ffd700; margin-right:4px; }
.energy-grid { display:grid; grid-template-columns:1fr 1fr 1fr; gap:10px; }
.energy-btn { background:rgba(12,20,32,0.6); backdrop-filter:blur(12px); border:1px solid rgba(255,255,255,0.12); border-radius:32px; padding:10px 8px; font-size:0.65rem; font-weight:700; letter-spacing:1.5px; text-transform:uppercase; cursor:pointer; color:rgba(255,255,255,0.45); transition:all 0.2s ease; }
.energy-low    { --ec:#ff4b2b; --ec-rgb:255,75,43; }
.energy-medium { --ec:#ffd700; --ec-rgb:255,215,0; }
.energy-high   { --ec:#3dd68c; --ec-rgb:61,214,140; }
.energy-btn:hover { border-color:var(--ec); color:var(--ec); }
.energy-btn.active { border-color:var(--ec); background:rgba(var(--ec-rgb),0.18); color:var(--ec); box-shadow:0 0 12px rgba(var(--ec-rgb),0.3); }

/* ── BOTTOM-LEFT STACK ── */
.bl-stack { position:fixed; bottom:24px; left:24px; z-index:9999; display:flex; flex-direction:column; align-items:flex-start; gap:9px; }

/* ── FAB ── */
.systematic-fab { display:flex; align-items:center; gap:10px; padding:11px 20px; background:rgba(5,8,16,0.88); border:1px solid rgba(255,255,255,0.11); border-radius:50px; color:rgba(200,230,240,0.8); text-decoration:none; font-family:'Space Grotesk',monospace; font-size:0.68rem; font-weight:700; letter-spacing:0.18em; backdrop-filter:blur(14px); box-shadow:0 8px 32px rgba(0,0,0,0.45); transition:all 0.25s cubic-bezier(0.4,0,0.2,1); }
.systematic-fab:hover { background:rgba(5,10,18,0.96); border-color:rgba(57,255,20,0.4); color:#39ff14; box-shadow:0 8px 40px rgba(0,0,0,0.5),0 0 28px rgba(57,255,20,0.12); transform:translateY(-2px); letter-spacing:0.22em; }
.systematic-fab .sfab-icon { font-size:0.9rem; line-height:1; }
.systematic-fab .sfab-dot { width:6px; height:6px; border-radius:50%; background:#39ff14; box-shadow:0 0 8px #39ff14; flex-shrink:0; animation:nfab-pulse 2s ease-in-out infinite; }

@media (max-width:780px) {
    .stats-bar { grid-template-columns:repeat(3,1fr); }
    .widgets-row { grid-template-columns:1fr 1fr; }
    .wrap { padding:0 16px; }
    .countdown-row { grid-template-columns:1fr; }
    .cd-val { font-size:2.4rem; }
}

/* ── FOCUS QUICK VIEW ── */
#focusQV { position:fixed; inset:0; display:none; justify-content:center; align-items:center; z-index:2000; background:rgba(5,10,18,0.7); backdrop-filter:blur(14px); }
#focusQV.open { display:flex; }
.fqv-card { background:rgba(18,26,40,0.92); backdrop-filter:blur(28px); border:1px solid rgba(255,0,0,0.35); border-radius:32px; padding:36px 40px 28px; min-width:320px; text-align:center; box-shadow:0 0 48px rgba(255,0,0,0.1),0 24px 48px rgba(0,0,0,0.55); animation:fadeIn 0.18s ease; }
.fqv-eyebrow { font-size:0.52rem; letter-spacing:3.5px; text-transform:uppercase; color:var(--focus); margin-bottom:6px; }
.fqv-date-lbl { font-size:0.68rem; color:var(--text-muted); margin-bottom:24px; }
.fqv-row { display:flex; justify-content:center; align-items:flex-end; gap:8px; margin-bottom:20px; }
.fqv-stat { display:flex; flex-direction:column; align-items:center; }
.fqv-num { font-family:'Space Grotesk',monospace; font-size:3.8rem; font-weight:700; line-height:1; color:var(--text-primary); }
.fqv-num.red { color:var(--focus); text-shadow:0 0 20px rgba(255,0,0,0.4); }
.fqv-sub { font-size:0.5rem; text-transform:uppercase; letter-spacing:2px; color:var(--text-muted); margin-top:8px; }
.fqv-sep { font-family:'Space Grotesk',monospace; font-size:2rem; color:rgba(255,255,255,0.15); margin-bottom:12px; }
.fqv-bar-wrap { height:5px; background:rgba(255,255,255,0.06); border-radius:5px; overflow:hidden; margin-bottom:24px; }
.fqv-bar { height:100%; background:linear-gradient(90deg,#ff4b2b,#ff0000); box-shadow:0 0 10px rgba(255,0,0,0.5); border-radius:5px; transition:width 0.5s cubic-bezier(0.4,0,0.2,1); }
.fqv-hint { font-size:0.52rem; color:rgba(127,143,164,0.5); letter-spacing:1px; }
.fqv-kbd { background:rgba(255,255,255,0.08); padding:2px 6px; border-radius:4px; font-family:'JetBrains Mono',monospace; border:1px solid rgba(255,255,255,0.12); }

/* ── WEEK FOCUS QV ── */
#weekFocusQV { position:fixed; inset:0; display:none; justify-content:center; align-items:center; z-index:2000; background:rgba(5,10,18,0.7); backdrop-filter:blur(14px); }
#weekFocusQV.open { display:flex; }
.wfqv-card { background:rgba(18,26,40,0.92); backdrop-filter:blur(28px); border:1px solid rgba(0,255,0,0.22); border-radius:32px; padding:36px 40px 28px; min-width:340px; text-align:center; box-shadow:0 0 48px rgba(0,255,0,0.07),0 24px 48px rgba(0,0,0,0.55); animation:fadeIn 0.18s ease; }
.wfqv-eyebrow { font-size:0.52rem; letter-spacing:3.5px; text-transform:uppercase; color:var(--gym); margin-bottom:6px; }
.wfqv-date-lbl { font-size:0.65rem; color:var(--text-muted); margin-bottom:22px; }
.wfqv-row { display:flex; justify-content:center; align-items:flex-end; gap:8px; margin-bottom:20px; }
.wfqv-num { font-family:'Space Grotesk',monospace; font-size:3.8rem; font-weight:700; line-height:1; }
.wfqv-num.green { color:var(--gym); text-shadow:0 0 24px rgba(0,255,0,0.35); }
.wfqv-sub { font-size:0.5rem; text-transform:uppercase; letter-spacing:2px; color:var(--text-muted); margin-top:8px; }
.wfqv-sep { font-family:'Space Grotesk',monospace; font-size:2rem; color:rgba(255,255,255,0.15); margin-bottom:12px; }
.wfqv-bar-wrap { height:5px; background:rgba(255,255,255,0.06); border-radius:5px; overflow:hidden; margin-bottom:10px; }
.wfqv-bar { height:100%; background:linear-gradient(90deg,#00c853,#00ff00); box-shadow:0 0 10px rgba(0,255,0,0.4); border-radius:5px; transition:width 0.5s cubic-bezier(0.4,0,0.2,1); }
.wfqv-meta { font-size:0.52rem; color:rgba(127,143,164,0.6); margin-bottom:20px; letter-spacing:0.5px; }
.wfqv-hint { font-size:0.5rem; color:rgba(127,143,164,0.45); letter-spacing:1px; }

/* ── SHORTCUTS MODAL ── */
#shortcutsModal { position:fixed; inset:0; display:none; justify-content:center; align-items:center; z-index:2000; background:rgba(5,10,18,0.78); backdrop-filter:blur(18px); }
#shortcutsModal.open { display:flex; }
.sc-card { background:rgba(16,24,38,0.96); backdrop-filter:blur(32px); border:1px solid rgba(255,255,255,0.1); border-radius:32px; padding:36px 36px 28px; width:420px; box-shadow:0 0 0 0.5px rgba(255,255,255,0.04),0 32px 64px rgba(0,0,0,0.65); animation:fadeIn 0.18s ease; }
.sc-header { display:flex; align-items:center; justify-content:center; gap:10px; margin-bottom:28px; }
.sc-title { font-size:0.55rem; letter-spacing:4px; text-transform:uppercase; color:var(--gym); }
.sc-divider { width:100%; height:1px; background:rgba(255,255,255,0.06); margin-bottom:16px; }
.sc-list { display:flex; flex-direction:column; gap:6px; }
.sc-row { display:flex; align-items:center; gap:14px; padding:9px 14px; border-radius:12px; background:rgba(255,255,255,0.025); border:1px solid rgba(255,255,255,0.04); transition:background 0.15s; }
.sc-row:hover { background:rgba(255,255,255,0.055); }
.sc-key { font-family:'JetBrains Mono',monospace; font-size:0.68rem; font-weight:700; color:#060e1c; background:var(--gym); padding:3px 9px; border-radius:6px; min-width:30px; text-align:center; box-shadow:0 2px 8px rgba(0,255,0,0.28); flex-shrink:0; letter-spacing:0; }
.sc-key.dim { background:rgba(255,255,255,0.1); color:var(--text-muted); box-shadow:none; font-size:0.58rem; padding:3px 7px; }
.sc-desc { font-size:0.7rem; color:var(--text-secondary); flex:1; }
.sc-cat { font-size:0.48rem; color:var(--text-muted); text-transform:uppercase; letter-spacing:1.5px; flex-shrink:0; opacity:0.6; }

/* ── ICON FAB STACK ── */
.icon-fab-stack { position:fixed; bottom:24px; right:24px; z-index:9999; display:flex; flex-direction:column; gap:10px; align-items:center; }
.icon-fab { width:46px; height:46px; background:rgba(5,8,16,0.88); border:1px solid rgba(255,255,255,0.1); border-radius:14px; display:flex; align-items:center; justify-content:center; backdrop-filter:blur(14px); box-shadow:0 8px 32px rgba(0,0,0,0.45); transition:all 0.22s cubic-bezier(0.4,0,0.2,1); cursor:pointer; text-decoration:none; color:rgba(180,210,230,0.65); }
.icon-fab:hover { transform:translateY(-2px) scale(1.06); box-shadow:0 12px 40px rgba(0,0,0,0.5); color:rgba(220,240,255,0.9); }
.icon-fab.apex:hover { border-color:rgba(245,196,48,0.5); box-shadow:0 12px 40px rgba(0,0,0,0.5),0 0 22px rgba(245,196,48,0.14); }
.icon-fab.shortcuts:hover { border-color:rgba(0,255,0,0.35); box-shadow:0 12px 40px rgba(0,0,0,0.5),0 0 22px rgba(0,255,0,0.1); }

/* ── TOAST NOTIFICATIONS ── */
#toast-container { position:fixed; bottom:24px; left:50%; transform:translateX(-50%); z-index:99999; display:flex; flex-direction:column; gap:8px; pointer-events:none; }
.toast { padding:12px 18px; border-radius:12px; font-family:'JetBrains Mono',monospace; font-size:0.75rem; line-height:1.4; max-width:320px; word-wrap:break-word; pointer-events:auto; opacity:1; transform:translateY(0); transition:all 0.2s ease; }
.toast-error { background:rgba(224,58,62,0.92); border:1px solid rgba(255,0,0,0.5); color:var(--text-primary); box-shadow:0 0 24px rgba(255,0,0,0.15),0 8px 16px rgba(0,0,0,0.4); }
.toast-success { background:rgba(0,230,118,0.15); border:1px solid rgba(0,255,0,0.4); color:#00e676; box-shadow:0 0 20px rgba(0,255,0,0.1),0 8px 16px rgba(0,0,0,0.3); }
.toast-info { background:rgba(0,176,255,0.15); border:1px solid rgba(0,176,255,0.4); color:#00b0ff; box-shadow:0 0 20px rgba(0,176,255,0.08),0 8px 16px rgba(0,0,0,0.3); }
.toast-removing { opacity:0; transform:translateY(8px); }

/* ── NOTE CHIP ── */
.chip-notes { background:rgba(255,255,255,0.07); color:var(--text-secondary); cursor:pointer; border:1px solid rgba(255,255,255,0.1); }
.chip-notes:hover { background:rgba(255,255,255,0.12); border-color:rgba(255,255,255,0.22); color:var(--text-primary); }

/* ── NOTE QUICK-VIEW ── */
#noteQV { position:fixed; inset:0; display:none; justify-content:center; align-items:center; z-index:2000; background:rgba(5,10,18,0.7); backdrop-filter:blur(14px); }
#noteQV.open { display:flex; }
.nqv-card { background:rgba(18,26,40,0.96); backdrop-filter:blur(28px); border:1px solid rgba(255,255,255,0.12); border-radius:32px; padding:28px 32px; min-width:340px; max-width:420px; width:90%; box-shadow:0 0 48px rgba(0,0,0,0.5),0 24px 48px rgba(0,0,0,0.55); animation:fadeIn 0.18s ease; }
.nqv-header { display:flex; justify-content:space-between; align-items:center; margin-bottom:20px; }
.nqv-eyebrow { font-size:0.5rem; letter-spacing:3px; text-transform:uppercase; color:var(--text-muted); }
.nqv-date { font-size:0.8rem; font-weight:600; color:var(--text-primary); margin-top:4px; }
.nqv-close { background:none; border:none; color:var(--text-muted); cursor:pointer; padding:4px; font-size:1.1rem; transition:color 0.15s; }
.nqv-close:hover { color:var(--text-primary); }
.nqv-section { margin-bottom:14px; }
.nqv-section:last-child { margin-bottom:0; }
.nqv-label { font-size:0.52rem; letter-spacing:2px; text-transform:uppercase; color:var(--text-muted); margin-bottom:6px; }
.nqv-text { font-size:0.8rem; color:var(--text-secondary); line-height:1.6; background:rgba(255,255,255,0.04); border-radius:12px; padding:10px 14px; white-space:pre-wrap; word-break:break-word; }
.nqv-empty { font-size:0.72rem; color:rgba(127,143,164,0.35); font-style:italic; }
.nqv-edit-btn { display:block; width:100%; margin-top:18px; padding:11px; background:rgba(255,255,255,0.06); border:1px solid rgba(255,255,255,0.1); border-radius:16px; color:var(--text-secondary); font-size:0.65rem; letter-spacing:1.5px; text-transform:uppercase; cursor:pointer; transition:all 0.2s; font-family:'Space Grotesk',monospace; font-weight:600; }
.nqv-edit-btn:hover { background:rgba(0,255,0,0.1); border-color:rgba(0,255,0,0.3); color:var(--gym); }

/* ── WEEK-OVER-WEEK BADGES ── */
.wow-badge { display:inline-block; margin-top:6px; padding:2px 7px; border-radius:20px; font-size:0.52rem; font-weight:700; letter-spacing:0.5px; font-family:'JetBrains Mono',monospace; line-height:1.4; transition:opacity 0.3s; }
.wow-pos { background:rgba(0,255,0,0.12); color:#00e676; border:1px solid rgba(0,255,0,0.25); }
.wow-neg { background:rgba(255,75,43,0.12); color:#ff6b5b; border:1px solid rgba(255,75,43,0.22); }
.wow-zero { background:rgba(127,143,164,0.1); color:var(--text-muted); border:1px solid rgba(127,143,164,0.15); }

/* ── FUTURISTIC BRAND LOCKUP & HEADER ── */

.brand-lockup-futuristic {
    display: flex;
    flex-direction: column;
    width: 100%;
    margin-bottom: 28px;
    animation: fadeIn 0.8s ease-out;
}

.brand-container-futuristic {
    position: relative;
    display: flex;
    flex-direction: row;
    align-items: center;
    justify-content: center;
    text-align: left;
    padding: 22px 48px 18px;
    gap: 28px;
    background: radial-gradient(ellipse at 50% 0%, rgba(0, 240, 255, 0.08) 0%, transparent 68%);
}

.brand-text-group {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    gap: 4px;
}

/* ── HUD RETICLE CORNER BRACKETS ── */
.bc-corner {
    position: absolute;
    width: 18px;
    height: 18px;
    pointer-events: none;
    opacity: 0.55;
    transition: opacity 0.3s ease;
}
.brand-container-futuristic:hover .bc-corner { opacity: 1; }
.bc-tl { top: 0;    left: 0;  border-top:    1.5px solid var(--cyber-accent); border-left:  1.5px solid var(--cyber-accent); }
.bc-tr { top: 0;    right: 0; border-top:    1.5px solid var(--cyber-accent); border-right: 1.5px solid var(--cyber-accent); }
.bc-bl { bottom: 0; left: 0;  border-bottom: 1.5px solid var(--cyber-accent); border-left:  1.5px solid var(--cyber-accent); }
.bc-br { bottom: 0; right: 0; border-bottom: 1.5px solid var(--cyber-accent); border-right: 1.5px solid var(--cyber-accent); }

/* ── HERO ICON: centered with aura pulse rings ── */
.brand-hero-icon {
    position: relative;
    width: 120px;
    height: 120px;
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
}

/* ── CRYSTAL STAR ICON: diamond pulses + stroke-draw appearance ── */

/* Expanding diamond pulse rings (replace old circle auras) */
.bhi-pulse {
    position: absolute;
    width: 60px;
    height: 60px;
    border: 1.5px solid rgba(0, 240, 255, 0.4);
    transform: rotate(45deg) scale(1);
    pointer-events: none;
}
.bhi-pulse.p1 { animation: bhi-diamond-pulse 2.8s ease-out 1.3s  infinite; }
.bhi-pulse.p2 { animation: bhi-diamond-pulse 2.8s ease-out 2.23s infinite; }
.bhi-pulse.p3 { animation: bhi-diamond-pulse 2.8s ease-out 3.16s infinite; }

/* Core SVG: materialise from a bright blurry point on load */
.bhi-svg {
    position: relative;
    z-index: 2;
    overflow: visible;
    animation:
        bhi-appear    0.78s cubic-bezier(0.25, 0.46, 0.45, 0.94) both,
        bhi-glow-idle 3.6s ease-in-out 0.85s infinite alternate;
}
.brand-hero-icon:hover .bhi-svg {
    filter: drop-shadow(0 0 22px rgba(0, 240, 255, 1)) drop-shadow(0 0 50px rgba(189, 0, 255, 0.45)) !important;
}

/* Rotating dashed orbit ring */
.bhi-orbit {
    transform-box: fill-box;
    transform-origin: center;
    opacity: 0;
    animation:
        bhi-orbit-in   0.5s  ease-out  0.62s forwards,
        bhi-orbit-spin 9s    linear    1.12s infinite;
}

/* Outer 4-pointed crystal star */
.bhi-star {
    transform-box: fill-box;
    transform-origin: center;
    stroke-dasharray: 306;
    stroke-dashoffset: 306;
    fill-opacity: 0;
    animation:
        bhi-star-draw    0.65s cubic-bezier(0.4, 0, 0.2, 1) 0.1s  forwards,
        bhi-star-fill    0.45s ease-in                       0.52s forwards,
        bhi-star-breathe 4.2s  ease-in-out                  1.05s infinite alternate;
}

/* Inner accent star (rotated 45°) */
.bhi-star-inner {
    transform-box: fill-box;
    transform-origin: center;
    opacity: 0;
    transform: scale(0);
    animation:
        bhi-inner-in   0.45s cubic-bezier(0.175, 0.885, 0.32, 1.275) 0.68s forwards,
        bhi-inner-spin 14s   linear                                   1.15s infinite;
}

/* Tip accent dots */
.bhi-dot {
    transform-box: fill-box;
    transform-origin: center;
    transform: scale(0);
    opacity: 0;
    animation: bhi-dot-pop 0.5s cubic-bezier(0.175, 0.885, 0.32, 1.275) forwards;
}
.bhi-dot.d1 { animation-delay: 0.82s; }
.bhi-dot.d2 { animation-delay: 0.94s; }
.bhi-dot.d3 { animation-delay: 1.06s; }
.bhi-dot.d4 { animation-delay: 1.18s; }

.brand-title-text {
    font-family: 'Righteous', system-ui, -apple-system, sans-serif;
    font-size: 4.8rem;
    font-weight: 400;
    letter-spacing: 0.05em;
    line-height: 1;
    margin: 0;
    background: linear-gradient(135deg, #00f0ff 0%, #bd00ff 50%, #ff007f 100%);
    -webkit-background-clip: text;
    background-clip: text;
    color: transparent;
    filter: drop-shadow(0 0 24px rgba(0, 240, 255, 0.4)) drop-shadow(0 2px 30px rgba(189, 0, 255, 0.2));
    transition: filter 0.35s ease, transform 0.35s ease;
    animation: title-breathe 4s ease-in-out infinite alternate;
}
.brand-title-text:hover {
    filter: drop-shadow(0 0 36px rgba(0, 240, 255, 0.75)) drop-shadow(0 0 50px rgba(189, 0, 255, 0.45));
    transform: scale(1.02);
}

/* ── CITRUS SVG ANIMATIONS ── */
.citrus-orbit {
    transform-box: fill-box;
    transform-origin: center;
    animation: spin-clockwise 15s linear infinite;
}
.citrus-hex {
    transform-box: fill-box;
    transform-origin: center;
    animation: spin-counter-clockwise 20s linear infinite;
}
.citrus-segments {
    transform-box: fill-box;
    transform-origin: center;
    transition: transform 0.6s cubic-bezier(0.2, 0.8, 0.2, 1);
    animation: citrus-breath 3s ease-in-out infinite alternate;
}
.brand-hero-icon:hover .citrus-segments {
    transform: rotate(45deg) scale(1.06);
}
.citrus-core {
    transform-box: fill-box;
    transform-origin: center;
    animation: pulse-hud 2.5s ease-in-out infinite alternate;
}

@keyframes title-breathe {
    0% { filter: drop-shadow(0 0 16px rgba(0, 240, 255, 0.3)) drop-shadow(0 2px 20px rgba(189, 0, 255, 0.15)); }
    100% { filter: drop-shadow(0 0 28px rgba(0, 240, 255, 0.55)) drop-shadow(0 2px 30px rgba(189, 0, 255, 0.35)); }
}

@keyframes citrus-breath {
    0% { transform: scale(0.96); opacity: 0.85; }
    100% { transform: scale(1.04); opacity: 1; }
}

/* ── ELEGANT TAGLINE ── */
.brand-tagline {
    display: flex;
    align-items: center;
    gap: 12px;
    margin-top: 8px;
}

.tagline-rule {
    flex: 1;
    height: 1px;
    max-width: 56px;
    background: linear-gradient(90deg, transparent, rgba(0, 240, 255, 0.45));
}

.tagline-rule:last-child {
    background: linear-gradient(90deg, rgba(0, 240, 255, 0.45), transparent);
}

.tagline-label {
    font-family: 'JetBrains Mono', 'Courier New', monospace;
    font-size: 0.58rem;
    font-weight: 400;
    letter-spacing: 0.3em;
    text-transform: uppercase;
    color: rgba(0, 240, 255, 0.7);
    white-space: nowrap;
}

/* ── HIGH-TECH divider with scanline glow ── */
.hud-divider {
    position: relative;
    width: 100%;
    height: 1px;
    background: linear-gradient(90deg, rgba(0, 240, 255, 0.35) 0%, rgba(189, 0, 255, 0.15) 50%, rgba(255, 255, 255, 0.03) 100%);
    margin-top: 14px;
    overflow: hidden;
}

.hud-divider-glow {
    position: absolute;
    top: 0;
    left: -150px;
    width: 150px;
    height: 100%;
    background: linear-gradient(90deg, transparent, rgba(0, 240, 255, 0.85), transparent);
    animation: scanline-sweep 4s cubic-bezier(0.4, 0, 0.2, 1) infinite;
}

/* ── ANIMATIONS KEYFRAMES ── */
@keyframes spin-clockwise {
    from { transform: rotate(0deg); }
    to { transform: rotate(360deg); }
}

@keyframes spin-counter-clockwise {
    from { transform: rotate(360deg); }
    to { transform: rotate(0deg); }
}

@keyframes pulse-hud {
    0% { transform: scale(0.96); opacity: 0.45; }
    100% { transform: scale(1.04); opacity: 0.88; }
}

/* bhi-appear: materialise from bright blurry point with chromatic-aberration glitch flash */
@keyframes bhi-appear {
    0%   { opacity: 0; transform: scale(0.45); filter: blur(22px) brightness(14); }
    28%  { opacity: 1; transform: scale(1.08);
           filter: blur(1px) brightness(5)
                   drop-shadow(-5px 0 8px rgba(255, 30, 80, 0.8))
                   drop-shadow(5px 0 8px rgba(0, 215, 255, 0.8)); }
    52%  { transform: scale(0.96);
           filter: blur(0) brightness(2) drop-shadow(0 0 22px rgba(0, 240, 255, 0.9)); }
    76%  { transform: scale(1.01);
           filter: brightness(1.15) drop-shadow(0 0 14px rgba(0, 240, 255, 0.72)); }
    100% { transform: scale(1);
           filter: drop-shadow(0 0 12px rgba(0, 240, 255, 0.65)) drop-shadow(0 0 30px rgba(189, 0, 255, 0.18)); }
}
@keyframes bhi-glow-idle {
    from { filter: drop-shadow(0 0 10px rgba(0, 240, 255, 0.55)) drop-shadow(0 0 24px rgba(189, 0, 255, 0.1)); }
    to   { filter: drop-shadow(0 0 20px rgba(0, 240, 255, 0.9))  drop-shadow(0 0 40px rgba(189, 0, 255, 0.28)); }
}
@keyframes bhi-diamond-pulse {
    0%   { transform: rotate(45deg) scale(0.75); opacity: 0.88; border-color: rgba(0, 240, 255, 0.55); }
    100% { transform: rotate(45deg) scale(3.5);  opacity: 0;    border-color: rgba(189, 0, 255, 0); }
}
@keyframes bhi-orbit-in   { from { opacity: 0; } to { opacity: 1; } }
@keyframes bhi-orbit-spin { from { transform: rotate(0deg); } to { transform: rotate(360deg); } }
@keyframes bhi-star-draw {
    0%   { stroke-dashoffset: 306; stroke-opacity: 0; }
    8%   { stroke-opacity: 1; }
    100% { stroke-dashoffset: 0;   stroke-opacity: 1; }
}
@keyframes bhi-star-fill    { from { fill-opacity: 0; } to { fill-opacity: 1; } }
@keyframes bhi-star-breathe { from { transform: scale(1); } to { transform: scale(1.028); } }
@keyframes bhi-inner-in {
    0%   { transform: scale(0);    opacity: 0; }
    65%  { transform: scale(1.38); opacity: 1; }
    100% { transform: scale(1);    opacity: 1; }
}
@keyframes bhi-inner-spin { from { transform: rotate(0deg); } to { transform: rotate(-360deg); } }
@keyframes bhi-dot-pop {
    0%   { transform: scale(0);   opacity: 0; }
    60%  { transform: scale(2.1); opacity: 1; }
    100% { transform: scale(1);   opacity: 0.9; }
}

@keyframes blink-dot {
    0% { opacity: 0.3; }
    100% { opacity: 1; }
}

@keyframes blink-cursor {
    0%, 100% { opacity: 0; }
    50% { opacity: 1; }
}

@keyframes scanline-sweep {
    0% { left: -150px; }
    100% { left: 100%; }
}

/* ── CURRENT MONTH HORIZONTAL LINE ── */
.current-month-section {
    margin: 28px auto 0;
    max-width: 1040px;
    background: rgba(10, 20, 32, 0.42);
    backdrop-filter: var(--blur-strong);
    border: 1px solid rgba(255, 255, 255, 0.06);
    border-radius: 22px;
    padding: 20px 24px;
    box-shadow: 0 12px 36px rgba(0,0,0,0.48), inset 0 1px 0 rgba(255,255,255,0.03);
    transition: all 0.35s cubic-bezier(0.2,0.9,0.3,1.1);
}
.current-month-section:hover {
    border-color: rgba(0, 255, 136, 0.28);
    box-shadow: 0 12px 40px rgba(0, 255, 136, 0.08), 0 0 1px rgba(0, 255, 136, 0.15);
}
.current-month-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 16px;
    border-bottom: 1px solid rgba(255, 255, 255, 0.06);
    padding-bottom: 10px;
}
.cm-label {
    font-family: 'Inter', 'Space Grotesk', system-ui, sans-serif;
    font-size: 0.72rem;
    letter-spacing: 1px;
    text-transform: uppercase;
    color: var(--text-secondary);
    font-weight: 600;
}
.cm-legend {
    font-family: 'Inter', 'Space Grotesk', system-ui, sans-serif;
    font-size: 0.64rem;
    color: var(--text-muted);
    display: flex;
    align-items: center;
    gap: 16px;
    letter-spacing: 0.5px;
    text-transform: uppercase;
}
.cm-legend-item {
    display: flex;
    align-items: center;
    gap: 6px;
}
.cm-dot {
    width: 6px;
    height: 6px;
    border-radius: 50%;
    display: inline-block;
}
.sun-dot {
    background: #ff5e00;
    box-shadow: 0 0 8px #ff5e00;
}
.today-dot {
    background: #00ff88;
    box-shadow: 0 0 8px #00ff88;
}
.current-month-line {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 8px;
    padding: 10px 0;
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
}
.current-month-line::-webkit-scrollbar {
    height: 4px;
}
.current-month-line::-webkit-scrollbar-track {
    background: rgba(255, 255, 255, 0.02);
    border-radius: 2px;
}
.current-month-line::-webkit-scrollbar-thumb {
    background: rgba(255, 255, 255, 0.1);
    border-radius: 2px;
}

.cm-brick-wrapper {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 10px;
    flex: 1;
    min-width: 22px;
}
.cm-brick {
    width: 14px;
    height: 16px;
    background: rgba(255, 255, 255, 0.04);
    clip-path: polygon(50% 0%, 100% 25%, 100% 75%, 50% 100%, 0% 75%, 0% 25%);
    transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
    cursor: pointer;
}
.cm-brick:hover {
    transform: scale(1.35) rotate(5deg);
    filter: brightness(1.22);
    z-index: 5;
}
.cm-brick.is-past {
    background: rgba(255, 255, 255, 0.11);
}
.cm-brick.today {
    background: #00ff88;
    transform: scale(1.25);
    animation: brickTodayPulse 2s ease-in-out infinite alternate;
    z-index: 3;
    filter: drop-shadow(0 0 6px rgba(0, 255, 136, 0.8));
}

.cm-brick.score-1 { background:#ff4b2b; filter:drop-shadow(0 0 3px rgba(255,75,43,0.5)); }
.cm-brick.score-2 { background:#ff9000; filter:drop-shadow(0 0 3px rgba(255,144,0,0.5)); }
.cm-brick.score-3 { background:#007aff; filter:drop-shadow(0 0 3px rgba(0,122,255,0.5)); }
.cm-brick.score-4 { background:#00ff00; filter:drop-shadow(0 0 5px rgba(0,255,0,0.6)); }

/* Sunday Special Styling */
.cm-brick.is-sunday {
    filter: drop-shadow(0 0 6px rgba(255, 94, 0, 0.8));
}
.cm-brick.is-sunday:not(.score-1):not(.score-2):not(.score-3):not(.score-4):not(.today) {
    background: rgba(255, 94, 0, 0.25);
}

.cm-brick-label {
    font-family: 'Inter', 'Space Grotesk', system-ui, sans-serif;
    font-size: 0.62rem;
    color: var(--text-muted);
    transition: all 0.2s ease;
    font-weight: 500;
    line-height: 1;
}
.cm-brick-wrapper:hover .cm-brick-label {
    color: var(--text-primary);
}
.cm-brick-wrapper.is-sunday .cm-brick-label {
    color: #ff9000;
    font-weight: 700;
    text-shadow: 0 0 4px rgba(255, 144, 0, 0.4);
}
.cm-brick-wrapper.today .cm-brick-label {
    color: #00ff88;
    font-weight: 700;
    text-shadow: 0 0 4px rgba(0, 255, 136, 0.4);
}

.cm-pct-badge {
    background: rgba(0, 255, 136, 0.08);
    border: 1px solid rgba(0, 255, 136, 0.22);
    color: #00ff88;
    padding: 3px 10px;
    border-radius: 40px;
    font-family: 'Inter', system-ui, sans-serif;
    font-size: 0.62rem;
    font-weight: 600;
    letter-spacing: 0.5px;
    text-transform: uppercase;
    box-shadow: 0 0 12px rgba(0, 255, 136, 0.05);
    transition: all 0.3s ease;
}
.cm-pct-badge:hover {
    background: rgba(0, 255, 136, 0.15);
    border-color: rgba(0, 255, 136, 0.45);
    box-shadow: 0 0 16px rgba(0, 255, 136, 0.15);
}

/* ── DASHBOARD MISSIONS SECTION ── */
.dash-missions-section { margin: 20px 0; }
.dms-header { display: flex; align-items: center; justify-content: space-between; margin-bottom: 12px; }
.dms-title { font-family: 'Space Grotesk', sans-serif; font-size: 0.7rem; font-weight: 700; color: rgba(0, 240, 255, 0.75); letter-spacing: 3px; text-transform: uppercase; }
.dms-link { font-family: 'JetBrains Mono', monospace; font-size: 0.6rem; color: rgba(255,255,255,0.3); letter-spacing: 1px; text-decoration: none; transition: color 0.2s; }
.dms-link:hover { color: rgba(0, 240, 255, 0.75); }
.dms-cards { display: grid; grid-template-columns: repeat(auto-fit, minmax(260px, 1fr)); gap: 12px; }
.dms-card {
    background: rgba(22, 32, 45, 0.55);
    backdrop-filter: blur(12px);
    border: 1px solid rgba(255,255,255,0.08);
    border-radius: 10px;
    padding: 16px 18px;
    transition: border-color 0.25s, box-shadow 0.25s;
}
.dms-card:hover { border-color: rgba(0, 240, 255, 0.3); box-shadow: 0 4px 20px rgba(0,0,0,0.3); }
.dms-card.dms-urgent { border-color: rgba(255,80,80,0.25); }
.dms-card.dms-urgent:hover { border-color: rgba(255,80,80,0.5); box-shadow: 0 4px 20px rgba(255,80,80,0.1); }
.dms-card-top { display: flex; align-items: center; gap: 8px; margin-bottom: 10px; flex-wrap: wrap; }
.dms-card-name { font-family: 'Space Grotesk', sans-serif; font-size: 0.95rem; font-weight: 600; color: var(--text-primary); }
.dms-card-type { font-family: 'JetBrains Mono', monospace; font-size: 0.52rem; color: var(--text-muted); letter-spacing: 1px; margin-right: auto; }
.dms-chip { font-family: 'JetBrains Mono', monospace; font-size: 0.48rem; font-weight: 700; letter-spacing: 1.5px; text-transform: uppercase; padding: 2px 7px; border-radius: 3px; }
.dms-chip-ok { background: rgba(0, 240, 255, 0.1); color: var(--cyber-accent); border: 1px solid rgba(0, 240, 255, 0.25); }
.dms-chip-urgent { background: rgba(255,80,80,0.12); color: #ff5050; border: 1px solid rgba(255,80,80,0.3); }
.dms-bar-wrap { height: 3px; background: rgba(255,255,255,0.07); border-radius: 2px; overflow: hidden; margin-bottom: 8px; }
.dms-bar-fill { height: 100%; background: linear-gradient(90deg, var(--cyber-accent), var(--cyber-glow)); border-radius: 2px; transition: width 0.4s ease; }
.dms-card.dms-urgent .dms-bar-fill { background: linear-gradient(90deg, #ff5050, #ff9000); }
.dms-card-meta { display: flex; justify-content: space-between; align-items: center; font-family: 'JetBrains Mono', monospace; font-size: 0.55rem; color: var(--text-muted); }
.dms-days { color: rgba(0, 240, 255, 0.75); }
.dms-days-urgent { color: rgba(255,80,80,0.85); }

/* ── INTERMITTENT FASTING WIDGET ── */
.if-widget {
    position: fixed;
    top: 24px;
    left: 24px;
    z-index: 10000;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 9px;
    padding: 24px 14px 18px;
    min-width: 110px;
    background: transparent;
    border: none;
    filter: drop-shadow(0 12px 36px rgba(0,0,0,0.65));
    animation: if-slide-in 0.55s ease-out both;
    transition: filter 0.4s;
    user-select: none;
}

.if-widget-bg {
    position: absolute;
    inset: 1px;
    background: rgba(10, 6, 22, 0.9);
    backdrop-filter: blur(20px);
    -webkit-backdrop-filter: blur(20px);
    clip-path: polygon(0 0, calc(100% - 15px) 0, 100% 15px, 100% 100%, 15px 100%, 0 calc(100% - 15px));
    z-index: -1;
    transition: background 0.4s;
}

.if-widget::before {
    content: '';
    position: absolute;
    inset: 0;
    background: linear-gradient(135deg, rgba(192, 64, 255, 0.28), rgba(0, 240, 255, 0.28));
    clip-path: polygon(0 0, calc(100% - 15px) 0, 100% 15px, 100% 100%, 15px 100%, 0 calc(100% - 15px));
    z-index: -2;
    transition: background 0.4s;
}

@keyframes if-slide-in {
    from { opacity: 0; transform: translateX(-22px); }
    to   { opacity: 1; transform: translateX(0); }
}

/* Scan line sweep */
.if-widget::after {
    content: '';
    position: absolute;
    left: 0; right: 0;
    height: 80px;
    background: linear-gradient(to bottom,
        transparent,
        rgba(192,64,255,0.032) 40%,
        rgba(192,64,255,0.032) 60%,
        transparent);
    top: -80px;
    animation: if-scan 7s ease-in-out infinite;
    pointer-events: none;
    clip-path: polygon(0 0, calc(100% - 15px) 0, 100% 15px, 100% 100%, 15px 100%, 0 calc(100% - 15px));
}

@keyframes if-scan {
    0%   { top: -80px; }
    100% { top: 110%; }
}

/* Active state */
.if-widget.if-on::before {
    background: linear-gradient(135deg, rgba(192, 64, 255, 0.75), rgba(0, 240, 255, 0.75));
}
.if-widget.if-on {
    filter: drop-shadow(0 12px 36px rgba(0,0,0,0.65)) drop-shadow(0 0 15px rgba(192, 64, 255, 0.35));
}

/* HUD corner brackets */
.if-hud { position: absolute; width: 10px; height: 10px; pointer-events: none; }
.if-hud.tl { top: 6px; left: 6px;   border-top: 1.5px solid rgba(192,64,255,0.5); border-left:  1.5px solid rgba(192,64,255,0.5); }
.if-hud.tr { top: 6px; right: 6px;  border-top: 1.5px solid rgba(192,64,255,0.5); border-right: 1.5px solid rgba(192,64,255,0.5); }
.if-hud.bl { bottom: 6px; left: 6px;  border-bottom: 1.5px solid rgba(192,64,255,0.5); border-left:  1.5px solid rgba(192,64,255,0.5); }
.if-hud.br { bottom: 6px; right: 6px; border-bottom: 1.5px solid rgba(192,64,255,0.5); border-right: 1.5px solid rgba(192,64,255,0.5); }

.if-label {
    font-family: 'Orbitron', sans-serif;
    font-size: 0.46rem;
    font-weight: 700;
    color: rgba(192,64,255,0.6);
    letter-spacing: 4px;
    text-transform: uppercase;
}

/* Ring container */
.if-core {
    position: relative;
    width: 88px;
    height: 88px;
    display: flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
}
.if-core:active { transform: scale(0.94); }

/* Plasma glow */
.if-glow {
    position: absolute;
    inset: -6px;
    border-radius: 50%;
    background: radial-gradient(circle, rgba(192,64,255,0.1) 0%, transparent 68%);
    animation: if-glow-idle 3.5s ease-in-out infinite;
    pointer-events: none;
}
@keyframes if-glow-idle {
    0%, 100% { transform: scale(1);    opacity: 0.5; }
    50%       { transform: scale(1.18); opacity: 1; }
}
.if-widget.if-on .if-glow {
    background: radial-gradient(circle, rgba(192,64,255,0.22) 0%, rgba(0,180,255,0.07) 58%, transparent 70%);
    animation: if-glow-on 2.2s ease-in-out infinite;
}
@keyframes if-glow-on {
    0%, 100% { transform: scale(1);    opacity: 0.8; }
    50%       { transform: scale(1.26); opacity: 1; }
}

/* SVG ring */
.if-svg {
    position: absolute;
    top: 50%; left: 50%;
    transform: translate(-50%, -50%) rotate(-90deg);
    overflow: visible;
}
.if-ring-bg {
    fill: none;
    stroke: rgba(255,255,255,0.06);
    stroke-width: 3.5;
}
.if-ring-fill {
    fill: none;
    stroke: url(#ifGrad);
    stroke-width: 4;
    stroke-linecap: round;
    stroke-dasharray: 0 188.5;
    transition: stroke-dasharray 0.7s cubic-bezier(0.4,0,0.2,1);
    filter: drop-shadow(0 0 5px rgba(192,64,255,0.7));
}

/* Center number */
.if-center {
    position: relative;
    z-index: 1;
    display: flex;
    flex-direction: column;
    align-items: center;
    pointer-events: none;
}
.if-num {
    font-family: 'Orbitron', sans-serif;
    font-size: 1.72rem;
    font-weight: 900;
    color: #f0e8ff;
    line-height: 1;
    text-shadow: 0 0 18px rgba(192,64,255,0.45);
    transition: text-shadow 0.4s;
}
.if-widget.if-on .if-num {
    text-shadow: 0 0 22px rgba(192,64,255,0.95), 0 0 44px rgba(0,180,255,0.35);
}
.if-unit {
    font-family: 'JetBrains Mono', monospace;
    font-size: 0.36rem;
    color: rgba(192,64,255,0.5);
    letter-spacing: 2px;
    margin-top: 3px;
    text-transform: uppercase;
}

/* Status chip */
.if-status {
    font-family: 'JetBrains Mono', monospace;
    font-size: 0.5rem;
    letter-spacing: 2px;
    text-transform: uppercase;
    padding: 3px 8px;
    border-radius: 4px;
    transition: all 0.35s;
    white-space: nowrap;
}
.if-status.if-active {
    color: #c040ff;
    background: rgba(192,64,255,0.1);
    border: 1px solid rgba(192,64,255,0.35);
    animation: if-chip-glow 2s ease-in-out infinite;
}
@keyframes if-chip-glow {
    0%, 100% { box-shadow: 0 0 5px rgba(192,64,255,0.2); }
    50%       { box-shadow: 0 0 14px rgba(192,64,255,0.55); }
}
.if-status.if-rest {
    color: rgba(255,255,255,0.22);
    background: transparent;
    border: 1px solid rgba(255,255,255,0.09);
}

/* 7-day history dots */
.if-dots { display: flex; gap: 4px; align-items: center; }
.if-dot {
    width: 7px; height: 7px;
    border-radius: 50%;
    transition: background 0.3s, box-shadow 0.3s;
}
.if-dot.on  { background: linear-gradient(135deg,#c040ff,#00b4ff); box-shadow: 0 0 5px rgba(192,64,255,0.55); }
.if-dot.off { background: rgba(255,255,255,0.08); border: 1px solid rgba(255,255,255,0.13); }
.if-dot.today-on  {
    background: linear-gradient(135deg,#c040ff,#00b4ff);
    box-shadow: 0 0 8px rgba(192,64,255,0.9), 0 0 16px rgba(0,180,255,0.4);
    animation: if-dot-beat 1.6s ease-in-out infinite;
}
.if-dot.today-off {
    background: rgba(192,64,255,0.06);
    border: 1px solid rgba(192,64,255,0.35);
    animation: if-dot-beat 1.6s ease-in-out infinite;
}
@keyframes if-dot-beat {
    0%, 100% { transform: scale(1); }
    50%       { transform: scale(1.4); }
}

/* Footer labels */
.if-total {
    font-family: 'JetBrains Mono', monospace;
    font-size: 0.44rem;
    color: rgba(255,255,255,0.2);
    letter-spacing: 1px;
}
.if-hint {
    font-family: 'JetBrains Mono', monospace;
    font-size: 0.38rem;
    color: rgba(255,255,255,0.14);
    letter-spacing: 1px;
    padding-top: 4px;
    border-top: 1px solid rgba(255,255,255,0.05);
    width: 100%;
    text-align: center;
}

@media (max-width: 768px) { .if-widget { display: none; } }

/* ── FASTING STATISTICS PANEL ── */
.if-stats-panel {
    position: fixed;
    inset: 0;
    background: rgba(5, 10, 18, 0.88);
    z-index: 24000;
    display: none;
    align-items: center;
    justify-content: center;
    backdrop-filter: blur(18px);
    -webkit-backdrop-filter: blur(18px);
    animation: if-panel-fade 0.3s ease;
}
.if-stats-panel.open { display: flex; }

@keyframes if-panel-fade {
    from { opacity: 0; }
    to   { opacity: 1; }
}

.ifsp-card {
    background: rgba(16, 10, 28, 0.92);
    backdrop-filter: blur(28px);
    -webkit-backdrop-filter: blur(28px);
    border: 1px solid rgba(192,64,255,0.22);
    border-radius: 20px;
    padding: 28px;
    width: 90%;
    max-width: 600px;
    max-height: 85vh;
    overflow-y: auto;
    box-shadow:
        0 20px 60px rgba(0,0,0,0.8),
        0 0 0 1px rgba(192,64,255,0.08),
        inset 0 1px 0 rgba(255,255,255,0.05);
    scrollbar-width: thin;
    scrollbar-color: rgba(192,64,255,0.3) transparent;
}

.ifsp-card::-webkit-scrollbar { width: 6px; }
.ifsp-card::-webkit-scrollbar-track { background: transparent; }
.ifsp-card::-webkit-scrollbar-thumb { background: rgba(192,64,255,0.3); border-radius: 3px; }
.ifsp-card::-webkit-scrollbar-thumb:hover { background: rgba(192,64,255,0.5); }

.ifsp-header {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    margin-bottom: 20px;
    gap: 12px;
}

.ifsp-header-right {
    display: flex;
    gap: 8px;
    align-items: center;
}

.ifsp-title {
    font-family: 'Space Grotesk', sans-serif;
    font-size: 1.1rem;
    font-weight: 700;
    color: rgba(240,232,255,0.95);
    letter-spacing: 2px;
}

.ifsp-subtitle {
    font-family: 'JetBrains Mono', monospace;
    font-size: 0.56rem;
    color: rgba(192,64,255,0.5);
    letter-spacing: 1px;
    text-transform: uppercase;
    margin-top: 4px;
}

.ifsp-today-btn {
    background: linear-gradient(135deg, rgba(192,64,255,0.2), rgba(0,180,255,0.1));
    border: 1px solid rgba(192,64,255,0.35);
    color: #c040ff;
    padding: 6px 12px;
    border-radius: 6px;
    font-family: 'JetBrains Mono', monospace;
    font-size: 0.54rem;
    font-weight: 700;
    letter-spacing: 1.5px;
    cursor: pointer;
    transition: all 0.2s;
}

.ifsp-today-btn:hover {
    background: linear-gradient(135deg, rgba(192,64,255,0.35), rgba(0,180,255,0.2));
    border-color: rgba(192,64,255,0.55);
    box-shadow: 0 0 12px rgba(192,64,255,0.25);
}

.ifsp-today-btn.active {
    background: linear-gradient(135deg, #c040ff, #00b4ff);
    color: #fff;
    box-shadow: 0 0 14px rgba(192,64,255,0.5);
}

.ifsp-close {
    background: rgba(192,64,255,0.1);
    border: 1px solid rgba(192,64,255,0.25);
    color: rgba(192,64,255,0.7);
    width: 32px;
    height: 32px;
    border-radius: 50%;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: all 0.2s;
    flex-shrink: 0;
}

.ifsp-close:hover {
    background: rgba(192,64,255,0.2);
    border-color: rgba(192,64,255,0.5);
    color: #c040ff;
}

.ifsp-grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 14px;
    margin-bottom: 18px;
}

.ifsp-stat {
    background: rgba(192,64,255,0.06);
    border: 1px solid rgba(192,64,255,0.14);
    border-radius: 12px;
    padding: 14px;
}

.ifsp-val {
    font-family: 'Orbitron', sans-serif;
    font-size: 1.8rem;
    font-weight: 900;
    color: #c040ff;
    line-height: 1;
    text-shadow: 0 0 12px rgba(192,64,255,0.4);
}

.ifsp-label {
    font-family: 'JetBrains Mono', monospace;
    font-size: 0.54rem;
    color: rgba(255,255,255,0.4);
    letter-spacing: 1.5px;
    text-transform: uppercase;
    margin-top: 6px;
}

.ifsp-bar {
    height: 2px;
    background: rgba(255,255,255,0.06);
    border-radius: 1px;
    margin-top: 8px;
    overflow: hidden;
}

.ifsp-bar-fill {
    height: 100%;
    background: linear-gradient(90deg, #c040ff, #00b4ff);
    border-radius: 1px;
    transition: width 0.6s cubic-bezier(0.4,0,0.2,1);
}

.ifsp-divider {
    height: 1px;
    background: linear-gradient(90deg, transparent, rgba(192,64,255,0.2), transparent);
    margin: 18px 0;
}

.ifsp-section {
    margin-bottom: 12px;
}

.ifsp-section-title {
    font-family: 'Space Grotesk', sans-serif;
    font-size: 0.8rem;
    font-weight: 700;
    color: rgba(192,64,255,0.75);
    letter-spacing: 2px;
    text-transform: uppercase;
    margin-bottom: 12px;
}


.ifsp-calendar {
    display: grid;
    grid-template-columns: repeat(7, 1fr);
    gap: 4px;
}

.ifsp-cal-dow {
    font-family: 'JetBrains Mono', monospace;
    font-size: 0.46rem;
    font-weight: 700;
    color: rgba(192,64,255,0.45);
    text-align: center;
    padding: 4px 0 6px;
    letter-spacing: 1px;
    text-transform: uppercase;
}

.ifsp-cal-dow.sun,
.ifsp-cal-dow.sat {
    color: rgba(255,100,100,0.4);
}

.ifsp-cal-spacer {
    aspect-ratio: 1;
}

.ifsp-cal-day {
    aspect-ratio: 1;
    background: rgba(255,255,255,0.05);
    border: 1px solid rgba(255,255,255,0.08);
    border-radius: 6px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 0.7rem;
    color: rgba(255,255,255,0.3);
    transition: all 0.2s;
    cursor: pointer;
}

.ifsp-cal-day.on {
    background: linear-gradient(135deg, rgba(192,64,255,0.35), rgba(0,180,255,0.25));
    border-color: rgba(192,64,255,0.4);
    color: #c040ff;
    box-shadow: 0 0 8px rgba(192,64,255,0.25);
}

.ifsp-cal-day.today {
    border: 2px solid rgba(192,64,255,0.6);
    box-shadow: 0 0 12px rgba(192,64,255,0.4);
}

.ifsp-cal-day.sun,
.ifsp-cal-day.sat {
    color: rgba(255,120,120,0.5);
    border-color: rgba(255,80,80,0.1);
}

.ifsp-cal-day.sun.on,
.ifsp-cal-day.sat.on {
    color: #ff88aa;
}

.ifsp-footer {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding-top: 12px;
}

.ifsp-hint {
    font-family: 'JetBrains Mono', monospace;
    font-size: 0.54rem;
    color: rgba(255,255,255,0.25);
    letter-spacing: 1px;
}

/* ── BRAND COMPACT PILL (override) ── */
.brand-lockup-futuristic { margin-bottom: 16px; }

.brand-container-futuristic {
    position: relative;
    display: inline-flex;
    flex-direction: row;
    align-items: center;
    gap: 11px;
    padding: 7px 18px 7px 10px;
    background: rgba(8,15,24,0.58);
    border: 1px solid rgba(0,255,136,0.2);
    border-radius: 50px;
    backdrop-filter: blur(20px);
    box-shadow: 0 3px 18px rgba(0,0,0,0.35), 0 0 0 1px rgba(0,255,136,0.04), inset 0 1px 0 rgba(255,255,255,0.03);
    width: fit-content;
    margin: 0 auto;
    justify-content: center;
    text-align: left;
    transition: border-color 0.25s, box-shadow 0.25s;
}
.brand-container-futuristic:hover {
    border-color: rgba(0,255,136,0.42);
    box-shadow: 0 4px 28px rgba(0,0,0,0.4), 0 0 18px rgba(0,255,136,0.07);
}

.brand-icon-mini {
    flex-shrink: 0;
    animation: citrus-breath 3s ease-in-out infinite alternate;
    filter: drop-shadow(0 0 5px rgba(192,255,0,0.55));
}

.brand-title-text {
    font-family: 'Orbitron', system-ui, sans-serif !important;
    font-size: 1.45rem !important;
    font-weight: 900 !important;
    letter-spacing: 5px !important;
    line-height: 1 !important;
    margin: 0 !important;
    background: linear-gradient(135deg, #00f0ff 0%, #bd00ff 50%, #ff007f 100%);
    -webkit-background-clip: text;
    background-clip: text;
    color: transparent !important;
    filter: drop-shadow(0 0 10px rgba(0, 240, 255, 0.3));
    animation: none !important;
    transition: filter 0.25s;
}
.brand-container-futuristic:hover .brand-title-text {
    filter: drop-shadow(0 0 18px rgba(0, 240, 255, 0.6));
}

.brand-vsep {
    width: 1px;
    height: 16px;
    background: rgba(0, 240, 255, 0.22);
    flex-shrink: 0;
}

.brand-tagline-inline {
    font-family: 'JetBrains Mono', monospace;
    font-size: 0.48rem;
    font-weight: 700;
    letter-spacing: 3px;
    text-transform: uppercase;
    color: rgba(0, 240, 255, 0.5);
    white-space: nowrap;
}

/* ── YESTERDAY WIDGET ── */
@keyframes slideInLeft { from { opacity:0; transform:translateX(-18px); } to { opacity:1; transform:translateX(0); } }

.yest-widget {
    position: relative;
    background: rgba(6,11,20,0.9);
    backdrop-filter: blur(22px);
    clip-path: polygon(10px 0, 100% 0, calc(100% - 10px) 100%, 0 100%);
    padding: 2px;
    animation: slideInLeft 0.4s cubic-bezier(0.2,0.9,0.3,1.1) both;
    filter: drop-shadow(0 4px 18px rgba(0,0,0,0.55));
}
.yest-widget::before {
    content: '';
    position: absolute;
    inset: 0;
    clip-path: polygon(10px 0, 100% 0, calc(100% - 10px) 100%, 0 100%);
    background: linear-gradient(135deg, rgba(0, 240, 255, 0.28) 0%, rgba(189, 0, 255, 0.1) 60%, transparent 100%);
    pointer-events: none;
}
.yw-inner {
    clip-path: polygon(10px 0, 100% 0, calc(100% - 10px) 100%, 0 100%);
    background: rgba(7,13,22,0.94);
    padding: 10px 20px 10px 16px;
    min-width: 164px;
}

.yw-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 3px;
    gap: 12px;
}
.yw-title {
    font-family: 'Inter', sans-serif;
    font-size: 0.58rem;
    font-weight: 600;
    letter-spacing: 0.5px;
    color: rgba(0,255,136,0.6);
    text-transform: uppercase;
}
.yw-score {
    font-family: 'Inter', sans-serif;
    font-size: 0.68rem;
    font-weight: 700;
    color: rgba(255,255,255,0.8);
}
.yw-date {
    font-family: 'Inter', sans-serif;
    font-size: 0.6rem;
    font-weight: 400;
    color: rgba(255,255,255,0.35);
    letter-spacing: 0;
    margin-bottom: 8px;
}
.yw-habits {
    display: flex;
    flex-direction: column;
    gap: 5px;
}
.yw-habit {
    display: flex;
    align-items: center;
    gap: 8px;
    font-family: 'Inter', sans-serif;
    font-size: 0.72rem;
    font-weight: 600;
    letter-spacing: 0;
    text-transform: capitalize;
    white-space: nowrap;
}
.yw-habit i { font-size: 0.55rem; width: 11px; text-align: center; flex-shrink: 0; }

.yw-gym   { color:#3dd68c; }
.yw-read  { color:#ffcd7e; }
.yw-plan  { color:#7bb3ff; }
.yw-wake  { color:#ffaa66; }
.yw-focus { color:#ff7b6b; }

.yw-empty {
    font-family: 'Inter', sans-serif;
    font-size: 0.68rem;
    font-weight: 400;
    color: rgba(255,255,255,0.25);
    letter-spacing: 0;
    font-style: italic;
    text-transform: none;
}
