/* portal.css — NextDay Nanny v2 */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;}
body{font-family:'Plus Jakarta Sans','Segoe UI',system-ui,sans-serif;background:#f3ede4;color:#181a18;-webkit-font-smoothing:antialiased;}
a{color:inherit;text-decoration:none;}
.f{font-family:'Fraunces','Palatino Linotype',Georgia,serif;}
:root{--green:#1b3a2d;--green2:#254d3b;--amber:#d4853a;--amber2:#e89b52;--gold:#e8c170;--paper:#faf7f2;--paper2:#f3ede4;--white:#fff;--muted:#6b7566;--light:#a8b5a2;--border:#e2ddd6;--r:14px;}

/* LAYOUT */
.wrap{display:grid;grid-template-columns:230px 1fr;min-height:100vh;}
.sidebar{background:var(--green);display:flex;flex-direction:column;position:sticky;top:0;height:100vh;overflow-y:auto;}
.s-logo{padding:1.4rem 1.4rem 1rem;border-bottom:1px solid rgba(255,255,255,.08);}
.s-logo-name{font-family:'Fraunces',Georgia,serif;font-size:1.1rem;font-weight:600;color:#fff;letter-spacing:-.01em;}
.s-logo-name span{color:var(--gold);}
.s-role{font-size:.62rem;letter-spacing:.12em;text-transform:uppercase;color:rgba(255,255,255,.3);margin-top:.2rem;}
.s-nav{flex:1;padding:1rem 0;}
.s-section{font-size:.6rem;letter-spacing:.14em;text-transform:uppercase;color:rgba(255,255,255,.28);padding:.55rem 1.4rem .25rem;font-weight:700;}
.s-link{display:flex;align-items:center;gap:.6rem;padding:.65rem 1.4rem;font-size:.83rem;color:rgba(255,255,255,.58);transition:background .15s,color .15s;}
.s-link:hover{background:rgba(255,255,255,.06);color:#fff;}
.s-link.on{background:rgba(232,193,112,.12);color:var(--gold);font-weight:600;}
.s-link svg{width:15px;height:15px;stroke:currentColor;fill:none;stroke-width:2;stroke-linecap:round;flex-shrink:0;}
.s-foot{padding:1rem 1.4rem;border-top:1px solid rgba(255,255,255,.08);}
.s-user{font-size:.78rem;color:rgba(255,255,255,.4);}
.s-user strong{color:rgba(255,255,255,.72);display:block;}
.s-out{display:inline-block;margin-top:.55rem;font-size:.73rem;color:rgba(255,255,255,.3);border:1px solid rgba(255,255,255,.12);border-radius:20px;padding:.28rem .75rem;transition:color .2s,border-color .2s;}
.s-out:hover{color:#fff;border-color:rgba(255,255,255,.38);}

/* CONTENT */
.content{display:flex;flex-direction:column;min-height:100vh;}
.topbar{background:#fff;border-bottom:1px solid var(--border);padding:0 2rem;height:56px;display:flex;align-items:center;justify-content:space-between;position:sticky;top:0;z-index:10;}
.topbar-t{font-family:'Fraunces',Georgia,serif;font-size:1.25rem;font-weight:600;color:var(--green);letter-spacing:-.02em;}
.topbar-r{font-size:.82rem;color:var(--muted);}
.main{padding:1.75rem;flex:1;}

/* STAT CARDS */
.sg{display:grid;grid-template-columns:repeat(auto-fit,minmax(170px,1fr));gap:1rem;margin-bottom:1.75rem;}
.sc{background:#fff;border-radius:var(--r);padding:1.3rem 1.5rem;border:1px solid var(--border);}
.sc-l{font-size:.67rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--light);margin-bottom:.35rem;}
.sc-v{font-family:'Fraunces',Georgia,serif;font-size:2rem;font-weight:600;color:var(--green);line-height:1;}
.sc-s{font-size:.73rem;color:var(--light);margin-top:.2rem;}
.sc.amber .sc-v{color:var(--amber);}
.sc.red .sc-v{color:#dc2626;}

/* TABLE */
.tc{background:#fff;border-radius:var(--r);border:1px solid var(--border);overflow:hidden;margin-bottom:1.25rem;}
.tc-head{padding:1.1rem 1.4rem;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:.6rem;}
.tc-title{font-size:.88rem;font-weight:700;color:var(--green);}
table{width:100%;border-collapse:collapse;}
th{font-size:.65rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--light);padding:.7rem 1.2rem;text-align:left;border-bottom:1px solid var(--border);white-space:nowrap;}
td{font-size:.82rem;color:#2a3a28;padding:.78rem 1.2rem;border-bottom:1px solid #f5f0ea;vertical-align:middle;}
tr:last-child td{border-bottom:none;}
tr:hover td{background:var(--paper);}

/* BADGE */
.badge{display:inline-block;padding:.22rem .6rem;border-radius:20px;font-size:.66rem;font-weight:700;letter-spacing:.04em;text-transform:uppercase;}
.b-pending{background:#fef9ec;color:#b45309;}
.b-paid{background:#e8f5ee;color:#166534;}
.b-broadcast{background:#eff6ff;color:#1d4ed8;}
.b-matched{background:#f0fdf4;color:#15803d;}
.b-completed{background:#f8fafc;color:#475569;}
.b-cancelled{background:#fef2f2;color:#dc2626;}
.b-active{background:#e8f5ee;color:#166534;}
.b-inactive{background:#f8fafc;color:#94a3b8;}
.b-pending-s{background:#fef9ec;color:#b45309;}
.b-offered{background:#eff6ff;color:#1d4ed8;}
.b-accepted{background:#e8f5ee;color:#166534;}
.b-earnings{background:#faf7f2;color:var(--amber);border:1px solid var(--border);}

/* FORMS */
.fc{background:#fff;border-radius:var(--r);border:1px solid var(--border);padding:1.75rem;}
.fg{display:flex;flex-direction:column;gap:.3rem;margin-bottom:.9rem;}
.fg label{font-size:.68rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--muted);}
.fg input,.fg select,.fg textarea{padding:.62rem .85rem;border:1.5px solid var(--border);border-radius:8px;font-family:inherit;font-size:.88rem;color:var(--green);background:#fff;outline:none;transition:border-color .2s;}
.fg input:focus,.fg select:focus,.fg textarea:focus{border-color:var(--green);}
.fr{display:grid;grid-template-columns:1fr 1fr;gap:1rem;}
.btn{display:inline-flex;align-items:center;gap:.4rem;padding:.58rem 1.2rem;border-radius:40px;font-size:.79rem;font-weight:600;border:none;cursor:pointer;transition:background .2s,transform .15s;font-family:inherit;}
.btn:hover{transform:translateY(-1px);}
.btn-p{background:var(--green);color:#fff;}
.btn-p:hover{background:var(--green2);}
.btn-a{background:var(--amber);color:#fff;}
.btn-a:hover{background:var(--amber2);}
.btn-sm{padding:.35rem .85rem;font-size:.73rem;}
.btn-g{background:transparent;color:var(--muted);border:1px solid var(--border);}
.btn-g:hover{color:var(--green);border-color:var(--green);}
.btn-d{background:#fef2f2;color:#dc2626;border:1px solid #fecaca;}
.btn-d:hover{background:#dc2626;color:#fff;}

/* ALERTS */
.alert{padding:.82rem 1.1rem;border-radius:10px;font-size:.84rem;margin-bottom:1rem;border:1px solid;}
.alert-e{background:#fef2f2;color:#dc2626;border-color:#fecaca;}
.alert-s{background:#e8f5ee;color:#166534;border-color:#bbf7d0;}
.alert-i{background:#eff6ff;color:#1d4ed8;border-color:#bfdbfe;}
.alert-w{background:#fef9ec;color:#b45309;border-color:#fed7aa;}

/* EARNINGS CARD */
.earn-card{background:#fff;border:1px solid var(--border);border-radius:var(--r);padding:1.5rem;margin-bottom:1rem;}
.earn-card.highlight{background:var(--green);border-color:var(--green);}
.earn-card.highlight *{color:#fff!important;}
.earn-row{display:flex;justify-content:space-between;align-items:center;padding:.55rem 0;border-bottom:1px solid var(--border);font-size:.85rem;}
.earn-row:last-child{border-bottom:none;}
.earn-label{color:var(--muted);font-weight:500;}
.earn-value{font-weight:700;color:var(--green);}

/* JOB CARD (sitter board) */
.job-card{background:#fff;border:1px solid var(--border);border-radius:var(--r);padding:1.5rem;margin-bottom:1rem;transition:box-shadow .2s,border-color .2s;}
.job-card:hover{box-shadow:0 8px 30px rgba(27,58,45,.1);border-color:#c8d5c0;}
.job-card.featured{border-color:var(--amber);border-width:2px;}
.job-meta{display:flex;flex-wrap:wrap;gap:.45rem 1.4rem;font-size:.82rem;color:var(--muted);margin-top:.5rem;}
.job-meta span{display:flex;align-items:center;gap:.35rem;}
.job-meta svg{width:13px;height:13px;stroke:var(--amber);fill:none;stroke-width:2;stroke-linecap:round;}
.job-pay{font-family:'Fraunces',Georgia,serif;font-size:1.5rem;font-weight:600;color:var(--green);}

/* LOGIN PAGE */
.login-wrap{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--paper2);padding:2rem;}
.login-card{background:#fff;border-radius:20px;padding:2.5rem;width:100%;max-width:400px;box-shadow:0 20px 60px rgba(27,58,45,.1);}
.login-logo{text-align:center;margin-bottom:2rem;}
.login-ico{width:48px;height:48px;background:var(--green);border-radius:50%;display:flex;align-items:center;justify-content:center;margin:0 auto .75rem;}
.login-ico svg{width:22px;height:22px;stroke:var(--gold);fill:none;stroke-width:1.8;stroke-linecap:round;}
.login-t{font-family:'Fraunces',Georgia,serif;font-size:1.6rem;font-weight:600;color:var(--green);letter-spacing:-.02em;}
.login-s{font-size:.82rem;color:var(--muted);margin-top:.25rem;}

/* PROFILE AVATAR */
.avatar{width:72px;height:72px;border-radius:50%;object-fit:cover;border:3px solid var(--border);}
.avatar-lg{width:120px;height:120px;border-radius:50%;object-fit:cover;border:4px solid var(--border);}
.avatar-placeholder{background:var(--paper2);display:flex;align-items:center;justify-content:center;}
.avatar-placeholder svg{stroke:var(--light);}

/* MODAL */
.modal-bg{display:none;position:fixed;inset:0;background:rgba(0,0,0,.5);z-index:999;align-items:center;justify-content:center;padding:1rem;}
.modal-box{background:#fff;border-radius:var(--r);padding:2rem;max-width:480px;width:100%;max-height:90vh;overflow-y:auto;}

/* RATING STARS */
.stars{color:#d4853a;letter-spacing:1px;}
.stars-empty{color:#e2ddd6;letter-spacing:1px;}

/* RESPONSIVE */
@media(max-width:800px){
  .wrap{grid-template-columns:1fr;}
  .sidebar{display:none;}
  .fr{grid-template-columns:1fr;}
  .main{padding:1rem;}
  .sg{grid-template-columns:1fr 1fr;}
}
