*{box-sizing:border-box}
body{margin:0;font-family:"Segoe UI",system-ui,sans-serif;background:#f3f5f8;color:#171717}
.container{width:min(1180px,calc(100% - 32px));margin:0 auto}
.app-header{background:#10243e;color:#fff;padding:18px 0;margin-bottom:28px;box-shadow:0 8px 24px rgba(16,36,62,.12)}
.app-header-row{display:flex;align-items:center;justify-content:space-between;gap:16px}
.app-nav{display:flex;align-items:center;gap:8px}
.app-user{font-size:.95rem}
.card{background:#fff;border:1px solid #d9dde3;border-radius:18px;padding:24px;box-shadow:0 10px 30px rgba(16,36,62,.05)}
.card.narrow{width:min(460px,100%)}
.auth-card{margin:56px auto}
.page-head{display:flex;justify-content:space-between;align-items:flex-end;gap:16px;margin-bottom:16px}
.page-head h1{margin:0 0 6px}
.page-head p{margin:0;color:#55606e}
.grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:16px}
.two-col{display:grid;grid-template-columns:minmax(320px,420px) minmax(0,1fr);gap:16px}
.youth-layout{margin-bottom:16px}
.card-link{display:block;padding:18px;border:1px solid #d9dde3;border-radius:12px;text-decoration:none;color:#10243e;background:#f9fbfd}
label{display:block;font-weight:600;margin-bottom:6px}
input,button{font:inherit}
input,select,textarea{width:100%;padding:12px 14px;border:1px solid #c9ced6;border-radius:10px;margin-bottom:14px;background:#fff}
input:focus,select:focus,textarea:focus{outline:2px solid rgba(16,36,62,.18);border-color:#10243e}
button{padding:12px 16px;border:none;border-radius:12px;background:#10243e;color:#fff;cursor:pointer}
button:disabled{opacity:.55;cursor:not-allowed}
.button{display:inline-flex;align-items:center;justify-content:center;padding:12px 16px;border-radius:12px;text-decoration:none}
.button-secondary{background:#e8edf4;color:#10243e}
.button-link{display:inline-flex;align-items:center;justify-content:center;padding:12px 16px;border-radius:12px;background:#10243e;color:#fff;text-decoration:none}
.button-link-secondary{display:inline-flex;align-items:center;justify-content:center;padding:12px 16px;border-radius:12px;background:#e8edf4;color:#10243e;text-decoration:none;border:1px solid #cfd6df;line-height:1.1;white-space:nowrap}
.button-danger{background:#a72c2c;color:#fff}
.logout-form{display:flex;align-items:center;gap:10px;margin:0}
.notice{padding:12px 14px;border-radius:10px;background:#eef5ff;color:#194c95}
.alert{padding:12px 14px;border-radius:10px;background:#fdecec;color:#8a2424}
.help{margin-top:0;color:#55606e}
.choice-group{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;margin:0 0 14px;padding:0;border:none;min-inline-size:0}
.choice-group legend{grid-column:1/-1;font-weight:600;margin-bottom:6px}
.choice-option{display:flex;align-items:center;justify-content:flex-start;gap:10px;padding:12px 14px;border:1px solid #c9ced6;border-radius:10px;background:#fff;cursor:pointer;margin:0;font-weight:600}
.choice-option input[type="radio"]{width:auto;padding:0;margin:0;border:none;background:transparent;box-shadow:none;accent-color:#10243e;flex:0 0 auto}
.choice-option span{display:block}
.inline-actions{display:flex;flex-wrap:wrap;gap:8px}
.check-row{display:flex;align-items:center;gap:10px;margin:0 0 14px}
.check-row input{width:auto;margin:0}
.stats-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px}
.stats-grid-4{grid-template-columns:repeat(4,minmax(0,1fr))}
.mini-stat{padding:16px;border:1px solid #d9dde3;border-radius:14px;background:#f9fbfd;text-align:center}
.mini-stat strong{display:block;font-size:1.6rem;line-height:1}
.mini-stat span{display:block;margin-top:6px;color:#55606e}
.success-banner{margin:0 0 16px;padding:14px 16px;border:1px solid #b7e0c2;border-radius:12px;background:#e7f7ec;color:#176437;font-weight:600}
.success-banner[data-tone="danger"]{border-color:#f2c1c1;background:#fde6e6;color:#9c2626}
.simple-list{margin:0;padding-left:18px}
.simple-list li{padding:2px 0}
.data-table{width:100%;border-collapse:collapse}
.data-table th,.data-table td{padding:12px 10px;border-bottom:1px solid #e2e7ee;text-align:left;vertical-align:top}
.data-table thead th{font-size:.92rem;color:#55606e;background:#f8fafc}
.data-table tbody tr:hover{background:#fbfcfe}
.data-table code{font-size:.92rem}
.text-link{color:#10243e;font-weight:700;text-decoration:none}
.text-link:hover,.text-link:focus{text-decoration:underline}
.search-form{display:flex;align-items:center;gap:8px}
.search-form input{margin:0;min-width:260px}
.table-tools{align-items:center}
.terrain-search-card{margin:16px 0}
.terrain-list{display:grid;gap:12px;margin-top:16px}
.person-card{display:grid;grid-template-columns:88px minmax(0,1fr);gap:16px;padding:16px;border:1px solid #d9dde3;border-radius:14px;background:#fff}
.person-photo{display:flex;align-items:center;justify-content:center;border-radius:18px;overflow:hidden;background:#edf1f6}
.person-photo.small{width:88px;height:88px}
.person-photo.large{width:100%;min-height:320px}
.person-photo img{width:100%;height:100%;object-fit:cover;display:block}
.photo-detail-visual{display:grid;gap:12px;align-self:start}
.photo-reference-large{display:flex;align-items:center;justify-content:center;min-height:92px;padding:16px;border:1px solid #d9dde3;border-radius:14px;background:#10243e;color:#fff;text-align:center}
.photo-reference-large strong{font-size:4.5rem;line-height:1}
.photo-placeholder{display:flex;align-items:center;justify-content:center;width:100%;height:100%;font-size:2.4rem;font-weight:700;color:#435065}
.person-main h3,.detail-main h2{margin:0 0 10px}
.status-row{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:12px}
.reason-editor{display:grid;gap:8px}
.reason-editor label{margin-bottom:0}
.reason-editor input,.reason-editor select{margin-bottom:0}
.status-pill{background:#edf1f6;color:#10243e}
.status-pill.active.yes,.status-badge.yes{background:#dff3e5;color:#136338}
.status-pill.active.no,.status-badge.no{background:#fde6e6;color:#9c2626}
.status-pill.active.pending,.status-badge.pending{background:#eef1f5;color:#495869}
.status-badge.present{background:#dff3e5;color:#136338}
.status-badge{display:inline-flex;align-items:center;justify-content:center;padding:8px 12px;border-radius:999px;font-size:.92rem;font-weight:600}
.person-main textarea,.detail-main textarea{min-height:88px;resize:vertical}
.detail-main textarea[readonly]{background:#f8fafc;color:#55606e}
.terrain-checkin-layout{display:grid;grid-template-columns:minmax(280px,360px) minmax(0,1fr);gap:16px;margin-top:16px}
.checkin-search-panel{margin-top:12px}
.results-list{display:grid;gap:8px;margin-top:12px}
.result-row{display:flex;align-items:center;justify-content:space-between;gap:12px;width:100%;padding:14px 16px;border:1px solid #d9dde3;border-radius:12px;background:#fff;color:#10243e;text-align:left;cursor:pointer;appearance:none;-webkit-appearance:none}
.result-row.active{border-color:#10243e;background:#f4f8fc}
.result-form{margin:0}
.result-row-main{display:grid;gap:3px;min-width:0}
.result-row-main span{color:#55606e;font-size:.92rem}
.result-statuses{display:flex;flex-wrap:wrap;gap:8px}
.checkin-detail-grid{display:grid;grid-template-columns:minmax(280px,1.1fr) minmax(320px,1fr);gap:20px;align-items:stretch}
.detail-meta{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:14px}
.detail-list{display:grid;gap:12px;margin:0 0 18px}
.detail-list div{padding:12px 14px;border:1px solid #e2e7ee;border-radius:12px;background:#f9fbfd}
.detail-list dt{font-weight:700;color:#55606e;font-size:.9rem}
.detail-list dd{margin:4px 0 0;color:#10243e;font-size:1.08rem}
.youth-browser{margin-top:16px}
.youth-detail-panel{min-width:0}
.terrain-top-actions{margin:0 0 16px}
.inline-actions .button,
.inline-actions .button-link,
.inline-actions .button-link-secondary,
.inline-actions button{white-space:nowrap}
.event-access-actions{display:grid;grid-template-columns:1fr;gap:8px;min-width:168px}
.event-access-actions .button-link,
.event-access-actions .button-link-secondary{width:100%}
.events-table td:nth-child(4){width:190px}
.events-table td:nth-child(5){width:130px}
.settings-option-list{display:grid;gap:12px;margin:16px 0 24px}
.settings-option-row{display:grid;grid-template-columns:minmax(0,1fr) 110px auto;gap:10px;align-items:end;padding:14px;border:1px solid #d9dde3;border-radius:14px;background:#f9fbfd}
.settings-option-row input{margin-bottom:0}
.settings-option-actions{display:flex;flex-wrap:wrap;gap:8px}
.settings-create-form{border-top:1px solid #e2e7ee;padding-top:20px}

@media (max-width: 820px){
  .app-header-row{flex-direction:column;align-items:flex-start}
  .app-nav{width:100%;flex-wrap:wrap}
  .app-nav .button-link-secondary,
  .logout-form .button{width:100%}
  .two-col{grid-template-columns:1fr}
  .stats-grid{grid-template-columns:1fr}
  .logout-form{flex-wrap:wrap}
  .page-head{align-items:flex-start;flex-direction:column}
  .search-form{width:100%;flex-direction:column;align-items:stretch}
  .search-form input{min-width:0;width:100%}
  .choice-group{grid-template-columns:1fr}
  .person-card{grid-template-columns:1fr}
  .person-photo.small{width:100%;height:220px}
  .terrain-checkin-layout{grid-template-columns:1fr}
  .checkin-detail-grid{grid-template-columns:1fr}
  .person-photo.large{min-height:240px}
  .result-row{flex-direction:column;align-items:flex-start}
  .settings-option-row{grid-template-columns:1fr}
}
