/* DB Ozone RHBA — Resident Portal.
   Royal, light, accessible theme.
   - regal jewel tones: deep royal indigo + rich gold, on a soft pearl background
   - near-black indigo text on white cards (WCAG AAA contrast)
   - status is always shown by a TEXT LABEL, never colour alone (colour-blind safe)
   - 17px base type, generous spacing, clear focus rings (older / low-vision readers)
   Every page is themed through these tokens. */
:root{
  /* surfaces */
  --ground:#F7F3E9;      /* royal cream — warm ivory backdrop */
  --ground-2:#EFE8D6;
  --panel:#FFFFFF;       /* cards / surfaces */
  --panel-2:#EDEFF9;     /* inputs, chips, insets */
  --panel-line:#D3D8EC;  /* borders */
  --hover:#EEF0FC;       /* row / header hover */
  /* text */
  --text:#191D38;        /* primary — deep indigo-ink, ~15:1 on white (AAA) */
  --text-2:#3A4063;      /* secondary body — ~9:1 (AAA) */
  --muted:#5B628A;       /* captions / labels — ~4.8:1 (AA) */
  --on-accent:#FFFFFF;
  /* royal brand + jewel-tone status (all AA on white; paired with text labels) */
  --accent:#2A3C8F;      /* royal indigo — links, buttons, nav, headings, focus */
  --accent-strong:#1E2C72;
  --accent-soft:#EBEEFA; /* tinted indigo wash */
  --gold:#9A7400;        /* rich gold — Open status, warm highlights (AA text) */
  --gold-bright:#C7A327; /* decorative gold — logo ring, rules, stars */
  --blue:#1C63A8;        /* sapphire — info / in-progress */
  --green:#16704A;       /* emerald — success / approved / resolved */
  --coral:#B0303F;       /* deep crimson — error / rejected / reopened */
  --violet:#5B3E9E;      /* royal purple */
  --star-off:#C8CCE2;
  /* type */
  --serif:Georgia,"Times New Roman",serif;
  --sans:system-ui,-apple-system,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;
  --mono:ui-monospace,"SF Mono",Consolas,"Courier New",monospace;
  /* metrics */
  --maxw:980px;
  --radius:14px;
  --shadow:0 1px 2px rgba(25,29,56,.06), 0 10px 28px rgba(25,29,56,.10);
  --shadow-sm:0 1px 3px rgba(25,29,56,.10);
}
*{box-sizing:border-box}
html{-webkit-text-size-adjust:100%}
body{margin:0;background:var(--ground);color:var(--text);font-family:var(--sans);font-size:17px;line-height:1.65;
  -webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;overflow-x:hidden}
img{max-width:100%;height:auto}
a{color:var(--accent);text-decoration:none;font-weight:600}
a:hover{text-decoration:underline}
:focus-visible{outline:3px solid var(--accent);outline-offset:2px;border-radius:5px}

/* ---- Header + nav ---- */
.top{display:flex;align-items:center;gap:14px;max-width:var(--maxw);margin:0 auto;padding:18px 22px;border-bottom:2px solid var(--gold-bright)}
.top .logo{width:48px;height:48px;border-radius:50%;box-shadow:0 0 0 2px var(--gold-bright);flex-shrink:0;background:#fff}
.top .brand{flex:1;min-width:0}
.top .ttl{font-family:var(--serif);font-weight:700;font-size:21px;letter-spacing:.2px;color:var(--text)}
.top .sub{font-family:var(--mono);font-size:10.5px;letter-spacing:2.5px;text-transform:uppercase;color:var(--gold);font-weight:700}
.top .acct{display:flex;align-items:center;gap:10px;flex-shrink:0}
.top .acct .who{font-size:14px;color:var(--text-2);max-width:140px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-weight:600}
.top .logout{background:#fff;border:1px solid var(--panel-line);color:var(--text-2);border-radius:22px;padding:8px 14px;font-family:var(--sans);font-size:13px;font-weight:600;cursor:pointer;transition:border-color .15s,color .15s}
.top .logout:hover{border-color:var(--accent);color:var(--accent)}
.top .login-link{font-family:var(--sans);font-size:13px;font-weight:700;color:var(--on-accent);background:var(--accent);padding:9px 16px;border-radius:22px;flex-shrink:0;box-shadow:var(--shadow-sm)}
.top .login-link:hover{text-decoration:none;background:var(--accent-strong)}
.nav{max-width:var(--maxw);margin:0 auto;padding:14px 22px 0;display:flex;flex-wrap:wrap;gap:8px}
.nav a{font-family:var(--sans);font-size:13.5px;font-weight:600;color:var(--text-2);border:1px solid var(--panel-line);background:#fff;padding:9px 15px;border-radius:22px;transition:all .15s}
.nav a:hover{color:var(--accent);border-color:var(--accent);text-decoration:none}
.nav a.active{color:var(--on-accent);background:var(--accent);border-color:var(--accent);box-shadow:var(--shadow-sm)}

/* ---- Page shell ---- */
.wrap{max-width:var(--maxw);margin:0 auto;padding:28px 22px 88px}
h1{font-family:var(--serif);font-size:31px;color:var(--accent);margin:6px 0 6px;letter-spacing:.2px;line-height:1.2}
.lead{color:var(--muted);margin:0 0 24px;max-width:64ch;font-size:16px}

/* ---- Cards ---- */
.card{background:var(--panel);border:1px solid var(--panel-line);border-left:4px solid var(--accent);border-radius:var(--radius);padding:18px 20px;margin-bottom:14px;box-shadow:var(--shadow);overflow-wrap:break-word}
.card h3{font-family:var(--serif);margin:0 0 4px;font-size:20px;color:var(--text)}
.card .meta{font-family:var(--mono);font-size:11.5px;letter-spacing:1px;color:var(--accent);text-transform:uppercase;margin-bottom:10px;font-weight:700}
.card .body{font-size:16px;color:var(--text-2)}
.card .body :is(h1,h2,h3){color:var(--text);font-family:var(--serif)}
.card .body img{max-width:100%;height:auto;border-radius:8px}
.state{padding:46px 10px;text-align:center;color:var(--muted)}
.err{color:var(--coral)}

/* ---- Buttons (min 44px target) ---- */
.btn{display:inline-block;background:var(--accent);color:var(--on-accent);border:none;border-radius:10px;padding:13px 22px;font-weight:700;font-family:var(--sans);font-size:15.5px;cursor:pointer;box-shadow:var(--shadow-sm);transition:background .15s}
.btn:hover{background:var(--accent-strong);text-decoration:none}
.btn[disabled]{opacity:.55;cursor:not-allowed;background:var(--accent)}
.btn.ghost{background:#fff;border:1px solid var(--panel-line);color:var(--accent)}
.btn.ghost:hover{border-color:var(--accent);background:var(--hover)}

/* ---- Forms ---- */
.field{margin-bottom:15px}
.field label{display:block;font-family:var(--sans);font-size:13px;font-weight:700;letter-spacing:.2px;color:var(--text);margin-bottom:6px}
.field input,.field select,.field textarea{width:100%;background:#fff;border:1.5px solid var(--panel-line);border-radius:10px;color:var(--text);font-family:var(--sans);font-size:16px;padding:12px 14px;transition:border-color .15s,box-shadow .15s}
.field input::placeholder,.field textarea::placeholder{color:var(--muted)}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px rgba(42,60,143,.18)}
.field textarea{min-height:100px;resize:vertical}
.field .hint{font-size:13px;color:var(--muted);margin-top:5px}
.search input{font-size:16px}

/* ---- Messages ---- */
.msg{border-radius:10px;padding:12px 15px;font-size:15px;margin:12px 0;border:1px solid;font-weight:500}
.msg.ok{background:#E4F2EB;border-color:var(--green);color:#0C5538}
.msg.bad{background:#FaEAEC;border-color:var(--coral);color:#86232F}
.msg.info{background:var(--accent-soft);border-color:var(--accent);color:var(--accent-strong)}

/* ---- Layout helpers ---- */
.row{display:flex;gap:12px;flex-wrap:wrap}
.row>.field{flex:1;min-width:150px}
.narrow{max-width:480px}
.badge{display:inline-block;font-family:var(--sans);font-size:11.5px;font-weight:700;letter-spacing:.3px;text-transform:uppercase;padding:3px 10px;border-radius:20px;border:1px solid var(--panel-line);color:var(--muted)}
.badge.role{background:#FBF1D6;color:#6E5200;border-color:#D9BE66}

/* ---- Collapsible grouped lists ---- */
.grp{border:1px solid var(--panel-line);border-radius:var(--radius);margin-bottom:12px;overflow:hidden;background:var(--panel);box-shadow:var(--shadow-sm)}
.grp-head{display:flex;justify-content:space-between;align-items:center;gap:8px;padding:15px 18px;cursor:pointer;font-family:var(--serif);font-size:18px;color:var(--text);user-select:none;transition:background .15s}
.grp-head:hover{background:var(--hover)}
.grp-head .cnt{display:inline-block;background:var(--accent-soft);border:1px solid var(--panel-line);color:var(--accent);border-radius:20px;padding:1px 10px;font-family:var(--sans);font-size:12.5px;font-weight:700;margin-left:8px}
.grp-head .chev{transition:transform .18s;color:var(--accent);font-size:14px}
.grp.open>.grp-head .chev{transform:rotate(90deg)}
.grp-body{display:none}
.grp.open>.grp-body{display:block}
.grp .grp{border:none;border-top:1px solid var(--panel-line);border-radius:0;margin:0;background:transparent;box-shadow:none}
.grp .grp .grp-head{font-size:15.5px;padding:12px 18px 12px 30px;color:var(--text);font-family:var(--sans);font-weight:700}
.entry{display:flex;justify-content:space-between;align-items:center;gap:12px;padding:13px 18px;border-top:1px solid var(--panel-line)}
.entry:hover{background:var(--hover)}
.entry .who{color:var(--text);font-weight:700}
.entry .e-meta{font-size:14px;color:var(--muted);margin-top:2px}
.entry .e-detail{font-size:14px;color:var(--text-2);margin-top:4px}
.badge2{display:inline-block;font-size:11px;font-weight:700;letter-spacing:.3px;text-transform:uppercase;background:#E4F2EB;color:#0C5538;border:1px solid var(--green);border-radius:20px;padding:1px 9px;margin-left:6px;vertical-align:middle}
.pill2{display:inline-block;font-size:12px;font-weight:600;color:var(--muted);background:var(--panel-2);border:1px solid var(--panel-line);border-radius:20px;padding:1px 9px;margin-left:6px;vertical-align:middle}
.call{flex-shrink:0;background:#fff;border:1.5px solid var(--accent);color:var(--accent);border-radius:9px;padding:9px 14px;font-size:14px;font-weight:700;white-space:nowrap;transition:background .15s}
.call:hover{background:var(--hover);text-decoration:none}
.sm-entry{display:block;padding:14px 18px;border-top:1px solid var(--panel-line)}
.sm-entry .top{display:flex;justify-content:space-between;align-items:flex-start;gap:12px}
.stars{display:inline-flex;gap:2px;font-size:18px;line-height:1;color:var(--star-off)}
.stars .on{color:var(--gold-bright)}
.stars.interactive .s{cursor:pointer;transition:transform .1s}
.stars.interactive .s:hover{transform:scale(1.18)}
.sm-avg{font-size:14px;color:var(--muted);margin-top:6px;display:flex;align-items:center;gap:7px;flex-wrap:wrap}
.sm-rate{margin-top:8px;font-size:13.5px;color:var(--muted);display:flex;align-items:center;gap:8px;flex-wrap:wrap}

/* ---- Modal ---- */
.modal-ovl{position:fixed;inset:0;background:rgba(20,24,48,.50);display:flex;align-items:center;justify-content:center;padding:18px;z-index:1000}
.modal-card{background:var(--panel);border:1px solid var(--panel-line);border-top:4px solid var(--gold-bright);border-radius:16px;max-width:430px;width:100%;padding:26px 24px;position:relative;box-shadow:0 26px 64px rgba(20,24,48,.34)}
.modal-card h3{font-family:var(--serif);color:var(--accent);font-size:23px;margin:0 0 4px}
.modal-card .lead-sm{color:var(--muted);font-size:15px;margin:0 0 14px}
.modal-card .x{position:absolute;top:10px;right:14px;background:none;border:none;color:var(--muted);font-size:28px;line-height:1;cursor:pointer}
.modal-card .x:hover{color:var(--text)}

/* ---- Footer ---- */
.foot{max-width:var(--maxw);margin:0 auto;padding:30px 22px 36px;color:var(--muted);font-size:13px;border-top:1px solid var(--panel-line);text-align:center;position:relative}
.foot::before{content:"";position:absolute;top:-1px;left:50%;transform:translateX(-50%);width:54px;height:3px;border-radius:3px;background:var(--gold-bright)}
.foot .foot-brand{font-family:var(--serif);font-size:15px;color:var(--text);font-weight:700;margin-bottom:6px}
.foot .foot-copy{color:var(--muted);font-size:13px}
.foot .foot-dev{margin-top:8px;font-size:12.5px;color:var(--muted);letter-spacing:.2px}
.foot .foot-dev strong{color:var(--accent);font-weight:700}
.foot .foot-note{margin:10px auto 0;max-width:620px;font-size:11.5px;line-height:1.5;color:var(--muted)}

/* ===========================================================
   Responsive — phone → tablet → laptop → desktop → huge
   =========================================================== */
@media (max-width:600px){
  :root{--maxw:100%}
  body{font-size:16.5px}
  h1{font-size:25px}
  .wrap{padding:20px 15px 64px}
  .top{padding:14px 15px;gap:11px}
  .top .logo{width:42px;height:42px}
  .top .ttl{font-size:18px}
  .top .acct .who{display:none}
  .nav{padding:12px 15px 0;gap:7px}
  .nav a{font-size:13px;padding:8px 13px}
  .card{padding:16px 16px}
  .grp-head{font-size:16.5px;padding:14px 15px}
  .grp .grp .grp-head{padding-left:24px}
  .entry,.sm-entry{padding:13px 15px}
  .entry{flex-wrap:wrap}
  .modal-card{padding:22px 18px}
  .btn{width:100%;text-align:center}
  .btn.ghost,.btn.sm{width:auto}
  .stats{display:grid!important;grid-template-columns:repeat(3,1fr)}
  .stats .stat{min-width:0}
}
@media (min-width:601px) and (max-width:900px){
  :root{--maxw:720px}
}
@media (min-width:1500px){
  :root{--maxw:1120px}
  body{font-size:18px}
  h1{font-size:35px}
  .top .ttl{font-size:23px}
}
@media (min-width:1900px){
  :root{--maxw:1240px}
}
@media (prefers-reduced-motion:reduce){
  *{transition:none!important;scroll-behavior:auto!important}
}
