:root {
  --cream:       #faf6ef;
  --warm-white:  #fff9f2;
  --amber:       #e8a84c;
  --amber-light: #f5d598;
  --amber-dark:  #c27c1a;
  --forest:      #2d4a3e;
  --forest-mid:  #3d6352;
  --forest-light:#6a9e84;
  --blush:       #e8b4a2;
  --ink:         #1e1e1e;
  --ink-soft:    #4a4540;
  --muted:       #9a9088;
  --border:      #e2d9cc;
  --card-bg:     #fffdf9;
  --success:     #4a9e6a;
  --tag-quick:   #ffd166;
  --tag-deep:    #a8d5ba;
  --radius:      16px;
  --radius-sm:   8px;
  --shadow:      0 4px 24px rgba(45,74,62,.10);
  --shadow-lg:   0 12px 48px rgba(45,74,62,.14);
}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:'DM Sans',sans-serif;
  background:var(--cream);
  color:var(--ink);
  line-height:1.6;
  min-height:100vh;
  overflow-x:hidden;
}

/* ── CONFETTI ── */
#confetti-canvas{position:fixed;top:0;left:0;width:100%;height:100%;pointer-events:none;z-index:9999}

/* ── LAYOUT ── */
#app{max-width:760px;margin:0 auto;padding:0 16px 60px}

/* ── HEADER ── */
.site-header{display:flex;align-items:center;justify-content:space-between;gap:18px;padding:18px 0 10px;margin-bottom:6px;border-bottom:1px solid rgba(226,217,204,.78)}
.brand-lockup{display:flex;align-items:center;gap:12px;text-decoration:none;color:var(--forest)}
.brand-mark{width:42px;height:42px;border-radius:50%;display:grid;place-items:center;background:linear-gradient(135deg,var(--forest),var(--forest-mid));color:var(--warm-white);font-family:'Playfair Display',serif;font-size:22px;font-weight:700;box-shadow:0 8px 22px rgba(45,74,62,.18)}
.brand-text{display:grid;gap:1px}
.brand-name{font-size:15px;font-weight:800;letter-spacing:.01em;color:var(--forest)}
.brand-kicker{font-family:'DM Mono',monospace;font-size:10px;letter-spacing:.12em;text-transform:uppercase;color:var(--muted)}
.site-header-note{font-size:13px;color:var(--ink-soft);text-align:right;max-width:220px;line-height:1.35}
.app-header{text-align:center;padding:36px 0 24px}
.app-header .eyebrow{font-family:'DM Mono',monospace;font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--forest-mid);margin-bottom:10px}
.app-header h1{font-family:'Playfair Display',serif;font-size:clamp(28px,6vw,44px);color:var(--forest);line-height:1.15;margin-bottom:8px}
.app-header h1 em{color:var(--amber-dark);font-style:italic}
.app-header p{font-size:15px;color:var(--ink-soft);max-width:420px;margin:0 auto}

/* ── LOADING / ERROR ── */
.state-card{background:var(--card-bg);border:1px solid var(--border);border-radius:var(--radius);padding:48px 32px;text-align:center;box-shadow:var(--shadow-lg);margin:40px 0}
.state-card .icon{font-size:48px;margin-bottom:16px;display:block}
.state-card h2{font-family:'Playfair Display',serif;font-size:22px;color:var(--forest);margin-bottom:10px}
.state-card p{font-size:15px;color:var(--ink-soft);line-height:1.7;margin-bottom:8px}
.state-card code{background:var(--cream);padding:2px 8px;border-radius:4px;font-family:'DM Mono',monospace;font-size:13px;color:var(--amber-dark)}
.spinner{width:40px;height:40px;border:3px solid var(--border);border-top-color:var(--forest);border-radius:50%;animation:spin .8s linear infinite;margin:0 auto 20px}
@keyframes spin{to{transform:rotate(360deg)}}

/* â”€â”€ VIEW SWITCH â”€â”€ */
.view-switch{display:flex;gap:8px;background:rgba(255,253,249,.72);border:1px solid var(--border);border-radius:99px;padding:6px;margin:0 auto 24px;box-shadow:var(--shadow);max-width:660px}
.view-tab{flex:1;border:0;background:transparent;color:var(--ink-soft);border-radius:99px;padding:10px 14px;font-family:'DM Sans',sans-serif;font-size:13px;font-weight:600;cursor:pointer;transition:all .2s}
.view-tab:hover{color:var(--forest);background:var(--cream)}
.view-tab.active{background:var(--forest);color:white;box-shadow:0 4px 14px rgba(45,74,62,.22)}

/* HOMEPAGE DASHBOARD */
.home-dashboard{display:grid;gap:18px}
.home-hero{display:flex;align-items:center;justify-content:space-between;gap:22px;background:linear-gradient(135deg,var(--forest),var(--forest-mid));border-radius:var(--radius);padding:28px;box-shadow:var(--shadow-lg);color:white;overflow:hidden;position:relative}
.home-hero::after{content:'';position:absolute;right:-54px;top:-54px;width:180px;height:180px;border-radius:50%;background:rgba(255,255,255,.06)}
.home-hero .eyebrow,.home-section-head .eyebrow{font-family:'DM Mono',monospace;font-size:11px;letter-spacing:.14em;text-transform:uppercase;margin-bottom:8px}
.home-hero .eyebrow{color:var(--amber-light)}
.home-hero h2{font-family:'Playfair Display',serif;font-size:clamp(26px,5vw,38px);line-height:1.12;margin-bottom:8px;position:relative;z-index:1}
.home-hero p{max-width:500px;font-size:15px;line-height:1.65;color:rgba(255,255,255,.78);position:relative;z-index:1}
.home-progress-ring{width:112px;height:112px;border-radius:50%;border:10px solid rgba(245,213,152,.42);background:rgba(255,255,255,.08);display:grid;place-items:center;align-content:center;flex-shrink:0;position:relative;z-index:1}
.home-progress-ring strong{font-family:'Playfair Display',serif;font-size:28px;line-height:1;color:white}
.home-progress-ring span{font-family:'DM Mono',monospace;font-size:10px;letter-spacing:.08em;text-transform:uppercase;color:var(--amber-light);margin-top:5px}
.dashboard-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px}
.dashboard-card,.home-tags-panel{background:var(--card-bg);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);padding:20px}
.dashboard-card-primary{background:linear-gradient(135deg,#fffdf9,#fff4dd);border-color:var(--amber-light)}
.dashboard-kicker{font-family:'DM Mono',monospace;font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--forest-mid);margin-bottom:8px}
.dashboard-card h3{font-family:'Playfair Display',serif;font-size:21px;line-height:1.2;color:var(--forest);margin-bottom:8px}
.dashboard-card p{font-size:14px;color:var(--ink-soft);line-height:1.55;margin-bottom:14px}
.dashboard-action{border:1.5px solid var(--border);background:var(--warm-white);color:var(--forest);border-radius:99px;padding:10px 15px;font-family:'DM Sans',sans-serif;font-size:13px;font-weight:700;cursor:pointer;transition:transform .2s,box-shadow .2s,background .2s,color .2s}
.dashboard-action:hover{transform:translateY(-1px);box-shadow:var(--shadow);border-color:var(--forest-light)}
.dashboard-action.primary{background:linear-gradient(135deg,var(--forest-mid),var(--forest));border-color:var(--forest);color:white}
.summary-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin:2px 0 14px}
.summary-stats div{background:var(--cream);border:1px solid var(--border);border-radius:var(--radius-sm);padding:10px;text-align:center}
.summary-stats strong{display:block;font-family:'Playfair Display',serif;font-size:24px;line-height:1;color:var(--forest)}
.summary-stats span{display:block;font-family:'DM Mono',monospace;font-size:10px;letter-spacing:.08em;text-transform:uppercase;color:var(--muted);margin-top:4px}
.dashboard-progress-track{height:9px;background:var(--amber-light);border-radius:99px;overflow:hidden;margin-bottom:12px}
.dashboard-progress-track span{display:block;height:100%;background:linear-gradient(90deg,var(--forest-light),var(--forest));border-radius:99px;min-width:4px}
.home-section-head{margin-bottom:14px}
.home-section-head .eyebrow{color:var(--forest-mid)}
.home-section-head h2{font-family:'Playfair Display',serif;font-size:24px;line-height:1.2;color:var(--forest)}
.home-tag-list{display:flex;flex-wrap:wrap;gap:9px}
.home-tag-chip{display:flex;align-items:center;gap:8px;border:1.5px solid var(--border);background:var(--cream);color:var(--forest);border-radius:99px;padding:9px 13px;font-family:'DM Sans',sans-serif;font-size:13px;font-weight:700;cursor:pointer;transition:all .2s}
.home-tag-chip:hover{background:var(--forest);border-color:var(--forest);color:white;transform:translateY(-1px);box-shadow:var(--shadow)}
.home-tag-chip strong{font-family:'DM Mono',monospace;font-size:11px;opacity:.74}

/* ── PROGRESS ── */
.progress-section{background:var(--card-bg);border:1px solid var(--border);border-radius:var(--radius);padding:20px 24px;margin-bottom:24px;box-shadow:var(--shadow)}
.progress-top{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}
.progress-label{font-family:'DM Mono',monospace;font-size:12px;color:var(--forest-mid);letter-spacing:.06em}
.progress-count{font-size:13px;font-weight:600;color:var(--forest)}
.progress-bar-track{height:10px;background:var(--amber-light);border-radius:99px;overflow:hidden}
.progress-bar-fill{height:100%;background:linear-gradient(90deg,var(--forest-light),var(--forest));border-radius:99px;transition:width .6s cubic-bezier(.4,0,.2,1);min-width:4px}
.streak-row{display:flex;gap:6px;flex-wrap:wrap;margin-top:14px}
.streak-dot{width:22px;height:22px;border-radius:50%;background:var(--amber-light);border:2px solid var(--border);cursor:pointer;transition:transform .15s,background .2s;position:relative}
.streak-dot.completed{background:var(--forest);border-color:var(--forest)}
.streak-dot.today{border-color:var(--amber-dark);box-shadow:0 0 0 3px var(--amber-light);animation:pulse-dot 2s infinite}
.streak-dot:hover{transform:scale(1.2)}
@keyframes pulse-dot{0%,100%{box-shadow:0 0 0 3px var(--amber-light)}50%{box-shadow:0 0 0 6px rgba(232,168,76,.25)}}

/* ── DAY NAV ── */
.day-nav{display:flex;align-items:center;gap:12px;margin-bottom:20px}
.day-nav-btn{width:40px;height:40px;border-radius:50%;border:2px solid var(--border);background:var(--card-bg);color:var(--forest);font-size:18px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s;flex-shrink:0}
.day-nav-btn:hover:not(:disabled){background:var(--forest);color:white;border-color:var(--forest)}
.day-nav-btn:disabled{opacity:.3;cursor:default}
.day-selector{flex:1;display:flex;gap:6px;overflow-x:auto;scrollbar-width:none;padding:4px 0}
.day-selector::-webkit-scrollbar{display:none}
.day-pill{padding:6px 14px;border-radius:99px;border:2px solid var(--border);background:var(--card-bg);font-size:13px;font-weight:500;cursor:pointer;white-space:nowrap;transition:all .2s;color:var(--ink-soft);font-family:'DM Sans',sans-serif}
.day-pill:hover{border-color:var(--forest-light);color:var(--forest)}
.day-pill.active{background:var(--forest);color:white;border-color:var(--forest)}
.day-pill.done{background:var(--forest-light);color:white;border-color:var(--forest-light)}
.day-pill.missing{opacity:.4;cursor:default}

/* ── CHALLENGE CARD ── */
.challenge-card{background:var(--card-bg);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-lg);margin-bottom:24px;animation:card-in .4s cubic-bezier(.4,0,.2,1)}
.challenge-card.completed{border-color:rgba(74,158,106,.48);box-shadow:0 12px 48px rgba(45,74,62,.14),0 0 0 3px rgba(74,158,106,.12)}
@keyframes card-in{from{opacity:0;transform:translateY(18px)}to{opacity:1;transform:translateY(0)}}

.card-hero{background:linear-gradient(135deg,var(--forest) 0%,var(--forest-mid) 100%);padding:32px 28px 24px;position:relative;overflow:hidden}
.card-hero::after{content:'';position:absolute;top:-40px;right:-40px;width:180px;height:180px;border-radius:50%;background:rgba(255,255,255,.05)}
.card-hero::before{content:'';position:absolute;bottom:-20px;left:40px;width:100px;height:100px;border-radius:50%;background:rgba(232,168,76,.12)}
.day-badge{display:inline-flex;align-items:center;gap:6px;background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.2);border-radius:99px;padding:4px 14px;font-family:'DM Mono',monospace;font-size:12px;letter-spacing:.1em;color:var(--amber-light);margin-bottom:14px}
.day-badge .dot{width:7px;height:7px;border-radius:50%;background:var(--amber)}
.card-hero h2{font-family:'Playfair Display',serif;font-size:clamp(22px,4vw,30px);color:white;line-height:1.2;margin-bottom:6px;position:relative;z-index:1}
.card-hero .subtitle{font-size:14px;color:rgba(255,255,255,.7);font-weight:300;position:relative;z-index:1}
.completed-banner{position:absolute;top:16px;right:16px;background:var(--success);color:white;border-radius:99px;padding:4px 11px 4px 5px;font-size:12px;font-weight:700;display:none;align-items:center;gap:6px;z-index:2;box-shadow:0 8px 20px rgba(24,84,50,.24)}
.completed-banner.show{display:flex}
.completed-banner .completion-mark{width:18px;height:18px;font-size:12px;background:white;color:var(--success);box-shadow:none}

/* ── SECTIONS ── */
.section{padding:24px 28px;border-bottom:1px solid var(--border)}
.section:last-child{border-bottom:none}
.section-tag{display:inline-flex;align-items:center;gap:6px;border-radius:99px;padding:3px 12px;font-size:11px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;margin-bottom:12px}
.tag-story{background:var(--tag-story,#bde0fe);color:#1a5276}
.tag-lesson{background:var(--tag-lesson,#f4a261);color:#7d2d00}
.tag-quick{background:var(--tag-quick);color:#5c4000}
.tag-deep{background:var(--tag-deep);color:#1a4a2e}
.section h3{font-family:'Playfair Display',serif;font-size:18px;color:var(--forest);margin-bottom:10px;line-height:1.3}
.section p{font-size:15px;color:var(--ink-soft);line-height:1.75;margin-bottom:10px}
.section p:last-child{margin-bottom:0}

.whack-box{background:linear-gradient(135deg,#fff8ee,#fff3e0);border:2px solid var(--amber);border-radius:var(--radius-sm);padding:16px 20px;margin-top:12px;position:relative}
.whack-box::before{content:'💡';position:absolute;top:-12px;left:16px;font-size:22px}
.whack-box p{font-size:15px;font-weight:500;color:var(--amber-dark);margin:0;line-height:1.5}

.task-block{background:var(--cream);border-radius:var(--radius-sm);padding:16px 20px;margin-top:12px}
.task-block .task-meta{display:flex;align-items:center;gap:8px;margin-bottom:8px;flex-wrap:wrap}
.time-badge{background:var(--forest);color:white;border-radius:99px;padding:2px 10px;font-size:11px;font-family:'DM Mono',monospace;font-weight:500}
.task-block p{font-size:14px;color:var(--ink-soft);line-height:1.65}
.task-block ul{margin:8px 0 0 0;padding-left:18px;font-size:14px;color:var(--ink-soft);line-height:1.8}
.task-block ul li{margin-bottom:2px}

.mindset-strip{display:flex;gap:8px;flex-wrap:wrap;padding:16px 28px;border-bottom:1px solid var(--border)}
.mindset-pill{background:var(--cream);border:1.5px solid var(--border);border-radius:99px;padding:5px 14px;font-size:12px;color:var(--ink-soft);font-weight:500}
button.mindset-pill{font-family:'DM Sans',sans-serif;cursor:pointer;transition:all .2s}
button.mindset-pill:hover{background:var(--forest);border-color:var(--forest);color:white;transform:translateY(-1px)}

/* â”€â”€ TAG BROWSER â”€â”€ */
.tag-browser{display:grid;gap:18px}
.tag-panel{background:var(--card-bg);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-lg);overflow:hidden}
.tag-panel-head{padding:24px 28px 18px;border-bottom:1px solid var(--border);background:linear-gradient(135deg,#fffdf9,#fff7eb)}
.tag-panel-head .eyebrow{font-family:'DM Mono',monospace;font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--forest-mid);margin-bottom:8px}
.tag-panel-head h2{font-family:'Playfair Display',serif;font-size:clamp(24px,5vw,34px);line-height:1.15;color:var(--forest);margin-bottom:8px}
.tag-panel-head p{font-size:14px;color:var(--ink-soft);max-width:540px}
.tag-cloud{display:flex;flex-wrap:wrap;gap:8px;padding:18px 28px;border-bottom:1px solid var(--border)}
.tag-filter{border:1.5px solid var(--border);background:var(--cream);color:var(--ink-soft);border-radius:99px;padding:8px 12px;font-family:'DM Sans',sans-serif;font-size:12px;font-weight:600;cursor:pointer;transition:all .2s}
.tag-filter:hover{border-color:var(--forest-light);color:var(--forest);transform:translateY(-1px)}
.tag-filter.active{background:var(--forest);border-color:var(--forest);color:white}
.tag-filter .count{font-family:'DM Mono',monospace;font-size:11px;opacity:.72;margin-left:4px}
.tag-results{padding:20px 28px 28px}
.tag-results-head{display:flex;align-items:end;justify-content:space-between;gap:16px;margin-bottom:14px}
.tag-results-head h3{font-family:'Playfair Display',serif;font-size:20px;color:var(--forest);line-height:1.2}
.tag-results-head p{font-size:12px;color:var(--muted);font-family:'DM Mono',monospace;white-space:nowrap}
.tag-result-list{display:grid;gap:10px}
.tag-result{width:100%;text-align:left;border:1px solid var(--border);background:var(--warm-white);border-radius:var(--radius-sm);padding:14px 16px;cursor:pointer;font-family:'DM Sans',sans-serif;transition:all .2s;position:relative;overflow:hidden}
.tag-result.done{border-color:rgba(74,158,106,.42);background:linear-gradient(90deg,rgba(74,158,106,.12),var(--warm-white) 34%)}
.tag-result.done::before{content:'';position:absolute;inset:0 auto 0 0;width:4px;background:var(--success)}
.tag-result:hover{border-color:var(--forest-light);box-shadow:var(--shadow);transform:translateY(-1px)}
.tag-result-top{display:flex;justify-content:space-between;gap:12px;align-items:center;margin-bottom:4px}
.tag-result-day{font-family:'DM Mono',monospace;font-size:11px;color:var(--amber-dark);letter-spacing:.08em}
.completion-mark{display:inline-flex;align-items:center;justify-content:center;width:22px;height:22px;border-radius:50%;background:var(--success);color:white;font-size:13px;font-weight:800;line-height:1;box-shadow:0 3px 10px rgba(74,158,106,.28);flex:0 0 auto}
.tag-result-title{font-size:15px;font-weight:700;color:var(--forest);line-height:1.35;margin-bottom:3px}
.tag-result-subtitle{font-size:13px;color:var(--ink-soft);line-height:1.45}
.empty-tags{padding:32px 28px;color:var(--ink-soft);font-size:14px;text-align:center}

/* JOURNAL DASHBOARD */
.journal-dashboard{display:grid;gap:18px}
.journal-panel{background:var(--card-bg);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-lg);overflow:hidden}
.journal-panel-head{display:flex;align-items:flex-start;justify-content:space-between;gap:18px;padding:24px 28px 18px;border-bottom:1px solid var(--border);background:linear-gradient(135deg,#fffdf9,#fff7eb)}
.journal-panel-head .eyebrow{font-family:'DM Mono',monospace;font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--forest-mid);margin-bottom:8px}
.journal-panel-head h2{font-family:'Playfair Display',serif;font-size:clamp(24px,5vw,34px);line-height:1.15;color:var(--forest);margin-bottom:8px}
.journal-panel-head p{font-size:14px;color:var(--ink-soft);max-width:520px}
.journal-actions{display:flex;gap:8px;flex-wrap:wrap;justify-content:flex-end;flex-shrink:0}
.journal-summary{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:10px;padding:18px 28px;border-bottom:1px solid var(--border);background:var(--warm-white)}
.journal-stat{background:var(--cream);border:1px solid var(--border);border-radius:var(--radius-sm);padding:12px;text-align:center}
.journal-stat strong{display:block;font-family:'Playfair Display',serif;font-size:24px;line-height:1.1;color:var(--forest)}
.journal-stat span{display:block;font-family:'DM Mono',monospace;font-size:10px;letter-spacing:.08em;text-transform:uppercase;color:var(--muted);margin-top:4px}
.journal-entries{display:grid;gap:14px;padding:20px 28px 28px}
.journal-entry{border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--warm-white);overflow:hidden}
.journal-entry-head{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;padding:16px 18px;border-bottom:1px solid var(--border)}
.journal-day{font-family:'DM Mono',monospace;font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--amber-dark);margin-bottom:4px}
.journal-entry h3{font-family:'Playfair Display',serif;font-size:21px;line-height:1.2;color:var(--forest);margin-bottom:4px}
.journal-entry-head p:not(.journal-day){font-size:13px;color:var(--ink-soft);line-height:1.45}
.journal-fields{display:grid;gap:12px;padding:16px 18px}
.journal-fields label{display:grid;gap:6px}
.journal-fields span{font-size:13px;font-weight:700;color:var(--forest)}
.journal-fields textarea{width:100%;min-height:76px;resize:vertical;border:1.5px solid var(--border);border-radius:var(--radius-sm);background:var(--card-bg);padding:11px 12px;font:inherit;font-size:14px;line-height:1.5;color:var(--ink);outline:none;transition:border-color .2s,box-shadow .2s}
.journal-fields textarea:focus{border-color:var(--forest-light);box-shadow:0 0 0 3px rgba(106,158,132,.18)}
.journal-saved{padding:0 18px 16px;font-size:12px;color:var(--muted)}
.journal-empty{padding:34px 20px;text-align:center}
.journal-empty h3{font-family:'Playfair Display',serif;font-size:22px;color:var(--forest);margin-bottom:8px}
.journal-empty p{font-size:14px;color:var(--ink-soft);margin-bottom:16px}

/* COMPLETE BUTTON */
.complete-section{padding:24px 28px;background:linear-gradient(135deg,#f8fff6,#edf7f1);display:flex;flex-direction:column;align-items:center;gap:12px}
.btn-complete{width:100%;max-width:340px;padding:16px 32px;border-radius:99px;border:none;background:linear-gradient(135deg,var(--forest-mid),var(--forest));color:white;font-family:'DM Sans',sans-serif;font-size:16px;font-weight:600;cursor:pointer;transition:all .25s cubic-bezier(.4,0,.2,1);box-shadow:0 4px 16px rgba(45,74,62,.28);letter-spacing:.02em;position:relative;overflow:hidden}
.btn-complete::before{content:'';position:absolute;inset:0;background:linear-gradient(135deg,var(--amber),var(--amber-dark));opacity:0;transition:opacity .25s}
.btn-complete:hover:not(:disabled)::before{opacity:1}
.btn-complete span{position:relative;z-index:1}
.btn-complete:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 8px 28px rgba(45,74,62,.32)}
.btn-complete:disabled{background:var(--success);cursor:default;box-shadow:none}
.complete-note{font-size:13px;color:var(--muted);text-align:center}

/* DAILY RESET LOOP */
.reset-loop{padding:26px 28px;background:linear-gradient(135deg,#f9fff6,#fff8eb);border-top:1px solid var(--border)}
.reset-loop-head{display:flex;justify-content:space-between;gap:18px;align-items:flex-start;margin-bottom:18px}
.reset-loop .eyebrow{font-family:'DM Mono',monospace;font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--forest-mid);margin-bottom:6px}
.reset-loop h3{font-family:'Playfair Display',serif;font-size:22px;line-height:1.2;color:var(--forest);margin-bottom:6px}
.reset-loop p{font-size:14px;color:var(--ink-soft);line-height:1.65}
.reset-loop-status{min-width:76px;text-align:center;border:1px solid var(--border);border-radius:var(--radius-sm);background:rgba(255,253,249,.82);padding:8px 10px;color:var(--forest)}
.reset-loop-status strong{display:block;font-family:'Playfair Display',serif;font-size:24px;line-height:1}
.reset-loop-status span{display:block;font-family:'DM Mono',monospace;font-size:10px;letter-spacing:.08em;text-transform:uppercase;color:var(--muted);margin-top:4px}
.reset-fields{display:grid;gap:12px}
.reset-field{background:var(--card-bg);border:1px solid var(--border);border-radius:var(--radius-sm);padding:14px 16px;box-shadow:0 2px 12px rgba(45,74,62,.06)}
.reset-field label{display:block;font-size:13px;font-weight:700;color:var(--forest);margin-bottom:4px}
.reset-field .prompt{font-size:13px;color:var(--muted);line-height:1.45;margin-bottom:10px}
.reset-field textarea{width:100%;min-height:72px;resize:vertical;border:1.5px solid var(--border);border-radius:var(--radius-sm);background:var(--warm-white);padding:11px 12px;font:inherit;font-size:14px;line-height:1.5;color:var(--ink);outline:none;transition:border-color .2s,box-shadow .2s}
.reset-field textarea:focus{border-color:var(--forest-light);box-shadow:0 0 0 3px rgba(106,158,132,.18)}
.reset-actions{display:flex;gap:10px;flex-wrap:wrap;margin-top:16px}
.reset-action{border:0;border-radius:99px;padding:12px 18px;font-family:'DM Sans',sans-serif;font-size:14px;font-weight:700;cursor:pointer;transition:transform .2s,box-shadow .2s,background .2s,color .2s}
.reset-action.primary{background:linear-gradient(135deg,var(--forest-mid),var(--forest));color:white;box-shadow:0 4px 16px rgba(45,74,62,.24)}
.reset-action.secondary{background:var(--card-bg);color:var(--forest);border:1.5px solid var(--border)}
.reset-action:hover{transform:translateY(-1px);box-shadow:var(--shadow)}
.reset-action:disabled{cursor:default;transform:none;box-shadow:none;opacity:.72}
.share-preview{margin-top:16px;border:1px solid var(--border);border-radius:var(--radius);background:var(--card-bg);overflow:hidden;box-shadow:var(--shadow)}
.share-preview-head{background:linear-gradient(135deg,var(--forest),var(--forest-mid));color:white;padding:18px 20px}
.share-preview-head span{display:block;font-family:'DM Mono',monospace;font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--amber-light);margin-bottom:6px}
.share-preview-head strong{font-family:'Playfair Display',serif;font-size:22px;line-height:1.2}
.share-preview-body{padding:18px 20px}
.share-preview-body p{font-size:14px;color:var(--ink-soft);margin-bottom:10px}
.share-preview-body p:last-child{margin-bottom:0}
.share-preview-body strong{color:var(--forest)}
.save-note{font-size:12px;color:var(--muted);margin-top:10px;min-height:18px}

/* ── NOT FOUND CARD ── */
.not-found{text-align:center;padding:40px 28px}
.not-found .emoji{font-size:48px;display:block;margin-bottom:16px}
.not-found h3{font-family:'Playfair Display',serif;font-size:22px;color:var(--forest);margin-bottom:10px}
.not-found p{font-size:15px;color:var(--ink-soft)}

/* ── CELEBRATION ── */
#celebration{display:none;position:fixed;inset:0;background:rgba(45,74,62,.85);z-index:9998;align-items:center;justify-content:center;backdrop-filter:blur(4px)}
#celebration.show{display:flex}
.celebration-card{background:var(--card-bg);border-radius:24px;padding:48px 40px;text-align:center;max-width:400px;width:90%;animation:bounce-in .5s cubic-bezier(.4,0,.2,1);box-shadow:0 24px 80px rgba(0,0,0,.3)}
@keyframes bounce-in{from{opacity:0;transform:scale(.7)}to{opacity:1;transform:scale(1)}}
.celebration-emoji{font-size:64px;display:block;margin-bottom:16px}
.celebration-card h3{font-family:'Playfair Display',serif;font-size:26px;color:var(--forest);margin-bottom:10px}
.celebration-card p{font-size:15px;color:var(--ink-soft);line-height:1.65;margin-bottom:24px}
.btn-next{padding:14px 36px;border-radius:99px;border:none;background:linear-gradient(135deg,var(--forest-mid),var(--forest));color:white;font-size:15px;font-weight:600;cursor:pointer;font-family:'DM Sans',sans-serif;transition:all .2s;box-shadow:0 4px 16px rgba(45,74,62,.28)}
.btn-next:hover{transform:translateY(-2px);box-shadow:0 8px 24px rgba(45,74,62,.32)}

/* ── FOOTER ── */
.app-footer{display:flex;justify-content:space-between;align-items:center;gap:14px;margin-top:26px;padding:22px 0 0;border-top:1px solid rgba(226,217,204,.88);font-size:12px;color:var(--muted)}
.footer-brand{font-weight:700;color:var(--forest)}
.footer-brand::after{content:' · ';color:var(--muted);font-weight:400}
.footer-note{line-height:1.45}
.footer-copyright{font-family:'DM Mono',monospace;font-size:11px;text-align:right;white-space:nowrap}
.reset-link{display:block;text-align:center;margin-top:12px;font-size:12px;color:var(--muted);cursor:pointer;text-decoration:underline;background:none;border:none;font-family:'DM Sans',sans-serif}
.reset-link:hover{color:var(--blush)}

/* ── RESPONSIVE ── */
@media(max-width:520px){
  .site-header{align-items:flex-start}
  .site-header-note{display:none}
  .brand-mark{width:38px;height:38px;font-size:20px}
  .app-header{padding-top:30px}
  .view-switch{border-radius:var(--radius-sm);display:grid;grid-template-columns:1fr;padding:5px}
  .view-tab{border-radius:var(--radius-sm);padding:9px 10px}
  .home-hero{display:grid;padding:22px 20px}
  .home-progress-ring{width:96px;height:96px;border-width:8px}
  .dashboard-grid{grid-template-columns:1fr}
  .dashboard-card,.home-tags-panel{padding:18px}
  .summary-stats strong{font-size:22px}
  .section{padding:20px 20px}
  .card-hero{padding:24px 20px 20px}
  .complete-section{padding:20px 20px}
  .reset-loop{padding:22px 20px}
  .reset-loop-head{display:block}
  .reset-loop-status{margin-top:12px}
  .reset-actions{display:grid}
  .reset-action{width:100%}
  .progress-section{padding:16px 18px}
  .mindset-strip{padding:14px 20px}
  .tag-panel-head,.tag-cloud,.tag-results{padding-left:20px;padding-right:20px}
  .tag-results-head{display:block}
  .tag-results-head p{margin-top:4px}
  .journal-panel-head{display:grid;padding:22px 20px 16px}
  .journal-actions{justify-content:flex-start}
  .journal-actions .dashboard-action{flex:1}
  .journal-summary{grid-template-columns:repeat(2,minmax(0,1fr));padding:16px 20px}
  .journal-entries{padding:18px 20px 22px}
  .journal-entry-head{display:grid}
  .view-switch{margin-bottom:18px}
  .app-footer{display:grid;gap:8px;text-align:center}
  .footer-copyright{text-align:center;white-space:normal}
}
