*{margin:0;padding:0;box-sizing:border-box}
:root{
  --bg:#111318;--card:#1a1d24;--border:#2a2d35;
  --text:#e8e6e3;--muted:#8b8d93;--accent:#c9a55a;
  --accent-light:#d4b56e;--green:#4ade80;--green-bg:rgba(74,222,128,.12);--green-border:rgba(74,222,128,.3);
  --warm:#f59e0b;--warm-bg:rgba(245,158,11,.12);--blue:#60a5fa;
  --purple:#a78bfa;--purple-bg:rgba(167,139,250,.1);
  --red-bg:rgba(248,113,113,.12);--red-text:#fca5a5;
  --yellow-bg:rgba(250,204,21,.12);--yellow-text:#fde68a;
  --green-text:#86efac;
  --radius:14px;--nav-h:64px;
  --sans:system-ui,-apple-system,'Segoe UI',sans-serif;
  --serif:'Palatino Linotype',Palatino,Georgia,serif;
}
html,body{height:100%;overflow:hidden}
body{font-family:var(--serif);color:var(--text);background:var(--bg);-webkit-tap-highlight-color:transparent;display:flex;flex-direction:column}
#appShell{flex:1;display:flex;flex-direction:column;min-height:0}
.screens{flex:1;overflow-y:auto;-webkit-overflow-scrolling:touch;padding-bottom:calc(var(--nav-h)+32px);min-height:0}
.screens.no-scroll{overflow:hidden;display:flex;flex-direction:column}
.screen{display:none;padding:20px 16px 80px;max-width:600px;margin:0 auto;width:100%}
.screen.active{display:block}

/* Loading screen */
.loading-screen{position:fixed;inset:0;background:var(--bg);z-index:400;display:flex;align-items:center;justify-content:center;transition:opacity .4s}
.loading-screen.hidden{opacity:0;pointer-events:none}
.spinner{width:40px;height:40px;border:3px solid var(--border);border-top-color:var(--accent);border-radius:50%;animation:spin .8s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}

/* Auth screen */
.auth-screen{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh;padding:40px 24px;text-align:center}
.auth-screen h1{font-family:var(--serif);font-size:28px;color:var(--accent);margin-bottom:4px}
.auth-screen .tagline{font-family:var(--sans);font-size:14px;color:var(--muted);margin-bottom:32px}
.auth-form{width:100%;max-width:340px}
.auth-form label{display:block;font-family:var(--sans);font-size:13px;color:var(--muted);text-align:left;margin-bottom:6px}
.auth-form input{width:100%;padding:14px;border:1px solid var(--border);border-radius:10px;font-family:var(--sans);font-size:15px;background:var(--card);color:var(--text);margin-bottom:14px}
.auth-form input:focus{outline:none;border-color:var(--accent)}
.auth-form input::placeholder{color:#555}
.auth-msg{font-family:var(--sans);font-size:13px;color:var(--muted);margin-top:12px;line-height:1.5}
.auth-msg.error{color:var(--red-text)}
.auth-msg.success{color:var(--green-text)}

/* Bottom nav */
.bottom-nav{position:fixed;bottom:0;left:0;right:0;height:var(--nav-h);background:var(--card);border-top:1px solid var(--border);display:flex;align-items:center;justify-content:space-around;z-index:100;padding-bottom:env(safe-area-inset-bottom,0)}
.nav-btn{display:flex;flex-direction:column;align-items:center;gap:3px;background:none;border:none;cursor:pointer;padding:6px 12px;color:var(--muted);font-family:var(--sans);font-size:11px;font-weight:500;transition:color .2s;position:relative}
.nav-btn.active{color:var(--accent)}
.nav-btn svg{width:24px;height:24px;stroke:currentColor;stroke-width:1.8;fill:none}
.nav-btn .badge{position:absolute;top:2px;right:6px;width:8px;height:8px;background:var(--warm);border-radius:50%}

/* Typography */
h1{font-size:26px;font-weight:700;color:var(--accent);letter-spacing:-0.02em}
h2{font-size:20px;font-weight:700;color:var(--accent)}
h3{font-size:16px;font-weight:600;color:var(--accent);font-family:var(--sans)}
.subtext{font-size:14px;color:var(--muted);font-family:var(--sans)}

/* Cards */
.card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);padding:20px 22px;margin-bottom:14px;box-shadow:0 2px 8px rgba(0,0,0,.3)}
.card-sm{padding:12px 14px}

/* Today tab */
.today-header{text-align:center;margin-bottom:20px}
.today-header .day-label{font-family:var(--sans);font-size:13px;color:var(--accent);text-transform:uppercase;letter-spacing:0.12em;margin-bottom:4px}
.today-header h1{margin-bottom:2px;font-size:30px;color:#fff}
.today-header .streak{display:inline-flex;align-items:center;gap:4px;font-family:var(--sans);font-size:13px;color:var(--warm);margin-top:8px}
.video-wrapper{position:relative;width:100%;padding-top:56.25%;border-radius:var(--radius);overflow:hidden;margin-bottom:16px;background:#000;border:1px solid var(--border)}
.video-wrapper iframe{position:absolute;top:0;left:0;width:100%;height:100%;border:none}
.notes-label{font-family:var(--sans);font-size:13px;font-weight:600;color:var(--muted);display:block;margin-bottom:6px}
.reflection-area textarea{width:100%;min-height:80px;border:1px solid var(--border);border-radius:8px;padding:12px;font-family:var(--serif);font-size:15px;color:var(--text);background:var(--bg);resize:vertical;line-height:1.5}
.reflection-area textarea::placeholder{color:#555}
.reflection-area textarea:focus{outline:none;border-color:var(--accent)}
.complete-btn{display:block;width:100%;padding:16px;margin-top:8px;background:var(--accent);color:#111;border:none;border-radius:var(--radius);font-family:var(--sans);font-size:16px;font-weight:700;cursor:pointer;transition:transform .1s}
.complete-btn:active{transform:scale(0.97)}
.complete-btn.done{background:var(--green);color:#111}

/* Day navigation arrows (production replacement for demo bar) */
.day-nav{display:flex;justify-content:center;gap:12px;margin-top:12px}
.day-nav button{width:36px;height:36px;border-radius:50%;border:1px solid var(--border);background:transparent;color:var(--muted);font-size:16px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s}
.day-nav button:active{background:rgba(255,255,255,.05);border-color:var(--accent);color:var(--accent)}

/* Journey: dashboard (sticky) */
#screen-journey{display:none;flex-direction:column;padding-bottom:0 !important;overflow:hidden;flex:1;min-height:0}
#screen-journey.active{display:flex}
.journey-dash{flex-shrink:0;padding:12px 16px 14px;border-bottom:2px solid var(--border);background:var(--card);border-radius:0 0 var(--radius) var(--radius);z-index:2}
.journey-books{flex:1;min-height:0;overflow-y:auto;-webkit-overflow-scrolling:touch;padding-top:0;padding-bottom:80px;padding-right:4px}
.journey-section-header{padding:20px 2px 12px;display:flex;align-items:center;gap:10px}
.journey-section-header h2{font-family:var(--serif);font-size:18px;font-weight:700;color:var(--text);white-space:nowrap}
.journey-section-header::after{content:'';flex:1;height:1px;background:var(--border)}
.screens::-webkit-scrollbar,.journey-books::-webkit-scrollbar{width:6px}
.screens::-webkit-scrollbar-track,.journey-books::-webkit-scrollbar-track{background:transparent;margin:8px 0}
.screens::-webkit-scrollbar-thumb,.journey-books::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}
.screens::-webkit-scrollbar-thumb:hover,.journey-books::-webkit-scrollbar-thumb:hover{background:var(--muted)}
.screens,.journey-books{scrollbar-width:thin;scrollbar-color:var(--border) transparent}
.dash-label{font-family:var(--sans);font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:var(--muted);margin-bottom:8px}
.dash-row{display:flex;gap:0;align-items:stretch}
.dash-left{flex:1;padding-right:16px;border-right:1px solid var(--border)}
.dash-right{flex:0 0 auto;padding-left:16px;display:flex;flex-direction:column;align-items:center;justify-content:center}
.week-dots{display:flex;gap:8px;margin-bottom:6px}
.week-dot{width:30px;height:30px;border-radius:50%;border:2px solid var(--border);display:flex;align-items:center;justify-content:center;font-family:var(--sans);font-size:10px;font-weight:700;color:var(--muted);transition:all .3s}
.week-dot.filled{background:var(--green-bg);border-color:var(--green);color:var(--green-text)}
.week-dot.filled svg{stroke:var(--green)}
.week-dot.target-met{background:var(--green);border-color:var(--green);color:#111}
.week-msg{font-family:var(--sans);font-size:12px;color:var(--muted);line-height:1.4}
.week-streak{font-family:var(--sans);font-size:12px;color:var(--accent);font-weight:600;margin-top:4px}
.progress-ring-wrap{position:relative;width:90px;height:90px;margin-bottom:8px}
.progress-ring-wrap svg{width:100%;height:100%;transform:rotate(-90deg)}
.progress-ring-bg{fill:none;stroke:var(--border);stroke-width:6}
.progress-ring-fill{fill:none;stroke:url(#ringGrad);stroke-width:6;stroke-linecap:round;transition:stroke-dashoffset .8s ease}
.progress-ring-text{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center}
.progress-ring-pct{font-family:var(--sans);font-size:22px;font-weight:800;color:var(--text);line-height:1}
.progress-ring-label{font-family:var(--sans);font-size:9px;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--muted)}
.overall-stats{display:flex;flex-direction:column;gap:2px;align-items:center}
.overall-stat{font-family:var(--sans);font-size:11px;color:var(--muted);white-space:nowrap}
.overall-stat .num{font-weight:800;color:var(--text)}

/* Journey: section groups */
.section-group{margin-bottom:24px}
.section-title{font-family:var(--sans);font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.14em;color:var(--accent);padding:0 2px 8px;display:flex;align-items:center;gap:8px}
.section-title::after{content:'';flex:1;height:1px;background:var(--border)}

/* Journey: book cards */
.book-card{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius);margin-bottom:10px;overflow:hidden;transition:border-color .3s}
.book-card.is-current{border-color:var(--accent);box-shadow:0 0 20px rgba(201,165,90,.12)}
.book-card.is-complete{border-color:var(--green-border)}
.book-card-head{display:flex;align-items:center;gap:14px;padding:14px 16px;cursor:pointer;user-select:none}
.book-status{width:36px;height:36px;flex-shrink:0;position:relative}
.book-status svg{width:100%;height:100%}
.book-status .ring-bg{fill:none;stroke:var(--border);stroke-width:2.5}
.book-status .ring-fill{fill:none;stroke:var(--green);stroke-width:2.5;stroke-linecap:round;transition:stroke-dashoffset .6s ease;transform-origin:center;transform:rotate(-90deg)}
.book-card.is-current .ring-fill{stroke:var(--accent)}
.book-status .check{opacity:0;transition:opacity .3s}
.book-card.is-complete .check{opacity:1}
.book-card.is-complete .ring-fill{stroke:var(--green)}
.book-mid{flex:1;min-width:0}
.book-name{font-family:var(--serif);font-size:17px;font-weight:700;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.book-card.is-current .book-name{color:var(--accent)}
.book-sub{font-family:var(--sans);font-size:12px;color:var(--muted);margin-top:1px}
.book-bar-wrap{height:4px;background:var(--bg);border-radius:2px;margin-top:6px;overflow:hidden}
.book-bar{height:100%;border-radius:2px;background:var(--green);transition:width .5s ease}
.book-card.is-current .book-bar{background:var(--accent)}
.book-chev{color:var(--muted);font-size:14px;transition:transform .25s}
.book-card.open .book-chev{transform:rotate(90deg)}

/* Journey: chapter grid */
.book-chapters{max-height:0;overflow:hidden;transition:max-height .35s ease;padding:0 16px}
.book-card.open .book-chapters{max-height:600px;padding:0 16px 16px}
.ch-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(38px,1fr));gap:6px}
.ch-dot{width:100%;aspect-ratio:1;border-radius:8px;display:flex;align-items:center;justify-content:center;font-family:var(--sans);font-size:12px;font-weight:600;border:1.5px solid var(--border);color:var(--muted);background:var(--bg);cursor:pointer;transition:all .2s}
.ch-dot:hover:not(.locked){border-color:var(--accent);color:var(--accent)}
.ch-dot.completed{background:var(--green-bg);border-color:var(--green);color:var(--green-text)}
.ch-dot.current{background:var(--warm-bg);border-color:var(--warm);color:#fde68a;animation:pulse 2s infinite}
.ch-dot.locked{opacity:.25;cursor:default}
@keyframes pulse{0%,100%{box-shadow:0 0 0 0 rgba(245,158,11,.3)}50%{box-shadow:0 0 0 6px rgba(245,158,11,0)}}
.ch-dot.next{border-color:var(--accent);color:var(--accent);background:rgba(201,165,90,.08);cursor:pointer}
.ch-dot.combined-first{width:auto;padding:0 10px;border-radius:8px;font-size:11px;letter-spacing:-.02em}
.ch-dot.combined-pair{display:none}

/* Toggle switch */
.toggle-switch{position:relative;display:inline-block;width:44px;height:24px;flex-shrink:0}
.toggle-switch input{opacity:0;width:0;height:0}
.toggle-slider{position:absolute;cursor:pointer;inset:0;background:var(--border);transition:.3s;border-radius:24px}
.toggle-slider::before{content:'';position:absolute;height:18px;width:18px;left:3px;bottom:3px;background:var(--muted);transition:.3s;border-radius:50%}
.toggle-switch input:checked+.toggle-slider{background:var(--accent)}
.toggle-switch input:checked+.toggle-slider::before{transform:translateX(20px);background:#fff}

/* Explore mode: unlock all dots */
.ch-dot.unlocked{opacity:1;cursor:pointer;border-color:var(--border);color:var(--muted)}
.ch-dot.unlocked:hover{border-color:var(--accent);color:var(--accent)}

/* Welcome screen */
.welcome-overlay{position:fixed;inset:0;background:var(--bg);z-index:300;display:flex;align-items:flex-start;justify-content:center;overflow-y:auto;-webkit-overflow-scrolling:touch}
.welcome-overlay.hidden{display:none}
.welcome-inner{max-width:440px;width:100%;padding:60px 28px 80px}
.welcome-inner h1{font-family:var(--serif);font-size:26px;font-weight:700;color:var(--text);margin:0 0 28px;line-height:1.3}
.welcome-inner h1 span{color:var(--accent)}
.welcome-inner p{font-family:var(--serif);font-size:15px;line-height:1.8;color:#c2c0bc;margin:0 0 16px}
.welcome-inner .welcome-divider{width:32px;height:2px;background:var(--border);margin:28px 0;border:none}
.welcome-inner .welcome-sign{font-family:var(--serif);font-size:15px;line-height:1.8;color:#c2c0bc;margin:0 0 16px}
.welcome-inner .welcome-names{font-family:var(--serif);font-size:14px;color:var(--text);margin:0 0 4px}
.welcome-inner .welcome-church{font-family:var(--serif);font-size:13px;color:var(--muted);margin:0 0 16px}
.welcome-inner .welcome-note{font-family:var(--serif);font-size:13px;color:var(--muted);line-height:1.7;margin:0 0 36px;font-style:italic}
.welcome-actions{display:flex;flex-direction:column;gap:10px}
.welcome-install-btn{display:block;width:100%;padding:16px;background:var(--accent);color:var(--bg);border:none;border-radius:12px;font-family:var(--sans);font-size:15px;font-weight:700;cursor:pointer;letter-spacing:.01em}
.welcome-install-btn:active{opacity:.85}
.welcome-skip-btn{display:block;width:100%;padding:14px;background:transparent;color:var(--muted);border:1px solid var(--border);border-radius:12px;font-family:var(--sans);font-size:14px;font-weight:600;cursor:pointer}
.welcome-skip-btn:active{opacity:.7}

/* Completion overlay */
.completion-overlay{position:fixed;inset:0;background:rgba(0,0,0,.7);z-index:200;display:flex;align-items:center;justify-content:center;opacity:0;pointer-events:none;transition:opacity .4s}
.completion-overlay.show{opacity:1;pointer-events:auto}
.completion-card{background:var(--card);border:1px solid var(--border);border-radius:20px;padding:32px 28px;max-width:340px;width:90%;text-align:center;transform:scale(.85);transition:transform .4s cubic-bezier(.34,1.56,.64,1)}
.completion-overlay.show .completion-card{transform:scale(1)}
.completion-check{width:64px;height:64px;margin:0 auto 16px;border-radius:50%;background:var(--green-bg);border:2px solid var(--green);display:flex;align-items:center;justify-content:center}
.completion-check svg{width:32px;height:32px;stroke:var(--green);stroke-width:2.5;fill:none}
.completion-title{font-family:var(--serif);font-size:22px;font-weight:700;color:var(--text);margin-bottom:6px}
.completion-sub{font-family:var(--sans);font-size:14px;color:var(--muted);margin-bottom:20px;line-height:1.5}
.completion-actions{display:flex;flex-direction:column;gap:10px}
.completion-btn{padding:14px;border-radius:var(--radius);font-family:var(--sans);font-size:15px;font-weight:700;cursor:pointer;border:none;transition:transform .1s}
.completion-btn:active{transform:scale(.97)}
.completion-btn.primary{background:var(--accent);color:#111}
.completion-btn.secondary{background:transparent;border:1px solid var(--border);color:var(--muted)}

/* Memorize completion overlay */
.memorize-overlay{position:fixed;inset:0;background:rgba(0,0,0,.7);z-index:200;display:flex;align-items:center;justify-content:center;opacity:0;pointer-events:none;transition:opacity .4s}
.memorize-overlay.show{opacity:1;pointer-events:auto}
.memorize-card{background:var(--card);border:1px solid var(--border);border-radius:20px;padding:32px 28px;max-width:340px;width:90%;text-align:center;transform:scale(.85);transition:transform .4s cubic-bezier(.34,1.56,.64,1)}
.memorize-overlay.show .memorize-card{transform:scale(1)}
.memorize-star{font-size:48px;margin-bottom:12px}
.memorize-done-title{font-family:var(--serif);font-size:22px;font-weight:700;color:var(--text);margin-bottom:6px}
.memorize-done-sub{font-family:var(--sans);font-size:14px;color:var(--muted);margin-bottom:20px;line-height:1.5}

/* NT Completion overlay */
.finish-overlay{position:fixed;inset:0;background:rgba(0,0,0,.85);z-index:300;display:flex;align-items:center;justify-content:center;opacity:0;pointer-events:none;transition:opacity .5s}
.finish-overlay.show{opacity:1;pointer-events:auto}
.finish-card{background:var(--card);border:1px solid var(--accent);border-radius:20px;padding:36px 28px 28px;max-width:380px;width:90%;text-align:center;transform:scale(.85);transition:transform .5s cubic-bezier(.34,1.56,.64,1)}
.finish-overlay.show .finish-card{transform:scale(1)}
.finish-icon{font-size:56px;margin-bottom:14px}
.finish-title{font-family:var(--serif);font-size:26px;font-weight:700;color:var(--accent);margin-bottom:6px}
.finish-sub{font-family:var(--serif);font-size:15px;font-style:italic;color:var(--text);line-height:1.5;margin-bottom:6px}
.finish-ref{font-family:var(--sans);font-size:12px;font-weight:600;color:var(--accent);margin-bottom:20px}
.finish-prompt{font-family:var(--sans);font-size:14px;color:var(--muted);margin-bottom:10px;line-height:1.5}
.finish-textarea{width:100%;min-height:100px;border:1px solid var(--border);border-radius:10px;padding:12px;font-family:var(--serif);font-size:15px;color:var(--text);background:var(--bg);resize:vertical;line-height:1.5;margin-bottom:16px}
.finish-textarea::placeholder{color:#555}
.finish-textarea:focus{outline:none;border-color:var(--accent)}
.finish-sent{display:none;font-family:var(--sans);font-size:14px;color:var(--green);margin-bottom:16px}

/* Memorize tab */
.memorize-header{text-align:center;margin-bottom:20px}
.verse-counter{display:inline-flex;align-items:center;gap:6px;font-family:var(--sans);font-size:13px;color:var(--muted);margin-top:8px}
.verse-counter .dot{width:6px;height:6px;border-radius:50%;background:var(--green)}
.section-label{font-size:13px;font-weight:700;text-transform:uppercase;letter-spacing:0.08em;color:var(--muted);font-family:var(--sans);margin-bottom:10px;padding-left:2px}
.section-label.review-label{color:var(--purple)}
.section-divider{height:1px;background:var(--border);margin:8px 0 20px}
.card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}
.reference{font-size:20px;font-weight:700;color:var(--accent)}
.card-meta{font-size:12px;font-weight:600;color:var(--muted);font-family:var(--sans)}
.step{border:1px solid var(--border);border-radius:10px;margin-bottom:10px;overflow:hidden;transition:border-color .2s}
.step:last-child{margin-bottom:0}
.step.active{border-color:var(--accent)}
.step.completed{border-color:var(--green-border);background:var(--green-bg)}
.step.locked{opacity:.45;pointer-events:none}
.step-header{display:flex;align-items:center;gap:10px;padding:12px 16px;cursor:pointer;font-family:var(--sans);user-select:none}
.step-circle{width:24px;height:24px;border-radius:50%;border:2px solid var(--border);display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:700;color:var(--muted);flex-shrink:0;transition:all .2s}
.step.active .step-circle{border-color:var(--accent);color:var(--accent)}
.step.completed .step-circle{border-color:var(--green);background:var(--green);color:#111}
.step-label{font-size:14px;font-weight:600;color:var(--text);flex:1}
.step.completed .step-label{color:var(--green-text)}
.step-body{padding:0 16px 16px}
.verse-text{font-size:17px;line-height:1.8;margin-bottom:8px}
.w{display:inline;position:relative}
.w-blank{color:transparent;cursor:pointer;border-bottom:2.5px solid #555;border-radius:0;transition:color .25s,border-color .25s}
.w-peek{color:var(--blue);border-bottom:2.5px solid transparent;cursor:default;animation:fadeReveal .25s ease}
.w-hint{cursor:pointer;color:#666;font-style:italic}
@keyframes fadeReveal{from{opacity:0}to{opacity:1}}
.peek-hint{font-size:12px;color:#555;margin-top:4px;font-family:var(--sans);font-style:italic}
.step-actions{display:flex;gap:8px;justify-content:center;margin-top:14px;flex-wrap:wrap}
.btn{padding:10px 22px;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;font-family:var(--sans);transition:transform .1s;border:none}
.btn:active{transform:scale(0.97)}
.btn-primary{background:var(--accent);color:#111}
.btn-secondary{background:var(--card);color:var(--text);border:1px solid var(--border)}
.btn-ghost{background:transparent;color:var(--muted);font-weight:500;font-size:13px;padding:8px 14px}
.btn-ghost:hover{color:var(--text)}
.review-choice{text-align:center;padding:12px 0 4px}
.review-choice p{font-size:15px;color:var(--text);margin-bottom:14px;font-family:var(--sans)}
.review-choice-btns{display:flex;gap:10px;justify-content:center;flex-wrap:wrap}
.recall-block{text-align:center;padding:24px 10px}
.recall-block h3{font-size:18px;font-weight:600;color:var(--accent);margin-bottom:6px}
.recall-block p{font-size:14px;color:var(--muted);margin-bottom:18px;font-family:var(--sans)}
.grade-block{text-align:center;margin-top:14px}
.grade-block p{font-size:15px;font-weight:600;color:var(--text);margin-bottom:10px;font-family:var(--sans)}
.grade-buttons{display:flex;gap:8px;justify-content:center}
.grade-btn{padding:8px 16px;border-radius:8px;border:none;font-size:14px;font-weight:600;cursor:pointer;font-family:var(--sans);transition:transform .1s}
.grade-btn:active{transform:scale(0.96)}
.grade-perfect{background:var(--green-bg);color:var(--green-text)}
.grade-almost{background:var(--yellow-bg);color:var(--yellow-text)}
.grade-need{background:var(--red-bg);color:var(--red-text)}
.grade-result{text-align:center;font-size:14px;color:var(--text);padding:12px 16px;background:rgba(255,255,255,.05);border-radius:8px;margin-top:12px;font-family:var(--sans);line-height:1.5}
.day-complete{text-align:center;padding:14px;background:var(--green-bg);border-radius:10px;margin-top:12px}
.day-complete p{font-size:14px;color:var(--green-text);font-weight:600;font-family:var(--sans)}
.skip-bar{display:flex;justify-content:center;gap:8px;padding:10px 0 4px;flex-wrap:wrap}
.review-card{border-color:var(--purple-bg)}
.empty-state{text-align:center;padding:40px;font-size:16px;color:var(--muted)}

/* Notes tab */
.search-box{width:100%;padding:10px 14px;border:1px solid var(--border);border-radius:10px;font-family:var(--sans);font-size:14px;background:var(--card);color:var(--text);margin-bottom:16px}
.search-box:focus{outline:none;border-color:var(--accent)}
.note-item{padding:14px 0;border-bottom:1px solid var(--border);cursor:pointer}
.note-item:last-child{border-bottom:none}
.note-item .note-ref{font-family:var(--sans);font-size:13px;font-weight:600;color:var(--accent)}
.note-item .note-date{font-family:var(--sans);font-size:12px;color:var(--muted);float:right}
.note-item .note-preview{font-size:14px;color:var(--muted);margin-top:4px;line-height:1.4}

/* Profile tab */
.profile-header{text-align:center;margin-bottom:24px}
.profile-avatar{width:72px;height:72px;border-radius:50%;background:transparent;border:2px solid var(--accent);display:flex;align-items:center;justify-content:center;margin:0 auto 12px;font-size:30px;color:var(--accent);font-family:var(--serif);font-weight:700;letter-spacing:1px}
.profile-section-label{font-family:var(--sans);font-size:11px;text-transform:uppercase;letter-spacing:.1em;color:var(--muted);margin:28px 0 12px;padding-left:2px}
.profile-stats{display:flex;justify-content:space-around;text-align:center;padding:4px 0}
.stat-item .number{font-family:var(--serif);font-size:24px;font-weight:700;color:var(--accent)}
.stat-item .label{font-family:var(--sans);font-size:11px;color:var(--muted);text-transform:uppercase;letter-spacing:.05em;margin-top:2px}
.profile-actions-card{display:flex;gap:10px;padding:12px!important}
.profile-action-btn{flex:1;display:flex;align-items:center;justify-content:center;gap:8px;padding:12px;border-radius:var(--radius);background:rgba(255,255,255,.04);border:1px solid var(--border);color:var(--text);font-family:var(--sans);font-size:13px;font-weight:600;cursor:pointer;transition:background .2s}
.profile-action-btn:active{background:rgba(255,255,255,.08)}
.profile-action-btn svg{color:var(--accent)}
.profile-select{background:var(--card);border:1px solid var(--border);color:var(--text);font-family:var(--sans);font-size:14px;padding:8px 12px;border-radius:var(--radius);appearance:auto;cursor:pointer}
.donate-card{cursor:pointer;transition:border-color .2s}
.donate-card:active{border-color:var(--green)}
.streak-display{display:flex;justify-content:center;gap:24px;margin-top:16px}
.streak-item{text-align:center}
.streak-item .number{font-size:32px;font-weight:700;color:var(--accent);font-family:var(--sans)}
.streak-item .label{font-size:12px;color:var(--muted);font-family:var(--sans)}
.consistency-chart{display:flex;gap:3px;align-items:end;height:60px;padding:12px 0}
.consistency-bar{flex:1;background:rgba(74,222,128,.15);border-radius:3px 3px 0 0;min-height:4px;transition:height .3s}
.consistency-bar.active{background:var(--green)}
.settings-row{display:flex;align-items:center;justify-content:space-between;padding:14px 0;border-bottom:1px solid var(--border);font-family:var(--sans);font-size:15px}
.settings-row:last-child{border-bottom:none}
.settings-row .right{color:var(--muted);font-size:14px}
