/* =============================================================================
   portal.css - Serene customer portal (/app). Reuses the brand tokens
   (/css/tokens.css) + base + components; this file is the portal-specific shell,
   login screen, and preview components. Consumer-facing, so it keeps the normal
   type scale (no --ui-scale knob; that's the dense staff console).
   ============================================================================= */

/* ---- Login (split screen) --------------------------------------------- */
.auth { display: grid; grid-template-columns: 1.05fr 0.95fr; min-height: 100svh; }
.auth__brand { position: relative; background: var(--panel); color: var(--panel-ink); padding: clamp(1.5rem, 4vw, 3rem); display: flex; flex-direction: column; justify-content: space-between; }
.auth__brand .brand__name, .auth__brand .brand__sub { color: var(--panel-ink); }
.auth__brand .pitch { max-width: 24ch; }
.auth__brand .pitch h2 { color: var(--panel-ink); font-size: var(--step-4); line-height: 1.1; }
.auth__brand .pitch p { color: color-mix(in srgb, var(--panel-ink) 82%, transparent); margin-top: var(--space-sm); }
.auth__brand .legal { font-family: var(--font-mono); font-size: .68rem; color: color-mix(in srgb, var(--panel-ink) 65%, transparent); }
.auth__form { display: grid; place-items: center; padding: clamp(1.5rem, 5vw, 3rem); position: relative; }
.auth__card { width: min(380px, 100%); }
.auth__top { position: absolute; top: var(--space-md); right: var(--space-md); }
.field + .field { margin-top: var(--space-md); }
.auth__row { display: flex; align-items: center; justify-content: space-between; margin-top: var(--space-sm); font-size: var(--step--1); }
.auth__or { display: flex; align-items: center; gap: var(--space-sm); margin: var(--space-md) 0; color: var(--text-muted); font-size: var(--step--1); }
.auth__or::before, .auth__or::after { content: ""; flex: 1; height: 1px; background: var(--border); }
.auth__hint { text-align: center; margin-top: var(--space-lg); font-size: var(--step--1); color: var(--text-muted); }
@media (max-width: 760px) { .auth { grid-template-columns: 1fr; } .auth__brand { min-height: 34vh; } }

/* ---- App shell v2: sticky header + tabs (the sidebar is gone) ----------- */
.phead { position: sticky; top: 0; z-index: var(--z-header); background: var(--panel); color: var(--panel-ink); box-shadow: var(--shadow-sm); }
.phead__row { display: flex; align-items: center; justify-content: space-between; padding: var(--space-2xs) var(--container-pad); }
.phead .brand__name, .phead .brand__sub { color: var(--panel-ink); }
.phead__tools { display: flex; align-items: center; gap: var(--space-3xs); }
.phead__btn { color: var(--panel-ink); position: relative; }
.phead__btn:hover { background: color-mix(in srgb, #fff 14%, transparent); color: var(--panel-ink); }
.pbadge { position: absolute; top: 4px; right: 4px; min-width: 16px; height: 16px; padding: 0 4px; border-radius: var(--radius-pill); background: var(--accent); color: var(--accent-ink); font-family: var(--font-mono); font-size: .6rem; font-weight: 700; display: grid; place-items: center; }
.avatar--sm { width: 28px; height: 28px; font-size: .72rem; background: color-mix(in srgb, var(--panel-ink) 18%, transparent); color: var(--panel-ink); }
.ptabs { display: flex; gap: 2px; padding: 0 var(--container-pad); overflow-x: auto; }
.ptabs a { display: inline-flex; align-items: center; gap: 6px; padding: var(--space-2xs) var(--space-sm); color: color-mix(in srgb, var(--panel-ink) 78%, transparent); text-decoration: none; font-weight: 500; font-size: var(--step--1); border-bottom: 2px solid transparent; white-space: nowrap; }
.ptabs a svg { width: 15px; height: 15px; }
.ptabs a:hover { color: var(--panel-ink); }
.ptabs a[aria-current="page"] { color: var(--panel-ink); border-bottom-color: var(--accent); }
.pdrop { position: fixed; top: calc(var(--header-h) - 8px); right: var(--container-pad); z-index: var(--z-overlay); min-width: 260px; max-width: 92vw; background: var(--surface); color: var(--text); border: 1px solid var(--border); border-radius: var(--radius-md); box-shadow: var(--shadow-lg); padding: var(--space-2xs); }
.pdrop__head { font-weight: 700; font-size: var(--step--1); padding: var(--space-2xs) var(--space-sm); border-bottom: 1px solid var(--border); margin-bottom: var(--space-3xs); }
.pdrop__item { display: flex; align-items: center; gap: var(--space-2xs); width: 100%; text-align: left; font: inherit; font-size: var(--step--1); color: var(--text); background: none; border: 0; padding: var(--space-2xs) var(--space-sm); border-radius: var(--radius-sm); text-decoration: none; cursor: pointer; }
.pdrop__item:hover { background: var(--surface-2); }
.pdrop__item--static { cursor: default; }
.pdrop__item--static:hover { background: none; }
.pdrop__item svg { width: 15px; height: 15px; flex-shrink: 0; }
#pview { max-width: 880px; margin: 0 auto; padding: var(--space-lg) var(--container-pad) var(--space-3xl); }
.pv__sub { font-size: var(--step-1); margin: var(--space-lg) 0 var(--space-sm); }
.pgrid3 { display: grid; grid-template-columns: repeat(auto-fit, minmax(200px, 1fr)); gap: var(--space-md); margin-bottom: var(--space-md); }
.pgallery { display: grid; grid-template-columns: repeat(auto-fit, minmax(170px, 1fr)); gap: var(--space-sm); }
.pgal { margin: 0; }
.pgal img { width: 100%; aspect-ratio: 4 / 3; object-fit: cover; border-radius: var(--radius-md); border: 1px solid var(--border); }
.pgal figcaption { font-size: var(--step--1); color: var(--text-muted); margin-top: 4px; }
.psteps { display: grid; gap: var(--space-sm); margin-top: var(--space-2xs); }
.pstep { border-left: 3px solid var(--accent); padding-left: var(--space-sm); }
.pstep strong { display: block; }
.pstep span { font-size: var(--step--1); color: var(--text-muted); }
.pcard--hero { border-color: color-mix(in srgb, var(--accent) 45%, var(--border)); }
.pcard--pitch { border-style: dashed; }
.pfine { font-size: var(--step--1); color: var(--text-muted); margin-top: var(--space-md); }
.pmsg { display: flex; flex-direction: column; margin-bottom: var(--space-sm); }
.pmsg--me { align-items: flex-end; }
.pmsg--office { align-items: flex-start; }
.pmsg__txt { display: inline-block; max-width: 80%; padding: var(--space-2xs) var(--space-sm); border-radius: var(--radius-md); background: var(--primary-tint); }
.pmsg--office .pmsg__txt { background: var(--surface-2); }
.pmsg__at { font-size: var(--step--2); color: var(--text-muted); margin-top: 2px; }

/* the property map (parcel + footprint SVG) */
.tmap { display: block; width: 100%; background: linear-gradient(160deg, color-mix(in srgb, var(--primary) 10%, var(--surface)), var(--surface)); border-radius: var(--radius-md); }
.tmap__parcel { fill: color-mix(in srgb, var(--secondary) 10%, transparent); stroke: var(--primary); stroke-width: 0.8; stroke-dasharray: 2 1.2; }
.tmap__bldg { fill: color-mix(in srgb, var(--primary) 55%, var(--surface)); stroke: var(--primary); stroke-width: 0.5; }
.pcard--map { display: block; padding: var(--space-sm); text-decoration: none; color: inherit; }
.popt { display: flex; flex-wrap: wrap; gap: var(--space-2xs); }
.pchip__n { font-family: var(--font-mono); font-size: .62rem; min-width: 16px; padding: 0 4px; border-radius: var(--radius-pill); background: var(--surface-2); color: var(--text-muted); text-align: center; }
.pchip.is-on .pchip__n { background: var(--primary); color: var(--primary-ink); }
.psug strong { display: block; }

/* ---- App shell v1 (legacy sidebar) -------------------------------------- */
.portal { display: grid; grid-template-columns: 248px 1fr; height: 100svh; overflow: hidden; }
.pside { background: var(--panel); color: var(--panel-ink); padding: var(--space-lg) var(--space-md); display: flex; flex-direction: column; gap: var(--space-md); overflow-y: auto; overscroll-behavior: contain; }
.pside .brand { margin-bottom: var(--space-xs); }
.pside .brand__name, .pside .brand__sub { color: var(--panel-ink); }
.pside nav { display: flex; flex-direction: column; gap: 3px; }
.pside nav a { font: inherit; font-weight: 500; display: flex; align-items: center; gap: var(--space-2xs); padding: var(--space-2xs) var(--space-sm); border-radius: var(--radius-md); color: color-mix(in srgb, var(--panel-ink) 84%, transparent); text-decoration: none; }
.pside nav a svg { width: 1.2em; height: 1.2em; }
.pside nav a:hover { background: color-mix(in srgb, #fff 12%, transparent); color: var(--panel-ink); }
.pside nav a[aria-current="page"] { background: color-mix(in srgb, #fff 18%, transparent); color: var(--panel-ink); }
.pside .spacer { margin-top: auto; }
.pside .theme-toggle { color: var(--panel-ink); align-self: flex-start; }
.pside__who { display: flex; align-items: center; gap: var(--space-sm); padding-top: var(--space-sm); border-top: 1px solid color-mix(in srgb, var(--panel-ink) 20%, transparent); }
.pside__who .avatar { background: color-mix(in srgb, var(--panel-ink) 18%, transparent); color: var(--panel-ink); }
.pside__name { font-size: var(--step--1); font-weight: 600; }
.pside__out { display: inline-flex; align-items: center; gap: 6px; font-size: var(--step--1); color: color-mix(in srgb, var(--panel-ink) 72%, transparent); text-decoration: none; }
.pside__out:hover { color: var(--panel-ink); }
.pside__out svg { width: 14px; height: 14px; }
#pview { min-width: 0; overflow-y: auto; padding: var(--space-xl) clamp(1rem, 4vw, 2.4rem) var(--space-3xl); outline: none; }

@media (max-width: 860px) {
  .portal { grid-template-columns: 1fr; height: auto; overflow: visible; }
  .pside { flex-direction: row; flex-wrap: wrap; align-items: center; gap: var(--space-sm); height: auto; overflow: visible; }
  .pside nav { flex-direction: row; flex-wrap: wrap; }
  .pside .spacer { margin: 0; } .pside__who { border: 0; padding: 0; }
  #pview { overflow: visible; }
}

/* ---- View chrome ------------------------------------------------------- */
.pv__head { max-width: 70ch; margin-bottom: var(--space-lg); }
.pv__head h1 { font-size: var(--step-4); }
.pv__lede { color: var(--text-muted); margin-top: var(--space-2xs); }
.pcard { border: 1px solid var(--border); border-radius: var(--radius-lg); background: var(--surface); box-shadow: var(--shadow-sm); padding: var(--space-lg); margin-bottom: var(--space-md); }
.pcard__lbl { font-family: var(--font-mono); font-size: .62rem; letter-spacing: .08em; text-transform: uppercase; color: var(--text-muted); display: block; margin-bottom: var(--space-xs); }
.pcard__big { font-size: var(--step-4); font-weight: 700; line-height: 1; display: block; }
.pcard__sub { font-size: var(--step--1); color: var(--text-muted); display: block; margin-top: var(--space-2xs); }
.pcard--empty { display: flex; flex-direction: column; align-items: center; text-align: center; gap: var(--space-2xs); padding: var(--space-2xl); color: var(--text-muted); }
.pcard--empty svg { width: 30px; height: 30px; color: var(--text-muted); opacity: .7; }
.pcard--empty strong { color: var(--text); font-size: var(--step-1); }
.pgrid2 { display: grid; grid-template-columns: repeat(auto-fit, minmax(220px, 1fr)); gap: var(--space-md); margin-bottom: var(--space-md); }

/* "coming soon" honesty banner */
/* text is --text, NOT --accent-ink: dark-mode accent-tint is a deep olive and accent-ink is
   near-black - that pairing was the unreadable "brown box with black text". */
.soon { display: flex; gap: var(--space-sm); align-items: flex-start; padding: var(--space-md); border-radius: var(--radius-md); border: 1px dashed color-mix(in srgb, var(--accent) 50%, var(--border)); background: var(--accent-tint); color: var(--text); font-size: var(--step--1); margin-top: var(--space-md); }
.soon svg { width: 16px; height: 16px; flex-shrink: 0; margin-top: 2px; }

/* chips + filter bars */
.pchip { font: inherit; font-size: var(--step--1); display: inline-flex; align-items: center; gap: 5px; padding: 5px 12px; border-radius: var(--radius-pill); border: 1px solid var(--border); background: var(--surface); color: var(--text); cursor: pointer; }
.pchip svg { width: 14px; height: 14px; }
.pchip.is-on { background: var(--primary-tint); color: var(--primary); border-color: color-mix(in srgb, var(--primary) 40%, var(--border)); }
.pchip--alert { color: #C0392B; border-color: color-mix(in srgb, #C0392B 40%, var(--border)); }
.filterbar2 { display: flex; flex-wrap: wrap; gap: var(--space-2xs); margin-bottom: var(--space-md); }

/* the twin (My site) */
.twin { border: 1px solid var(--border); border-radius: var(--radius-lg); overflow: hidden; background: var(--surface); box-shadow: var(--shadow-sm); display: grid; grid-template-columns: 200px 1fr; min-height: 420px; }
.twin__filters { border-right: 1px solid var(--border); padding: var(--space-md); display: flex; flex-direction: column; gap: var(--space-2xs); background: var(--surface-2); }
.twin__flabel { font-family: var(--font-mono); font-size: .6rem; letter-spacing: .08em; text-transform: uppercase; color: var(--text-muted); margin-bottom: var(--space-2xs); }
.twin__filters .pchip { justify-content: flex-start; }
.twin__canvas { display: grid; place-items: center; padding: var(--space-xl); background: linear-gradient(160deg, color-mix(in srgb, var(--primary) 10%, var(--surface)), var(--surface)); position: relative; }
.twin__canvas::before { content: ""; position: absolute; inset: 0; background-image: linear-gradient(color-mix(in srgb, var(--primary) 12%, transparent) 1px, transparent 1px), linear-gradient(90deg, color-mix(in srgb, var(--primary) 12%, transparent) 1px, transparent 1px); background-size: 28px 28px; opacity: .5; }
.twin__placeholder { position: relative; text-align: center; display: flex; flex-direction: column; align-items: center; gap: var(--space-2xs); max-width: 36ch; color: var(--text-muted); }
.twin__placeholder svg { width: 40px; height: 40px; color: var(--primary); }
.twin__placeholder strong { color: var(--text); font-size: var(--step-1); }
@media (max-width: 620px) { .twin { grid-template-columns: 1fr; } .twin__filters { flex-direction: row; flex-wrap: wrap; border-right: 0; border-bottom: 1px solid var(--border); } }

/* systems grid */
.sysgrid { display: grid; grid-template-columns: repeat(auto-fill, minmax(260px, 1fr)); gap: var(--space-md); }
.syscard { display: flex; align-items: center; gap: var(--space-sm); }
.syscard__ico { width: 42px; height: 42px; border-radius: var(--radius-md); background: var(--primary-tint); color: var(--primary); display: grid; place-items: center; flex-shrink: 0; }
.syscard__ico svg { width: 22px; height: 22px; }
.syscard strong { display: block; } .syscard span { font-size: var(--step--1); color: var(--text-muted); }
.syscard__status { margin-left: auto; font-family: var(--font-mono); font-size: .58rem; text-transform: uppercase; letter-spacing: .05em; color: var(--text-muted); display: inline-flex; align-items: center; gap: 5px; white-space: nowrap; }
.syscard__status .dot { width: 8px; height: 8px; border-radius: 50%; background: var(--text-muted); opacity: .5; }

/* misc */
.acct-row { display: flex; justify-content: space-between; align-items: center; gap: var(--space-sm); padding: var(--space-xs) 0; border-bottom: 1px solid var(--border); font-size: var(--step--1); }
.acct-row:last-child { border-bottom: 0; }
.composer { display: flex; gap: var(--space-2xs); margin-top: var(--space-md); }
.composer .input { flex: 1; }
.avatar { width: 34px; height: 34px; border-radius: var(--radius-pill); background: var(--primary-tint); color: var(--primary); display: grid; place-items: center; font-weight: 700; font-size: .85rem; flex-shrink: 0; }

/* claim flow */
.claim-wait { display: flex; align-items: center; gap: 10px; color: var(--text-muted); padding: var(--space-xl) 0; }
.pm-spin { width: 18px; height: 18px; border: 2px solid var(--border); border-top-color: var(--primary); border-radius: 50%; animation: pspin .8s linear infinite; flex-shrink: 0; }
@keyframes pspin { to { transform: rotate(360deg); } }
.codes { display: grid; grid-template-columns: 1fr 1fr; gap: var(--space-2xs); margin: var(--space-md) 0; }
.codes code { font-family: var(--font-mono); font-size: var(--step-0); letter-spacing: .05em; text-align: center; padding: var(--space-xs); background: var(--surface-2); border: 1px solid var(--border); border-radius: var(--radius-sm); }
