/* Household Hub — stylesheet */
@import url('https://fonts.googleapis.com/css2?family=Fraunces:ital,opsz,wght@0,9..144,400;0,9..144,600;1,9..144,500&family=Outfit:wght@300;400;500;600&display=swap');

:root{
  --bg:#1a1614; --panel:#241f1c; --panel2:#2d2723; --cream:#f4ece0;
  --muted:#9a8e80; --accent:#e07a4f; --accent2:#c9a86a; --green:#7a9b6e;
  --red:#c2675a; --line:#3a322c;
}
*{box-sizing:border-box;margin:0;padding:0;}
body{background:var(--bg);color:var(--cream);font-family:'Outfit',sans-serif;line-height:1.5;
  background-image:radial-gradient(circle at 15% -5%,rgba(224,122,79,.07),transparent 40%),
                   radial-gradient(circle at 95% 105%,rgba(201,168,106,.05),transparent 45%);}
a{color:var(--accent);text-decoration:none;}
a:hover{text-decoration:underline;}
code{font-family:ui-monospace,monospace;background:var(--bg);padding:2px 6px;border-radius:5px;}

/* topbar */
.topbar{display:flex;align-items:center;gap:24px;padding:14px 28px;background:var(--panel);border-bottom:1px solid var(--line);flex-wrap:wrap;}
.brand{font-family:'Fraunces',serif;font-size:21px;font-weight:600;display:flex;align-items:center;gap:9px;}
.logo{color:var(--accent);font-size:24px;}
.topbar nav{display:flex;gap:6px;flex:1;flex-wrap:wrap;}
.topbar nav a{color:var(--muted);padding:7px 13px;border-radius:8px;font-size:15px;}
.topbar nav a:hover{color:var(--cream);background:var(--panel2);text-decoration:none;}
.topbar nav a.on{color:var(--accent);background:var(--panel2);}
.usermenu{display:flex;align-items:center;gap:14px;font-size:14px;color:var(--muted);}
.usermenu a{font-size:14px;}
.usermenu .out{color:var(--muted);}

main{max-width:1080px;margin:0 auto;padding:32px 24px 60px;}
.pagetitle{font-family:'Fraunces',serif;font-weight:600;font-size:32px;margin-bottom:24px;letter-spacing:-.5px;}
.foot{text-align:center;color:var(--muted);font-size:12px;padding:24px;letter-spacing:1px;}
.muted{color:var(--muted);}
h2{font-family:'Fraunces',serif;font-weight:600;font-size:22px;margin-bottom:16px;}
h3{font-size:16px;margin-bottom:10px;}

/* panels & layout */
.panel{background:var(--panel);border:1px solid var(--line);border-radius:18px;padding:24px;margin-bottom:24px;}
.panel.narrow{max-width:480px;margin:0 auto;}
.twocol{display:grid;grid-template-columns:1fr 1fr;gap:24px;}
@media(max-width:780px){.twocol{grid-template-columns:1fr;}}

/* dashboard cards */
.cardgrid{display:grid;grid-template-columns:repeat(2,1fr);gap:20px;}
@media(max-width:620px){.cardgrid{grid-template-columns:1fr;}}
.modcard{background:var(--panel);border:1px solid var(--line);border-radius:18px;padding:26px;display:block;transition:.2s;border-left:4px solid var(--accent2);}
.modcard:hover{transform:translateY(-3px);text-decoration:none;border-color:var(--accent);}
.modcard.meals{border-left-color:var(--accent);}
.modcard.budget{border-left-color:var(--green);}
.modcard.home{border-left-color:var(--accent2);}
.modcard.tasks{border-left-color:#8a7bb0;}
.mc-ico{font-size:30px;display:block;margin-bottom:10px;}
.modcard h3{font-family:'Fraunces',serif;font-size:20px;color:var(--cream);margin-bottom:6px;}
.modcard p{color:var(--muted);font-size:14px;}

/* forms */
label{display:block;font-size:13px;color:var(--muted);margin:14px 0 6px;}
input,textarea,select{width:100%;background:var(--bg);border:1px solid var(--line);border-radius:9px;
  padding:11px 13px;color:var(--cream);font-family:'Outfit';font-size:15px;outline:none;}
input:focus,textarea:focus,select:focus{border-color:var(--accent);}
textarea{resize:vertical;}
button{cursor:pointer;font-family:'Outfit';}
.btn{background:var(--accent);color:#1a1614;border:none;padding:12px 20px;border-radius:10px;font-weight:600;font-size:15px;margin-top:14px;transition:.2s;}
.btn:hover{filter:brightness(1.08);}
.btn.danger{background:none;border:1px solid var(--line);color:var(--red);}
.btn.danger:hover{border-color:var(--red);}
.inline{display:flex;align-items:center;gap:8px;width:auto;}
.inline input{width:auto;}
.addform{margin-top:18px;border-top:1px solid var(--line);padding-top:14px;}
.addform summary{color:var(--accent);cursor:pointer;font-size:14px;list-style:none;}
.addform summary::-webkit-details-marker{display:none;}
.addform form{display:flex;flex-direction:column;gap:10px;margin-top:14px;}
.inlineform{margin:0;}

/* flash */
.flash{padding:11px 15px;border-radius:9px;margin-bottom:16px;font-size:14px;}
.flash.ok{background:rgba(122,155,110,.18);color:#a8c79b;border:1px solid rgba(122,155,110,.3);}
.flash.err{background:rgba(194,103,90,.18);color:#e0a097;border:1px solid rgba(194,103,90,.3);}
.flash.info{background:var(--panel2);color:var(--muted);}

/* auth pages */
.authpage{display:flex;align-items:center;justify-content:center;min-height:100vh;padding:24px;}
.authcard{background:var(--panel);border:1px solid var(--line);border-radius:22px;padding:38px;width:100%;max-width:400px;text-align:center;}
.authlogo{font-size:40px;margin-bottom:12px;}
.authcard h1{font-family:'Fraunces',serif;font-size:26px;font-weight:600;}
.authcard .sub{color:var(--muted);margin:6px 0 22px;font-size:15px;}
.authcard form{text-align:left;}
.authcard label{margin-top:14px;}
.authcard button{width:100%;margin-top:22px;}
.authcard .muted{font-size:12px;margin-top:18px;display:block;}
.authcard .link{display:inline-block;margin-top:8px;}
.codeinput{text-align:center;font-size:26px;letter-spacing:8px;font-family:ui-monospace,monospace;}
.qrwrap{display:flex;justify-content:center;margin:18px 0;background:#fff;padding:12px;border-radius:12px;width:fit-content;margin-left:auto;margin-right:auto;}
.seckey{font-size:15px;letter-spacing:2px;display:inline-block;margin-top:6px;}
.backupgrid{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin:18px 0;}
.backupgrid code{text-align:center;padding:9px;font-size:15px;}

/* meals week */
.weekbar{display:flex;align-items:center;gap:14px;margin-bottom:22px;}
.weekbar h2{margin:0;font-style:italic;}
.navbtn{background:var(--panel);border:1px solid var(--line);color:var(--cream);width:38px;height:38px;border-radius:50%;display:inline-flex;align-items:center;justify-content:center;font-size:18px;}
.navbtn:hover{border-color:var(--accent);color:var(--accent);text-decoration:none;}
.navbtn.today{width:auto;border-radius:100px;padding:0 16px;font-size:13px;margin-left:auto;}
.weekgrid{display:grid;grid-template-columns:repeat(7,1fr);gap:10px;margin-bottom:24px;}
@media(max-width:860px){.weekgrid{grid-template-columns:repeat(2,1fr);}}
@media(max-width:500px){.weekgrid{grid-template-columns:1fr;}}
.daycard{background:var(--panel);border:1px solid var(--line);border-radius:14px;padding:12px;min-height:130px;display:flex;flex-direction:column;}
.dhead{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:10px;}
.dhead span{font-size:11px;text-transform:uppercase;letter-spacing:1px;color:var(--muted);}
.dhead b{font-family:'Fraunces',serif;font-size:20px;}
.meal{background:var(--panel2);border-radius:9px;padding:10px;cursor:pointer;flex:1;border-left:3px solid var(--accent2);}
.meal:hover{background:#352e29;}
.mname{font-family:'Fraunces',serif;font-size:15px;line-height:1.25;}
.msub{font-size:11px;color:var(--muted);margin-top:5px;}
.addbtn{flex:1;background:none;border:1.5px dashed var(--line);border-radius:9px;color:var(--muted);font-size:14px;}
.addbtn:hover{border-color:var(--accent);color:var(--accent);}

/* grocery */
.grocrow{display:flex;align-items:center;gap:12px;padding:10px 4px;border-bottom:1px solid var(--line);margin:0;}
.chk{width:22px;height:22px;border:1.5px solid var(--muted);border-radius:6px;background:none;color:var(--green);font-weight:700;display:flex;align-items:center;justify-content:center;flex:0 0 auto;}
.grocrow.done .chk{background:var(--green);border-color:var(--green);color:#1a1614;}
.gname{flex:1;}
.grocrow.done .gname{text-decoration:line-through;color:var(--muted);}
.gfor{font-size:11px;color:var(--accent2);}

/* modal */
.overlay{position:fixed;inset:0;background:rgba(10,8,7,.72);backdrop-filter:blur(4px);display:flex;align-items:flex-start;justify-content:center;padding:40px 16px;overflow-y:auto;z-index:50;}
.modal{background:var(--panel);border:1px solid var(--line);border-radius:20px;padding:26px;width:100%;max-width:500px;}
.modalactions{margin-top:18px;}

/* tables */
.tbl{width:100%;border-collapse:collapse;font-size:14px;}
.tbl th{text-align:left;color:var(--muted);font-weight:500;font-size:12px;text-transform:uppercase;letter-spacing:.5px;padding:8px 6px;border-bottom:1px solid var(--line);}
.tbl td{padding:10px 6px;border-bottom:1px solid var(--line);}
.tag{background:var(--panel2);color:var(--accent2);font-size:11px;padding:2px 7px;border-radius:20px;margin-left:7px;}
.pos{color:var(--green);}
.neg{color:var(--red);}
.xbtn{background:none;border:none;color:var(--muted);font-size:18px;line-height:1;}
.xbtn:hover{color:var(--red);}

/* stats */
.statrow{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:24px;}
@media(max-width:680px){.statrow{grid-template-columns:repeat(2,1fr);}}
.stat{background:var(--panel);border:1px solid var(--line);border-radius:14px;padding:18px;}
.stat span{font-size:12px;color:var(--muted);text-transform:uppercase;letter-spacing:.5px;}
.stat b{display:block;font-family:'Fraunces',serif;font-size:24px;margin-top:6px;}

/* milestones */
.milestone{background:var(--panel2);border-radius:12px;padding:14px;margin-bottom:12px;border-left:3px solid var(--muted);}
.milestone.st-done{border-left-color:var(--green);opacity:.7;}
.milestone.st-in_progress{border-left-color:var(--accent);}
.milestone.st-blocked{border-left-color:var(--red);}
.mtop{display:flex;justify-content:space-between;align-items:baseline;gap:10px;}
.mdate{font-size:12px;color:var(--accent2);white-space:nowrap;}
.mnotes{font-size:13px;color:var(--muted);margin:6px 0;}
.mrow{display:flex;gap:10px;align-items:center;margin-top:8px;}
.mrow select{width:auto;padding:5px 9px;font-size:13px;}

/* docs */
.doclist{list-style:none;}
.doclist li{display:flex;align-items:center;gap:12px;padding:10px 0;border-bottom:1px solid var(--line);}
.doclist li a{flex:1;}

/* task board */
.board{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;}
@media(max-width:680px){.board{grid-template-columns:1fr;}}
.boardcol h3{font-size:13px;text-transform:uppercase;letter-spacing:.5px;color:var(--muted);margin-bottom:12px;}
.count{background:var(--panel2);padding:1px 8px;border-radius:20px;font-size:12px;margin-left:4px;}
.task{background:var(--panel2);border-radius:10px;padding:12px;margin-bottom:10px;}
.ttitle{font-size:14px;margin-bottom:8px;}
.tmeta{display:flex;gap:6px;flex-wrap:wrap;margin-bottom:8px;}
.tmeta span{font-size:11px;padding:2px 7px;border-radius:20px;background:var(--bg);color:var(--muted);}
.who{color:var(--accent2)!important;}
.tactions{display:flex;gap:6px;align-items:center;flex-wrap:wrap;}
.mini{background:var(--bg);border:1px solid var(--line);color:var(--muted);font-size:11px;padding:3px 8px;border-radius:6px;}
.mini:hover{color:var(--accent);border-color:var(--accent);}

/* notes */
.notegrid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:14px;}
.note{background:var(--panel2);border-radius:12px;padding:14px;position:relative;}
.note h4{font-family:'Fraunces',serif;font-size:16px;margin-bottom:8px;padding-right:20px;}
.note p{font-size:13px;color:var(--cream);}
.note .xbtn{position:absolute;top:8px;right:10px;}
