body{margin:0;font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;background:#f3f6fb;color:#172033}
.admin-shell{display:grid;grid-template-columns:260px 1fr;min-height:100vh}
.admin-sidebar{background:#14213d;color:#fff;padding:22px 18px;position:sticky;top:0;height:100vh;box-sizing:border-box}
.admin-sidebar__brand{font-size:1.85rem;font-weight:800;line-height:1.1;margin-bottom:6px}
.admin-sidebar__sub{font-size:.9rem;color:#b8c8ef;margin-bottom:22px}
.admin-sidebar nav{display:grid;gap:6px}
.admin-sidebar a{color:#dce7ff;padding:12px 14px;border-radius:12px;text-decoration:none;font-weight:600}
.admin-sidebar a:hover,.admin-sidebar a.is-active{background:#2a4fbf;color:#fff}
.admin-main{padding:28px 28px 40px}
.admin-page-header{display:flex;justify-content:space-between;align-items:flex-start;gap:16px;margin-bottom:20px;flex-wrap:wrap}
.admin-page-header h1{margin:0;font-size:2.2rem;line-height:1.15}
.admin-page-header p{margin:8px 0 0;color:#5b6880}
.card{background:#fff;border:1px solid #dde5f1;border-radius:18px;padding:20px;box-shadow:0 8px 24px rgba(20,33,61,.04)}
.stack>*+*{margin-top:14px}
label{display:block;font-weight:700;color:#22314f}
input,textarea,select,button{font:inherit}
input[type=text],input[type=email],input[type=password],input[type=number],input[type=date],input[type=time],textarea,select{width:100%;padding:12px 14px;border:1px solid #ccd6e6;border-radius:12px;background:#fff;box-sizing:border-box;margin-top:6px}
textarea{min-height:92px;resize:vertical}
.btn,.btn-secondary,.btn-light,.btn-danger{display:inline-flex;align-items:center;justify-content:center;gap:6px;padding:11px 16px;min-height:44px;border-radius:12px;text-decoration:none;border:1px solid transparent;cursor:pointer;font-weight:700;line-height:1.2;box-sizing:border-box;transition:background-color .18s ease,border-color .18s ease,color .18s ease,box-shadow .18s ease}
.btn{background:#2b59d6;color:#fff;border-color:#2b59d6}
.btn:hover{background:#244fbe;border-color:#244fbe}
.btn-secondary{background:#eef3ff;color:#244fbe;border-color:#d7e2ff}
.btn-secondary:hover{background:#e2ebff;border-color:#c7d7ff}
.btn-light{background:#fff;color:#244fbe;border-color:#ccd6e6}
.btn-light:hover{background:#f8fbff;border-color:#b9c8df}
.btn-danger{background:#fff1f0;color:#b42318;border-color:#f3c8c2}
.btn-danger:hover{background:#fee2df;border-color:#ecb5ad}
.btn:focus-visible,.btn-secondary:focus-visible,.btn-light:focus-visible,.btn-danger:focus-visible{outline:0;box-shadow:0 0 0 3px rgba(43,89,214,.16)}
.btn-row{display:flex;gap:10px;flex-wrap:wrap}
.btn-sm{padding:8px 12px;min-height:38px;border-radius:10px;font-size:.92rem}
.btn-xs{padding:6px 10px;min-height:34px;border-radius:9px;font-size:.86rem}
.table{width:100%;border-collapse:separate;border-spacing:0;background:#fff;border:1px solid #dde5f1;border-radius:18px;overflow:hidden;box-shadow:0 8px 24px rgba(20,33,61,.04)}
.table th,.table td{padding:14px 16px;border-bottom:1px solid #ebf0f7;text-align:left;vertical-align:top}
.table tr:last-child td{border-bottom:0}
.table th{background:#f8fbff;font-size:.95rem;color:#30415f}
.table .actions{white-space:nowrap}
.badge{display:inline-flex;align-items:center;padding:5px 10px;border-radius:999px;font-size:.82rem;font-weight:800}
.badge-success{background:#e8f8ee;color:#15753c}
.badge-warning{background:#fff4db;color:#9a6400}
.badge-danger{background:#feeceb;color:#9f1d1d}
.badge-neutral{background:#eaf0ff;color:#244fbe}
.alert{padding:12px 14px;border-radius:12px;margin-bottom:16px}
.alert-error{background:#feeceb;color:#9f1d1d}.alert-success{background:#e9f8ee;color:#136335}
.login-box{max-width:440px;margin:72px auto;padding:26px;background:#fff;border:1px solid #e5e7ef;border-radius:20px;box-shadow:0 12px 30px rgba(20,33,61,.06)}
.stats{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:16px;margin-bottom:18px}.stat{background:#fff;border:1px solid #dde5f1;border-radius:18px;padding:18px;box-shadow:0 8px 24px rgba(20,33,61,.04)}.stat strong{display:block;font-size:2rem}.stat span{color:#60708d}.stat small{display:block;margin-top:6px;color:#7a869c}
.admin-subnav{display:flex;gap:10px;flex-wrap:wrap;margin:0 0 14px}.admin-subnav a{display:inline-flex;padding:8px 12px;background:#eef3ff;border-radius:999px;text-decoration:none;color:#244fbe;font-weight:700}
.photo-upload-card{max-width:760px}
.photo-admin-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:20px;margin-top:18px}
.photo-admin-card{background:#fff;border:1px solid #dde5f1;border-radius:18px;overflow:hidden;box-shadow:0 8px 24px rgba(20,33,61,.04)}
.photo-admin-card img{display:block;width:100%;aspect-ratio:16/9;object-fit:cover;background:#eef3ff}
.photo-admin-card__body{padding:14px}
.photo-admin-card__body h3{margin:0 0 6px;font-size:1rem}
.muted{color:#6b7790;font-size:.92rem}
.meta-row{display:flex;gap:10px;align-items:center;flex-wrap:wrap;margin-bottom:10px}
.table-actions,.photo-card-actions{display:flex;gap:8px;flex-wrap:wrap;margin-top:10px}
.empty-state{padding:20px;background:#fff;border:1px dashed #ccd6e6;border-radius:16px;color:#60708d}
.two-col{display:grid;grid-template-columns:minmax(0,1.5fr) minmax(280px,.9fr);gap:22px;align-items:start}
.kv-list{display:grid;gap:12px}.kv-item{display:flex;justify-content:space-between;gap:18px;padding:10px 0;border-bottom:1px solid #ebf0f7}.kv-item:last-child{border-bottom:0}.kv-item dt{font-weight:700;color:#4c5a74}.kv-item dd{margin:0;font-weight:700}
.inline-form{display:flex;gap:10px;flex-wrap:wrap;align-items:end}.inline-form > *{margin:0}
.help{color:#6b7790;font-size:.9rem}
@media (max-width:980px){.admin-shell{grid-template-columns:1fr}.admin-sidebar{height:auto;position:static}.stats{grid-template-columns:1fr}.two-col{grid-template-columns:1fr}.admin-main{padding:18px}}


.admin-card-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:18px}
.admin-stat{background:#fff;border:1px solid #dde5f1;border-radius:18px;padding:18px;box-shadow:0 8px 24px rgba(20,33,61,.04)}
.admin-stat__label{font-size:.9rem;color:#60708d;font-weight:700}
.admin-stat__value{font-size:2rem;font-weight:800;line-height:1.1;margin-top:8px}
.admin-stat__note{margin-top:6px;color:#7a869c;font-size:.9rem}
.table-thumb{width:104px;aspect-ratio:16/9;border-radius:10px;object-fit:cover;border:1px solid #dde5f1;background:#eef3ff}
.table-title{display:grid;gap:4px}
.table-title strong{font-size:1.02rem}
.table-link-pills{display:flex;flex-wrap:wrap;gap:8px}
.table-link-pills a{display:inline-flex;align-items:center;justify-content:center;padding:8px 12px;border-radius:999px;text-decoration:none;font-weight:700;font-size:.9rem;line-height:1.2;transition:background-color .18s ease,border-color .18s ease,color .18s ease}
.table-link-pills a.primary{background:#eef3ff;color:#244fbe}
.table-link-pills a.light{background:#fff;color:#244fbe;border:1px solid #ccd6e6}
.table-compact td,.table-compact th{padding:12px 12px}
.filter-card{max-width:none}
.filter-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:12px}
.filter-actions{display:flex;align-items:end;gap:10px}
.form-grid-2{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:16px}
.form-grid-3{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:16px}
.preview-chips{display:flex;flex-wrap:wrap;gap:8px;margin:14px 0 0}
.preview-chip{display:inline-flex;padding:7px 11px;border-radius:999px;background:#eef3ff;color:#244fbe;font-weight:700;font-size:.9rem}
.photo-upload-layout{display:grid;grid-template-columns:minmax(0,1.2fr) 300px;gap:18px;align-items:start}
.tip-card{background:#f8fbff;border:1px solid #dde5f1;border-radius:16px;padding:16px}
.tip-card h3{margin:0 0 10px;font-size:1rem}
.photo-admin-card__body .btn-secondary,.photo-admin-card__body .btn-danger{min-height:40px;padding:0 14px}
.photo-admin-card__body form{margin:0}
.photo-admin-card__body .photo-card-actions form{display:inline-flex}
.section-block{background:#fff;border:1px solid #dde5f1;border-radius:18px;padding:18px;box-shadow:0 8px 24px rgba(20,33,61,.04)}
.section-block h2{margin:0 0 12px;font-size:1.15rem}
.kpi-table-wrap{margin-top:18px}
@media (max-width:1100px){
  .photo-upload-layout{grid-template-columns:1fr}
  .filter-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
  .form-grid-2,.form-grid-3{grid-template-columns:1fr}
}
@media (max-width:720px){
  .filter-grid{grid-template-columns:1fr}
}


/* p9 admin photo polish */
.photo-admin-grid--wide{grid-template-columns:repeat(auto-fit,minmax(320px,1fr))}
.photo-sort-form{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:10px;align-items:end;margin:12px 0}
.photo-sort-form label{margin:0}
.photo-sort-form input[type=number]{margin-top:6px}
@media (max-width:720px){
  .photo-sort-form{grid-template-columns:1fr}
}


/* p12 admin brushup */
.admin-shortcuts{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:14px;margin:18px 0}
.admin-shortcut{display:block;background:#fff;border:1px solid #dde5f1;border-radius:18px;padding:16px 18px;text-decoration:none;box-shadow:0 8px 24px rgba(20,33,61,.04)}
.admin-shortcut strong{display:block;color:#172033;font-size:1rem;margin-bottom:6px}
.admin-shortcut span{color:#60708d;font-size:.92rem}
.dashboard-layout{display:grid;grid-template-columns:minmax(0,1.3fr) minmax(340px,.9fr);gap:22px;align-items:start;margin-top:18px}
.section-head{display:flex;justify-content:space-between;gap:12px;align-items:center;margin-bottom:12px;flex-wrap:wrap}
.section-head h2{margin:0;font-size:1.15rem}
.admin-activity-list{display:grid;gap:12px}
.admin-activity-item{border:1px solid #e6edf7;border-radius:16px;padding:14px}
.admin-activity-item__meta{display:flex;justify-content:space-between;gap:12px;align-items:flex-start;margin-bottom:10px}
.admin-activity-item__body{display:flex;justify-content:space-between;gap:12px;align-items:center}
.table-dashboard td:last-child,.table-reservations td:last-child{white-space:nowrap}
.mini-stats{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:16px}
.mini-stat{background:#fff;border:1px solid #dde5f1;border-radius:14px;padding:12px 14px;min-width:120px;box-shadow:0 8px 24px rgba(20,33,61,.04)}
.mini-stat strong{display:block;font-size:1.4rem;line-height:1.1;margin-top:6px}
.reservation-detail-layout .kv-item dd{max-width:420px;text-align:right;word-break:break-word}
.note-panel{background:#f8fbff;border:1px solid #dde5f1;border-radius:14px;padding:14px}
.note-panel p{margin:6px 0 0}
.facility-card-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:14px;margin-top:18px}
.facility-card{display:flex;justify-content:space-between;align-items:center;gap:12px;background:#fff;border:1px solid #dde5f1;border-radius:16px;padding:14px;box-shadow:0 8px 24px rgba(20,33,61,.04)}
@media (max-width:1320px){.dashboard-layout{grid-template-columns:1fr}}
@media (max-width:900px){.admin-activity-item__body,.admin-activity-item__meta,.facility-card{display:grid}.reservation-detail-layout .kv-item{display:grid;gap:6px}.reservation-detail-layout .kv-item dd{text-align:left;max-width:none}}

.alert{padding:12px 14px;border-radius:12px;margin:0 0 18px;}
.alert-error{background:#fef2f2;color:#991b1b;border:1px solid #fecaca;}

/* p14 admin calendar */
.admin-calendar-wrap{overflow-x:auto}
.admin-calendar-table{min-width:900px}
.admin-calendar-cell{min-width:180px;background:#fff}
.admin-calendar-cell.is-outside{background:#f8fafc}
.admin-calendar-bookings{display:grid;gap:8px}
.admin-calendar-booking{display:grid;gap:3px;padding:10px 12px;border-radius:12px;text-decoration:none;border:1px solid #dde5f1;background:#f8fbff;color:#172033}
.admin-calendar-booking strong{font-size:.88rem}
.admin-calendar-booking span{font-weight:700}
.admin-calendar-booking small{color:#60708d}
.admin-calendar-booking--pending{background:#fff7e6;border-color:#f7d9a8}
.admin-calendar-booking--confirmed{background:#edfdf3;border-color:#b7ebc6}
.admin-calendar-booking--cancelled{background:#fef2f2;border-color:#fecaca}

.alert-info{background:#eef4ff;color:#1f4dbf;border:1px solid #bfd4ff;}
.admin-demo-banner{margin-bottom:18px;line-height:1.6;}
.login-demo-note{line-height:1.6;}


.admin-calendar-table td[rowspan]{vertical-align:top}
.admin-calendar-cell{position:relative}
.admin-calendar-cell .badge{display:inline-flex}


.admin-page-header + .card,
.admin-page-header + form.card,
.admin-page-header + .stack{margin-top:2px}
.admin-form-inline{gap:12px;align-items:end}
.admin-form-inline > input[type=date]{max-width:220px}
.admin-form-inline > input[type=text]{min-width:240px;flex:1 1 260px}
.inline-form--compact{display:inline-flex;align-items:center;gap:8px;flex-wrap:wrap}
.table-actions,.table-actions form{display:inline-flex;align-items:center;gap:8px;margin:0}
.table-actions{flex-wrap:wrap}
.table-actions .btn-light,.table-actions .btn-danger,.table-actions .btn-secondary,.table-actions .btn{min-height:38px;padding:8px 12px;border-radius:10px}
.photo-sort-form .btn-light{white-space:nowrap}
.photo-sort-form input[type=number]{margin-top:6px}
.photo-card-actions{margin-top:8px}
.photo-card-actions form{margin:0}
.photo-card-actions .btn-secondary,.photo-card-actions .btn-danger{min-width:0}
.facility-card form{margin:0}
.tip-card ul{padding-left:20px;line-height:1.7;margin:0}
.tip-card li+li{margin-top:8px}
.table td .btn-light,.table td .btn-danger,.table td .btn-secondary,.table td .btn{min-height:38px;padding:8px 12px;border-radius:10px}


.checkbox-inline{display:inline-flex;align-items:center;gap:8px;font-weight:700}
.checkbox-inline input[type=checkbox]{width:auto;margin:0}
.user-admin-layout .card{min-width:0}
button[disabled], .btn[disabled], .btn-light[disabled], .btn-danger[disabled], .btn-secondary[disabled]{opacity:.55;cursor:not-allowed;pointer-events:none}


.login-help{margin-top:18px;padding-top:14px;border-top:1px solid #ebf0f7;color:#5b6880;line-height:1.7;font-size:.95rem}
.login-help p{margin:0}
.login-help p + p{margin-top:8px}
