/* TKCS Portal — Full-bleed Navy 3-up Card Layout (v1.2.6) */
:root{
  --navy:#0b1e3f;
  --navy-2:#0a1733;
  --text:#ffffff;
  --muted:#b8c6e0;
  --accent:#7c3aed;
  --accent-2:#06b6d4;
  --success:#22c55e;
}
/* Break out of theme container to fill the screen width */
#tkcs-portal{font-family:ui-sans-serif,system-ui,-apple-system,Segoe UI,Roboto,Arial;background:var(--navy); color:var(--text); min-height:100vh; padding:0 20px 40px; width:100vw; margin-left:calc(50% - 50vw); margin-right:calc(50% - 50vw); overflow-x:hidden;}
#tkcs-portal *{box-sizing:border-box}
.portal-hero{background:transparent;color:var(--text);padding:24px;border-radius:20px;margin:18px 0 22px;width:100%;max-width:none;border:1px solid rgba(255,255,255,.18)}
.portal-hero h2{font-size:28px; letter-spacing:.2px; margin:0 0 4px; display:flex; align-items:center; gap:10px}
.portal-hero .verchip{font-size:12px;padding:4px 8px;border-radius:999px;background:rgba(255,255,255,.15)}
.portal-hero .muted{opacity:.95;font-size:14px}
.tabs{display:flex; gap:8px; margin-top:12px}
.tab{background:rgba(255,255,255,.12);color:#fff;padding:8px 12px;border-radius:999px; cursor:pointer; font-weight:700; border:1px solid rgba(255,255,255,.2)}
.tab.active{background:#fff;color:#111827}
.portal-root{width:100%;max-width:none;margin:0}
/* Cards & Controls */
.portal-card{background:var(--navy-2);color:var(--text);border:1px solid rgba(255,255,255,.12);border-radius:18px;padding:20px;margin:16px 0;box-shadow:0 20px 50px -20px rgba(0,0,0,.5)}
.portal-controls{display:flex;gap:12px;align-items:center;flex-wrap:wrap;margin:10px 0 16px}
.badge{font-size:14px;padding:6px 10px;border-radius:999px;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.12);color:var(--text)}
.btn{background:linear-gradient(135deg,var(--accent),var(--accent-2));color:#fff;border:none;border-radius:12px;padding:10px 16px;font-weight:700;cursor:pointer;box-shadow:0 10px 25px -10px rgba(124,58,237,.6)}
.btn:hover{transform:translateY(-1px)}
.btn.ghost{background:transparent;border:1px solid rgba(255,255,255,.25);color:#fff;box-shadow:none}
input[type=text],input[type=number],input[type=date],select,textarea{background:rgba(255,255,255,.08);color:#fff;border:1px solid rgba(255,255,255,.2);border-radius:12px;padding:10px 12px;font-size:18px}
textarea{min-height:88px;width:100%}
.notice{padding:14px 16px;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.12);border-radius:14px;margin:12px 0;font-size:15px;color:#fff}

/* Grid of photo cards */
.hp-grid{display:grid;grid-template-columns:repeat(3,minmax(360px,1fr)); gap:20px; align-items:start}
@media (max-width: 1440px){.hp-grid{grid-template-columns:repeat(2,minmax(320px,1fr))}}
@media (max-width: 820px){.hp-grid{grid-template-columns:1fr}}

.hp-card{position:relative; display:grid; grid-auto-rows:auto; gap:14px;background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.14);border-radius:16px;padding:16px; overflow:hidden}
.hp-card.hp-paid{box-shadow:0 0 0 3px rgba(34,197,94,.35) inset}
.hp-photo{position:relative}
.hp-photo img{display:block;width:100%;height:auto;aspect-ratio:3/4;object-fit:cover;border-radius:12px;background:#061127;image-rendering:auto}
.field{display:flex;flex-direction:column;gap:6px}
.field label{font-size:13px;opacity:.9}
.extras-grid{display:grid;grid-template-columns:1fr auto; gap:8px 10px}
.hp-actions{display:flex;justify-content:flex-end}

/* Totals table */
.portal-table{width:100%;border-collapse:collapse;background:rgba(255,255,255,.03);color:var(--text);border-radius:14px;overflow:hidden}
.portal-table th,.portal-table td{border:1px solid rgba(255,255,255,.12);padding:10px 12px;font-size:14px}
.portal-table thead th{background:rgba(255,255,255,.08)}
