/* Homestead Academy — Master Stylesheet v7
   All pages link this. Dynamic season colours and dark-mode
   bg/text are injected as a tiny inline <style> in each PHP.
   ============================================================ */
@import url('https://fonts.googleapis.com/css2?family=Lora:ital,wght@0,400;0,600;1,400&family=DM+Sans:wght@300;400;500;600&display=swap');

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
a{color:inherit}img{max-width:100%;display:block}

:root{
  --green-50:#EAF3DE;--green-100:#C0DD97;--green-200:#97C459;
  --green-400:#639922;--green-600:#3B6D11;--green-800:#27500A;
  --amber-50:#FAEEDA;--amber-400:#BA7517;--amber-600:#854F0B;
  --blue-50:#E6F1FB;--blue-400:#378ADD;--blue-600:#185FA5;
  --red-50:#FCEBEB;--red-400:#E24B4A;
  --text-primary:#1a1a18;--text-secondary:#5a5a58;--text-muted:#8a8a88;
  --bg:#F7F5F0;--bg-white:#fff;
  --border:rgba(0,0,0,0.10);--border-md:rgba(0,0,0,0.18);
  --radius-sm:6px;--radius-md:10px;--radius-lg:16px;
  --shadow-sm:0 1px 3px rgba(0,0,0,.07);--shadow-md:0 4px 16px rgba(0,0,0,.09);
  --season-bg:#F2F7EE;--season-sidebar:#fff;--season-accent:#3B6D11;
}
/* body — layout in inline <style> */

/* TOP BAR */
/* .topbar — layout in inline <style> */
.topbar-spacer{flex:1}
.topbar-brand{font-family:'Lora',serif;font-size:15px;font-weight:600;color:var(--season-accent);display:none}
.topbar-btn{background:none;border:0.5px solid var(--border-md);border-radius:8px;padding:5px 11px;cursor:pointer;font-size:14px;display:flex;align-items:center;gap:5px;font-family:inherit;color:var(--text-secondary);text-decoration:none;white-space:nowrap;transition:background .15s}
.topbar-btn:hover{background:var(--season-bg)}
.topbar-user{font-size:13px;color:var(--text-muted);display:flex;align-items:center;gap:5px}
.support-dot{width:8px;height:8px;background:#E24B4A;border-radius:50%;display:inline-block;flex-shrink:0}
/* .hamburger-btn — in inline <style> */

/* LAYOUT */
/* .layout — layout in inline <style> */
/* .sidebar — layout in inline <style> */
/* .main — layout in inline <style> */

/* SIDEBAR */
.sidebar-logo{font-family:'Lora',serif;font-size:1.15rem;color:var(--season-accent);font-weight:600;padding:1.1rem 1.25rem 1rem;border-bottom:0.5px solid var(--border);line-height:1.3}
.sidebar-logo span{display:block;font-family:'DM Sans',sans-serif;font-size:11px;color:var(--text-muted);font-weight:400;margin-top:2px}
.xp-section{padding:.75rem 1.25rem;border-bottom:0.5px solid var(--border)}
.xp-section-label{font-size:10px;color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em;margin-bottom:4px}
.xp-bar-wrap{height:4px;background:var(--border);border-radius:2px;overflow:hidden;margin-bottom:3px}
.xp-bar-fill{height:100%;background:var(--season-accent);border-radius:2px;transition:width .4s}
.xp-label-row{display:flex;justify-content:space-between;font-size:10px;color:var(--text-muted)}
.xp-label-row strong{color:var(--text-secondary);font-weight:500}
.nav{padding:.5rem 0;flex:1}
.nav-item{display:flex;align-items:center;gap:10px;padding:.58rem 1.25rem;font-size:13.5px;color:var(--text-secondary);text-decoration:none;border-left:3px solid transparent;cursor:pointer;transition:all .15s;background:none;border-top:none;border-right:none;border-bottom:none;width:100%;text-align:left;font-family:inherit;line-height:1.4}
.nav-item:hover{background:var(--green-50);color:var(--season-accent)}
.nav-item.active{background:var(--green-50);color:var(--season-accent);border-left-color:var(--season-accent);font-weight:500}
.nav-icon{width:20px;text-align:center;font-size:15px;flex-shrink:0}
.plan-pill{font-size:9px;padding:1px 6px;border-radius:8px;font-weight:600;vertical-align:middle;margin-left:auto;flex-shrink:0}
.pill-basic{background:var(--green-50);color:var(--green-600)}
.pill-full{background:#E1F5EE;color:#0F6E56}

/* PROFILE DROPDOWN */
.sidebar-profile{border-top:0.5px solid var(--border)}
.profile-trigger{width:100%;display:flex;align-items:center;gap:8px;padding:.75rem 1rem;background:none;border:none;cursor:pointer;text-align:left;font-family:inherit;transition:background .15s}
.profile-trigger:hover{background:var(--season-bg)}
.profile-avatar{width:32px;height:32px;border-radius:50%;background:var(--season-accent);color:#fff;display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:700;flex-shrink:0}
.profile-info{flex:1;min-width:0}
.profile-name{font-size:13px;font-weight:500;color:var(--text-primary);display:flex;align-items:center;gap:4px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.profile-role{display:flex;gap:4px;margin-top:3px;flex-wrap:wrap}
.profile-chevron{font-size:10px;color:var(--text-muted);transition:transform .2s;margin-left:auto;flex-shrink:0}
.profile-trigger[aria-expanded="true"] .profile-chevron{transform:rotate(180deg)}
.profile-menu{border-top:0.5px solid var(--border);background:var(--bg-white)}
.profile-menu-item{display:flex;align-items:center;gap:8px;padding:.55rem 1rem;font-size:13px;color:var(--text-secondary);text-decoration:none;transition:background .15s;cursor:pointer}
.profile-menu-item:hover{background:var(--season-bg);color:var(--season-accent)}
/* .sidebar-overlay — in inline <style> */


/* PAGE TITLE */
.page-title{font-family:'Lora',serif;font-size:1.4rem;color:var(--text-primary);margin-bottom:1.25rem;font-weight:600}
.page-title span{font-family:'DM Sans',sans-serif;font-size:13px;color:var(--text-muted);font-weight:400;display:block;margin-top:3px}

/* COMPONENTS */
.card{background:var(--bg-white);border:0.5px solid var(--border);border-radius:var(--radius-md);padding:1.25rem;margin-bottom:1.25rem}
.card h3{font-size:14px;font-weight:600;margin-bottom:1rem;color:var(--text-primary)}
.section-head{font-size:11px;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.07em;margin-bottom:.75rem}
.tip-bar{border-left:3px solid var(--season-accent);padding:.7rem 1rem;background:var(--green-50);border-radius:0 var(--radius-sm) var(--radius-sm) 0;font-size:13px;color:var(--green-800);margin-bottom:1.25rem}
.tip-bar strong{display:block;font-size:10px;text-transform:uppercase;letter-spacing:.06em;margin-bottom:3px;color:var(--green-600)}
/* .tab-panel rules — in inline <style> with !important */
.locked-tab{position:relative;min-height:300px;overflow:hidden}
.lock-overlay{position:absolute;inset:0;background:rgba(247,245,240,.93);display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;z-index:10;padding:2rem}
.lock-icon{font-size:2.5rem;margin-bottom:.75rem}
.lock-title{font-size:16px;font-weight:600;color:var(--text-primary);margin-bottom:.4rem}
.lock-desc{font-size:13px;color:var(--text-secondary);max-width:340px;line-height:1.6;margin-bottom:1.25rem}
.lock-btn{display:inline-block;padding:.65rem 1.75rem;background:var(--season-accent);color:#fff;border-radius:var(--radius-sm);text-decoration:none;font-size:14px;font-weight:500}
.alert{padding:.7rem 1rem;border-radius:var(--radius-sm);font-size:13px;margin-bottom:1rem}
.alert-success{background:var(--green-50);color:var(--green-600);border:0.5px solid var(--green-100)}
.alert-error{background:var(--red-50);color:#a32d2d;border:0.5px solid #f09595}

/* METRICS */
.metrics{display:grid;grid-template-columns:repeat(auto-fit,minmax(155px,1fr));gap:12px;margin-bottom:1.5rem}
.metric-card{background:var(--bg-white);border:0.5px solid var(--border);border-radius:var(--radius-md);padding:1rem 1.1rem}
.metric-label{font-size:10px;color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em;margin-bottom:6px}
.metric-value{font-size:26px;font-weight:700;color:var(--text-primary);line-height:1}
.metric-sub{font-size:11px;color:var(--text-muted);margin-top:4px}
.stage-card{background:var(--bg-white);border:0.5px solid var(--border);border-radius:var(--radius-md);padding:1.1rem 1.25rem;margin-bottom:1.25rem}
.stage-label{font-size:10px;color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em;margin-bottom:10px}
.stage-steps{display:flex;gap:5px;margin-bottom:8px}
.stage-step{flex:1;height:6px;border-radius:3px;background:var(--border)}
.stage-step.done{background:var(--season-accent)}
.stage-step.active{background:var(--green-200)}
.stage-names{display:flex;justify-content:space-between;font-size:11px;color:var(--text-muted)}
.stage-names .cur{color:var(--season-accent);font-weight:500}
.pillars{display:grid;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:10px;margin-bottom:1.5rem}
.pillar-card{background:var(--bg-white);border:0.5px solid var(--border);border-radius:var(--radius-md);padding:.85rem}
.pillar-name{font-size:12px;font-weight:500;margin-bottom:3px}
.pillar-pct{font-size:11px;color:var(--text-muted);margin-bottom:7px}
.pbar{height:5px;background:var(--border);border-radius:3px;overflow:hidden}
.pbar-fill{height:100%;border-radius:3px;background:var(--season-accent);transition:width .4s}
.pbar-fill.amber{background:var(--amber-400)}
.pbar-fill.blue{background:var(--blue-400)}

/* TASKS */
.task-list{display:flex;flex-direction:column;gap:6px;margin-bottom:1.25rem}
.task-item{display:flex;align-items:flex-start;gap:10px;padding:.7rem 1rem;background:var(--bg-white);border:0.5px solid var(--border);border-radius:var(--radius-sm);cursor:pointer;transition:border-color .2s}
.task-item:hover{border-color:var(--border-md)}
.task-cb{width:18px;height:18px;border:1.5px solid var(--border-md);border-radius:4px;flex-shrink:0;margin-top:2px;display:flex;align-items:center;justify-content:center;transition:all .15s}
.task-cb.checked{background:var(--season-accent);border-color:var(--season-accent)}
.task-cb.checked::after{content:'\2713';color:#fff;font-size:11px;font-weight:700}
.task-title{font-size:13px;line-height:1.4}
.task-title.done{text-decoration:line-through;color:var(--text-muted)}
.task-tag{font-size:10px;padding:2px 7px;border-radius:10px;display:inline-block;margin-top:4px;font-weight:500}
.tag-food{background:var(--green-50);color:var(--green-600)}
.tag-water{background:var(--blue-50);color:var(--blue-600)}
.tag-energy{background:var(--amber-50);color:var(--amber-600)}
.tag-animals,.tag-safety{background:#FBEAF0;color:#72243E}
.tag-finance{background:#E1F5EE;color:#0F6E56}

/* SEASONAL */
.seasonal{display:grid;grid-template-columns:repeat(4,1fr);gap:10px;margin-bottom:1.25rem}
.season-card{border:0.5px solid var(--border);border-radius:var(--radius-sm);padding:.85rem;background:var(--bg-white)}
.season-name{font-size:12px;font-weight:600;margin-bottom:6px;color:var(--season-accent)}
.season-item{font-size:11px;color:var(--text-secondary);padding:2px 0}

/* ANIMALS */
.animal-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(165px,1fr));gap:12px;margin-bottom:1.25rem}
.animal-card{border:0.5px solid var(--border);border-radius:var(--radius-md);padding:1rem;background:var(--bg-white)}
.animal-name{font-size:13px;font-weight:600;margin-bottom:5px}
.animal-desc{font-size:12px;color:var(--text-secondary);line-height:1.5;margin-bottom:6px}
.difficulty{font-size:11px;font-weight:500}
.d-easy{color:var(--green-600)}.d-med{color:var(--amber-600)}.d-hard{color:#A32D2D}

/* WEALTH */
.wealth-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:1.25rem}
.wealth-card{background:var(--bg-white);border:0.5px solid var(--border);border-radius:var(--radius-md);padding:1rem}
.wealth-card h4{font-size:13px;font-weight:600;margin-bottom:.5rem}
.wealth-item{font-size:12px;color:var(--text-secondary);padding:4px 0;border-bottom:0.5px solid var(--border)}
.wealth-item:last-child{border-bottom:none}

/* STATS */
.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:12px}
.stat-input label{display:block;font-size:12px;font-weight:500;color:var(--text-secondary);margin-bottom:4px}
.stat-input input{width:100%;padding:.5rem .75rem;border:0.5px solid var(--border-md);border-radius:var(--radius-sm);font-family:inherit;font-size:14px;background:var(--bg)}
.stat-input input:focus{outline:none;border-color:var(--season-accent)}
.btn-save{padding:.6rem 1.5rem;background:var(--season-accent);color:#fff;border:none;border-radius:var(--radius-sm);font-family:inherit;font-size:14px;font-weight:500;cursor:pointer;margin-top:1rem}
.btn-save:hover{opacity:.9}

/* JOURNAL */
.journal-form textarea{width:100%;min-height:120px;padding:.75rem;border:0.5px solid var(--border-md);border-radius:var(--radius-sm);font-family:inherit;font-size:14px;background:var(--bg);resize:vertical}
.journal-form textarea:focus{outline:none;border-color:var(--season-accent)}
.journal-entry{padding:.85rem 1rem;border-bottom:0.5px solid var(--border)}
.journal-entry:last-child{border-bottom:none}
.journal-entry-title{font-size:14px;font-weight:500;margin-bottom:3px}
.journal-entry-meta{font-size:11px;color:var(--text-muted);margin-bottom:6px}
.journal-entry-body{font-size:13px;color:var(--text-secondary);line-height:1.6}

/* KNOWLEDGE */
.know-grid{display:flex;flex-direction:column;gap:8px}
.know-card{background:var(--bg-white);border:0.5px solid var(--border);border-radius:var(--radius-md);overflow:hidden}
.know-card-head{display:flex;align-items:center;gap:10px;padding:.85rem 1rem;cursor:pointer;transition:background .15s}
.know-card-head:hover{background:var(--green-50)}
.know-icon{font-size:20px;width:36px;height:36px;display:flex;align-items:center;justify-content:center;background:var(--green-50);border-radius:8px;flex-shrink:0}
.know-title{font-size:14px;font-weight:500}
.know-sub{font-size:11px;color:var(--text-muted);margin-top:2px}
.know-toggle{color:var(--text-muted);font-size:18px;margin-left:auto;flex-shrink:0}
.know-body{padding:0 1rem;max-height:0;overflow:hidden;transition:max-height .35s ease,padding .35s;font-size:13px;color:var(--text-secondary);line-height:1.75}
.know-body.open{padding:1rem;max-height:5000px;border-top:0.5px solid var(--border)}
.know-body h4{font-size:11px;font-weight:600;color:var(--season-accent);text-transform:uppercase;letter-spacing:.05em;margin:1rem 0 .4rem}
.know-body h4:first-child{margin-top:0}
.know-body ul{padding-left:1.1rem;margin:.25rem 0 .75rem}
.know-body ul li{margin-bottom:.35rem}
.know-body p{margin-bottom:.6rem}
.know-body table{width:100%;border-collapse:collapse;font-size:12px;margin-bottom:.75rem}
.know-body table th{text-align:left;padding:5px 8px;background:var(--green-50);font-weight:600;color:#27500A;border-bottom:0.5px solid var(--green-100)}
.know-body table td{padding:5px 8px;border-bottom:0.5px solid var(--border);vertical-align:top}
.know-body table tr:last-child td{border-bottom:none}
.companion-table{width:100%;border-collapse:collapse;font-size:12px;margin-bottom:.75rem}
.companion-table th{text-align:left;padding:5px 8px;background:var(--green-50);font-weight:600;color:#27500A;border-bottom:0.5px solid var(--green-100)}
.companion-table td{padding:5px 8px;border-bottom:0.5px solid var(--border);vertical-align:top}
.companion-table tr:last-child td{border-bottom:none}
.c-friend{color:var(--green-600);font-weight:500}
.c-foe{color:#A32D2D}
.know-links{margin-top:1.25rem;padding:1rem;background:var(--season-bg);border:0.5px solid var(--border);border-radius:var(--radius-md)}
.know-links-title{font-size:11px;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em;margin-bottom:.6rem}
.know-link-chip{display:inline-flex;align-items:center;gap:5px;padding:4px 10px;background:var(--bg-white);border:0.5px solid var(--border);border-radius:12px;font-size:12px;color:var(--text-secondary);text-decoration:none;margin:3px;transition:border-color .15s,color .15s}
.know-link-chip:hover{border-color:var(--season-accent);color:var(--season-accent)}

/* QUICK XP */
.quick-xp-strip{margin-bottom:1.25rem}
.quick-xp-head{display:flex;align-items:center;gap:8px;margin-bottom:.6rem}
.quick-xp-head span{font-size:11px;font-weight:600;color:var(--amber-600);text-transform:uppercase;letter-spacing:.05em}
.qxp-today{font-size:11px;color:var(--amber-600);background:var(--amber-50);padding:2px 8px;border-radius:8px;margin-left:auto}
.quick-xp-chips{display:flex;flex-wrap:wrap;gap:6px}
.qxp-chip{display:inline-flex;align-items:center;gap:5px;padding:5px 10px;border:0.5px solid var(--border-md);border-radius:20px;background:var(--bg-white);cursor:pointer;transition:all .15s;font-size:12px;color:var(--text-secondary)}
.qxp-chip:hover{border-color:var(--season-accent);color:var(--season-accent)}
.qxp-chip.done{background:var(--green-50);border-color:var(--season-accent);color:var(--season-accent)}
.qxp-icon{font-size:14px}
.qxp-xp{font-size:10px;color:var(--text-muted);font-weight:500}
.qxp-chip.done .qxp-xp{color:var(--season-accent);font-weight:700}

/* PERSONAL XP TAB */
.xp-hero{background:var(--bg-white);border:0.5px solid var(--border);border-radius:var(--radius-lg);padding:1.1rem;margin-bottom:1.25rem;display:grid;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:12px}
.xp-stat{text-align:center;padding:.4rem}
.xp-stat-val{font-size:1.9rem;font-weight:700;color:var(--text-primary);line-height:1}
.xp-stat-val.amber{color:var(--amber-400)}
.xp-stat-val.green{color:var(--season-accent)}
.xp-stat-label{font-size:11px;color:var(--text-muted);margin-top:4px;text-transform:uppercase;letter-spacing:.05em}
.xp-level-card{background:var(--bg-white);border:0.5px solid var(--border);border-radius:var(--radius-lg);padding:1.1rem;margin-bottom:1.25rem}
.xp-level-name{font-size:1.15rem;font-weight:600;margin-bottom:.2rem}
.xp-level-sub{font-size:12px;color:var(--text-muted);margin-bottom:.75rem}
.xp-prog-track{height:10px;background:var(--border);border-radius:5px;overflow:hidden;margin-bottom:6px}
.xp-prog-fill{height:100%;background:var(--season-accent);border-radius:5px;transition:width .5s}
.xp-milestone-row{display:flex;justify-content:space-between;font-size:11px;color:var(--text-muted)}
.cat-section{margin-bottom:1.5rem}
.cat-header{display:flex;align-items:center;gap:8px;margin-bottom:.75rem}
.cat-icon{font-size:18px}
.cat-name{font-size:13px;font-weight:600}
.cat-earned{font-size:11px;color:var(--amber-600);background:var(--amber-50);padding:2px 8px;border-radius:8px;margin-left:auto}
.daily-task{display:flex;align-items:center;gap:10px;padding:.65rem .85rem;background:var(--bg-white);border:0.5px solid var(--border);border-radius:var(--radius-sm);margin-bottom:6px;cursor:pointer;transition:border-color .15s}
.daily-task:hover{border-color:var(--border-md)}
.daily-task.earned{border-color:var(--season-accent);background:var(--green-50)}
.daily-task-icon{font-size:18px;width:28px;text-align:center;flex-shrink:0}
.daily-task-body{flex:1;min-width:0}
.daily-task-name{font-size:13px;font-weight:500;line-height:1.3}
.daily-task-name.done{color:var(--text-muted);text-decoration:line-through}
.daily-task-desc{font-size:11px;color:var(--text-muted);margin-top:2px}
.xp-pill{font-size:10px;font-weight:700;padding:2px 8px;border-radius:8px;white-space:nowrap;flex-shrink:0}
.xp-pill.pending{background:var(--bg);color:var(--text-muted)}
.xp-pill.earned{background:var(--green-50);color:var(--green-600)}
.xp-check{width:20px;height:20px;border:1.5px solid var(--border-md);border-radius:50%;flex-shrink:0;display:flex;align-items:center;justify-content:center;transition:all .15s;font-size:11px}
.xp-check.done{background:var(--season-accent);border-color:var(--season-accent);color:#fff}
.history-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:6px;margin-bottom:1.25rem}
.history-day{text-align:center;padding:.5rem .25rem;background:var(--bg-white);border:0.5px solid var(--border);border-radius:var(--radius-sm)}
.history-day.active{border-color:var(--season-accent);background:var(--green-50)}
.history-day .hd-name{font-size:10px;color:var(--text-muted);margin-bottom:3px}
.history-day .hd-xp{font-size:13px;font-weight:600;color:var(--text-primary)}
.history-day.active .hd-xp{color:var(--season-accent)}
.history-day .hd-tasks{font-size:10px;color:var(--text-muted)}
.streak-badge{display:inline-flex;align-items:center;gap:6px;background:var(--amber-50);border:0.5px solid #FAC775;border-radius:20px;padding:4px 12px;font-size:13px;font-weight:500;color:var(--amber-600);margin-bottom:1.25rem}

/* SAFETY */
.safety-score-card{background:var(--bg-white);border:0.5px solid var(--border);border-radius:var(--radius-lg);padding:1.25rem;margin-bottom:1.25rem;display:flex;align-items:center;gap:1.5rem}
.safety-score-ring{width:80px;height:80px;flex-shrink:0;position:relative}
.safety-score-ring svg{transform:rotate(-90deg)}
.safety-score-num{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;font-size:20px;font-weight:700;color:var(--season-accent)}
.safety-level{font-size:14px;font-weight:600;color:var(--text-primary)}
.safety-level-sub{font-size:12px;color:var(--text-muted);margin-top:2px}

/* WEATHER */
.weather-card{background:var(--bg-white);border:0.5px solid var(--border);border-radius:var(--radius-lg);padding:1.25rem;margin-bottom:1.25rem}
.weather-top{display:flex;align-items:center;gap:1.5rem;margin-bottom:1rem}
.weather-icon{font-size:3.5rem;line-height:1}
.weather-temp{font-size:2.5rem;font-weight:300;line-height:1}
.weather-desc{font-size:14px;color:var(--text-secondary);margin-top:4px}
.weather-loc{font-size:12px;color:var(--text-muted);margin-top:2px}
.weather-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(90px,1fr));gap:8px;border-top:0.5px solid var(--border);padding-top:1rem}
.w-stat label{display:block;font-size:10px;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;margin-bottom:3px}
.w-stat span{font-size:14px;font-weight:500}
.weather-loading{text-align:center;padding:3rem;color:var(--text-muted)}
.forecast-row{display:grid;grid-template-columns:repeat(7,1fr);gap:8px;margin-bottom:1.25rem}
.forecast-day{background:var(--bg-white);border:0.5px solid var(--border);border-radius:var(--radius-sm);padding:.6rem .4rem;text-align:center}
.fd-name{font-size:10px;color:var(--text-muted);margin-bottom:4px}
.fd-icon{font-size:1.25rem;margin-bottom:4px}
.fd-hi{font-size:13px;font-weight:600}
.fd-lo{font-size:11px;color:var(--text-muted)}
.season-advice-box{background:var(--bg-white);border:0.5px solid var(--border);border-radius:var(--radius-md);padding:1rem;margin-bottom:1.25rem}
.season-advice-title{font-size:14px;font-weight:600;margin-bottom:.75rem;color:var(--text-primary)}
.season-task{font-size:13px;color:var(--text-secondary);padding:5px 0;border-bottom:0.5px solid var(--border)}
.season-task:last-child{border-bottom:none}
.city-search{display:flex;gap:8px;margin-top:.75rem}
.city-search input{flex:1;padding:.55rem .85rem;border:0.5px solid var(--border-md);border-radius:var(--radius-sm);font-family:inherit;font-size:14px}

/* SUPPORT POPUP */
.support-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,.45);z-index:200;align-items:center;justify-content:center}
.support-overlay.open{display:flex}
.support-popup{background:var(--bg-white);border-radius:var(--radius-lg);padding:1.5rem;width:480px;max-width:95vw;box-shadow:0 8px 32px rgba(0,0,0,.2);position:relative}
.support-popup h2{font-size:15px;font-weight:600;margin-bottom:1rem;padding-bottom:.75rem;border-bottom:0.5px solid var(--border)}
.sp-close{position:absolute;top:.85rem;right:.85rem;background:none;border:none;font-size:22px;cursor:pointer;color:var(--text-muted);line-height:1}
.sp-row{margin-bottom:.75rem}
.sp-row label{display:block;font-size:11px;font-weight:500;color:var(--text-secondary);margin-bottom:4px}
.sp-row input,.sp-row textarea{width:100%;padding:.5rem .75rem;border:0.5px solid var(--border-md);border-radius:6px;font-family:inherit;font-size:13px;box-sizing:border-box;background:var(--bg)}
.sp-row textarea{min-height:100px;resize:vertical}
.sp-submit{width:100%;padding:.65rem;background:var(--season-accent);color:#fff;border:none;border-radius:6px;font-family:inherit;font-size:14px;font-weight:500;cursor:pointer;margin-top:.5rem}
.sp-success{background:var(--green-50);color:var(--green-600);border-radius:6px;padding:.65rem;font-size:13px;text-align:center;margin-top:.5rem;display:none}
.sp-error{background:var(--red-50);color:#A32D2D;border-radius:6px;padding:.65rem;font-size:13px;margin-top:.5rem;display:none}
.contrib-section{margin-top:1.5rem;border-top:0.5px solid var(--border);padding-top:1.25rem}
.contrib-section summary{cursor:pointer;font-size:13px;font-weight:500;color:var(--season-accent);list-style:none}
.contrib-section summary::-webkit-details-marker{display:none}

/* AUTH */
.auth-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--season-bg);padding:2rem 1rem}
.auth-card{background:var(--bg-white);border:0.5px solid var(--border);border-radius:var(--radius-lg);padding:2.5rem 2rem;width:100%;max-width:420px;box-shadow:var(--shadow-md)}
.auth-logo{font-family:'Lora',serif;font-size:1.6rem;color:var(--green-600);font-weight:600;text-align:center;margin-bottom:.25rem}
.auth-tagline{text-align:center;font-size:13px;color:var(--text-muted);margin-bottom:2rem}
.form-group{margin-bottom:1.1rem}
.form-group label{display:block;font-size:13px;font-weight:500;color:var(--text-secondary);margin-bottom:5px}
.form-group input,.form-group select{width:100%;padding:.6rem .85rem;border:0.5px solid var(--border-md);border-radius:var(--radius-sm);font-family:inherit;font-size:14px;background:var(--bg);color:var(--text-primary)}
.form-group input:focus,.form-group select:focus{outline:none;border-color:var(--season-accent);background:#fff}
.btn-primary{width:100%;padding:.75rem;background:var(--season-accent);color:#fff;border:none;border-radius:var(--radius-sm);font-family:inherit;font-size:15px;font-weight:500;cursor:pointer;margin-top:.5rem}
.btn-primary:hover{opacity:.9}
.auth-switch{text-align:center;font-size:13px;color:var(--text-muted);margin-top:1.25rem}
.auth-switch a{color:var(--season-accent);text-decoration:none;font-weight:500}

/* TOGGLE SWITCH */
.toggle-switch{position:relative;display:inline-block;width:36px;height:20px}
.toggle-switch input{opacity:0;width:0;height:0}
.ts-slider{position:absolute;inset:0;background:var(--border-md);border-radius:20px;transition:background .2s;cursor:pointer}
.ts-slider::before{content:'';position:absolute;width:14px;height:14px;left:3px;top:3px;background:#fff;border-radius:50%;transition:transform .2s}
.toggle-switch input:checked+.ts-slider{background:var(--season-accent)}
.toggle-switch input:checked+.ts-slider::before{transform:translateX(16px)}
.toggle-label{font-size:12px;color:var(--text-secondary)}
.back-link{display:inline-flex;align-items:center;gap:5px;font-size:13px;color:var(--text-muted);text-decoration:none;margin-bottom:1rem}
.back-link:hover{color:var(--season-accent)}

/* DARK MODE */
[data-theme="dark"]{
  --text-primary:#e8e6e0;--text-secondary:#b8b6b0;--text-muted:#808078;
  --bg:#1a1a18;--bg-white:#252523;
  --border:rgba(255,255,255,0.08);--border-md:rgba(255,255,255,0.14);
}
[data-theme="dark"] body{background:#1a1a18!important}
[data-theme="dark"] .sidebar{background:#1f1f1d!important}
[data-theme="dark"] .topbar{background:#1f1f1d!important;border-color:rgba(255,255,255,.08)!important}
[data-theme="dark"] .profile-menu{background:#1f1f1d!important}
[data-theme="dark"] .profile-trigger:hover,[data-theme="dark"] .nav-item:hover,[data-theme="dark"] .profile-menu-item:hover,[data-theme="dark"] .know-card-head:hover{background:#2e2e2c!important}
[data-theme="dark"] .nav-item.active{background:#2e2e2c!important}
[data-theme="dark"] .lock-overlay{background:rgba(26,26,24,.93)!important}
[data-theme="dark"] .tip-bar{background:#252523!important;color:#c8c6c0!important}
[data-theme="dark"] .know-body,[data-theme="dark"] .support-popup,[data-theme="dark"] .season-advice-box,[data-theme="dark"] .know-links{background:#252523!important}
[data-theme="dark"] .companion-table th,.know-body table th{background:#2e2e2c!important}
[data-theme="dark"] .daily-task.earned,[data-theme="dark"] .qxp-chip.done{background:#1e2e18!important}
[data-theme="dark"] input,[data-theme="dark"] select,[data-theme="dark"] textarea{background:#252523!important;color:#e8e6e0!important;border-color:rgba(255,255,255,.14)!important}

/* RESPONSIVE */
@media(max-width:768px){
  .sidebar{transform:translateX(-100%);top:0;height:100vh;z-index:100}
  .sidebar.open{transform:translateX(0)!important}
  .topbar-brand{display:block!important}
  .hamburger-btn{display:flex!important}
  .main{margin-left:0!important;padding:.85rem}
  .seasonal,.wealth-grid{grid-template-columns:1fr 1fr}
  .forecast-row{grid-template-columns:repeat(4,1fr)}
  .metrics{grid-template-columns:repeat(2,1fr)}
  .animal-grid{grid-template-columns:1fr 1fr}
  .history-grid{grid-template-columns:repeat(4,1fr)}
  .xp-hero{grid-template-columns:repeat(2,1fr)}
  .support-popup{width:100%;max-width:100%;border-radius:var(--radius-lg) var(--radius-lg) 0 0}
  .support-overlay{align-items:flex-end}
  .pillars{grid-template-columns:repeat(3,1fr)}
  .wealth-grid{grid-template-columns:1fr}
}
@media(max-width:480px){
  .metrics{grid-template-columns:1fr}
  .pillars{grid-template-columns:1fr 1fr}
  .animal-grid{grid-template-columns:1fr}
}

/* ── LAYOUT OVERRIDE: main content area (also in inline <style>) ── */
/* These !important rules override any cached old CSS */
body > .main,main.main,.main{
  position:fixed!important;
  top:48px!important;
  left:220px!important;
  right:0!important;
  bottom:0!important;
  margin:0!important;
  margin-left:0!important;
}
@media(max-width:768px){
  body > .main,main.main,.main{left:0!important}
}
/* ── SIDEBAR OVERRIDE ── */
body > nav.sidebar,.sidebar{
  width:220px!important;
  position:fixed!important;
  top:48px!important;
  left:0!important;
  margin:0!important;
}
