:root {
  --bg:#0a0f1a; --bg-card:#0f1724; --bg-card2:#111b2e;
  --border:#1a2540; --border-light:#1e2f50;
  --gold:#c8a96e; --teal:#7c9fa6; --purple:#8b7ec8;
  --text:#e2e8f0; --text-dim:#64748b; --text-mid:#94a3b8;
  --red:#e05252; --green:#52c487;
  --font-sans:'DM Sans',system-ui,sans-serif;
  --font-display:'Playfair Display',Georgia,serif;
  --font-mono:'DM Mono',monospace;
  --radius:10px; --radius-sm:6px;
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{font-size:15px}
body{background:var(--bg);color:var(--text);font-family:var(--font-sans);min-height:100vh;line-height:1.6}
a{color:var(--gold);text-decoration:none}
a:hover{color:var(--text)}
.nav{display:flex;align-items:center;padding:0 2rem;height:60px;background:var(--bg-card);border-bottom:1px solid var(--border);position:sticky;top:0;z-index:100;gap:2rem}
.nav-brand{display:flex;align-items:center;gap:.6rem}
.nav-icon{font-size:1.2rem;color:var(--gold)}
.nav-title{font-family:var(--font-mono);font-size:.9rem;letter-spacing:.15em;color:var(--gold);font-weight:500}
.nav-links{display:flex;gap:.25rem;flex:1}
.nav-link{color:var(--text-mid);font-size:.875rem;padding:.4rem .9rem;border-radius:var(--radius-sm);transition:all .15s}
.nav-link:hover{color:var(--text);background:var(--border)}
.nav-link.active{color:var(--gold);background:rgba(200,169,110,.08)}
.nav-right{display:flex;align-items:center;gap:1rem;margin-left:auto}
.nav-user{font-size:.8rem;color:var(--text-dim)}
.nav-logout{font-size:.8rem;color:var(--text-dim)}
.nav-logout:hover{color:var(--red)}
.main{max-width:1400px;margin:0 auto;padding:2rem}
.page-header{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:2rem;gap:1rem;flex-wrap:wrap}
.page-title{font-family:var(--font-display);font-size:2rem;font-weight:400;color:var(--text)}
.page-sub{color:var(--text-dim);font-size:.875rem;margin-top:.2rem}
.header-controls{display:flex;gap:.75rem;flex-wrap:wrap}
.period-toggle{display:flex;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-sm);overflow:hidden}
.period-btn{background:none;border:none;color:var(--text-dim);cursor:pointer;font-family:var(--font-mono);font-size:.75rem;padding:.4rem .75rem;transition:all .15s;letter-spacing:.05em}
.period-btn.active{background:var(--gold);color:#0a0f1a;font-weight:500}
.alert{padding:.75rem 1rem;border-radius:var(--radius-sm);margin-bottom:1.5rem;font-size:.875rem}
.alert-warn{background:rgba(200,169,110,.08);border:1px solid rgba(200,169,110,.2);color:var(--gold)}
.alert-info{background:rgba(124,159,166,.08);border:1px solid rgba(124,159,166,.2);color:var(--teal)}
.alert-info code{background:rgba(124,159,166,.15);padding:.1rem .3rem;border-radius:3px;font-family:var(--font-mono);font-size:.8rem}
.flash-container{margin-bottom:1.5rem}
.flash{padding:.75rem 1rem;border-radius:var(--radius-sm);margin-bottom:.5rem;font-size:.875rem}
.flash-success{background:rgba(82,196,135,.1);border:1px solid rgba(82,196,135,.2);color:var(--green)}
.flash-error{background:rgba(224,82,82,.1);border:1px solid rgba(224,82,82,.2);color:var(--red)}
.section-label{font-family:var(--font-mono);font-size:.7rem;letter-spacing:.12em;color:var(--text-dim);text-transform:uppercase;margin:2rem 0 1rem;padding-left:2px}
.sources-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(420px,1fr));gap:1.25rem}
.source-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:1.5rem;transition:border-color .2s}
.source-card:hover{border-color:var(--border-light)}
.source-card-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:1.25rem}
.source-name{font-size:1rem;font-weight:500;color:var(--text);margin-top:.3rem}
.source-currency{font-family:var(--font-mono);font-size:.7rem;color:var(--text-dim);letter-spacing:.08em}
.source-badge{font-family:var(--font-mono);font-size:.65rem;letter-spacing:.1em;padding:.2rem .5rem;border-radius:3px;font-weight:500}
.source-badge.pms{background:rgba(124,159,166,.12);color:var(--teal);border:1px solid rgba(124,159,166,.2)}
.source-badge.property{background:rgba(200,169,110,.12);color:var(--gold);border:1px solid rgba(200,169,110,.2)}
.source-badge.mixed{background:rgba(139,126,200,.12);color:var(--purple);border:1px solid rgba(139,126,200,.2)}
.kpi-grid{display:grid;grid-template-columns:1fr 1fr;gap:.75rem;margin-bottom:1.25rem}
.kpi-card{background:var(--bg-card2);border:1px solid var(--border);border-radius:var(--radius-sm);padding:.875rem 1rem}
.kpi-wide{grid-column:1/-1}
.kpi-label{font-size:.7rem;color:var(--text-dim);letter-spacing:.06em;text-transform:uppercase;margin-bottom:.4rem;font-family:var(--font-mono)}
.kpi-value{font-size:1.35rem;font-weight:600;color:var(--text);font-family:var(--font-mono);letter-spacing:-.02em}
.kpi-delta{font-size:.75rem;margin-top:.2rem;font-family:var(--font-mono)}
.kpi-delta.pos{color:var(--green)}
.kpi-delta.neg{color:var(--red)}
.pickup-grid{display:flex;gap:1.5rem}
.pickup-item{display:flex;flex-direction:column;gap:.2rem}
.pickup-label{font-size:.65rem;color:var(--text-dim);font-family:var(--font-mono);letter-spacing:.08em}
.pickup-val{font-size:.95rem;font-weight:500;color:var(--text);font-family:var(--font-mono)}
.chart-tabs{display:flex;gap:.25rem;margin-bottom:.75rem}
.chart-tab{background:none;border:1px solid transparent;color:var(--text-dim);cursor:pointer;font-size:.75rem;padding:.3rem .7rem;border-radius:var(--radius-sm);transition:all .15s;font-family:var(--font-sans)}
.chart-tab:hover{color:var(--text);border-color:var(--border)}
.chart-tab.active{color:var(--gold);border-color:rgba(200,169,110,.3);background:rgba(200,169,110,.06)}
.chart-container{height:180px}
.chart-empty{height:100%;display:flex;align-items:center;justify-content:center;color:var(--text-dim);font-size:.8rem;border:1px dashed var(--border);border-radius:var(--radius-sm)}
.card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:1.5rem}
.card-title{font-family:var(--font-display);font-size:1.1rem;font-weight:400;margin-bottom:1.25rem;color:var(--text)}
.card-sub{color:var(--text-dim);font-family:var(--font-sans);font-size:.8rem;margin-left:.5rem}
.mt-1{margin-top:1.25rem}
.form-group{margin-bottom:1rem}
.form-label{display:block;font-size:.75rem;color:var(--text-dim);margin-bottom:.4rem;letter-spacing:.04em}
.form-input{width:100%;background:var(--bg);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text);font-family:var(--font-sans);font-size:.875rem;padding:.6rem .875rem;outline:none;transition:border-color .15s}
.form-input:focus{border-color:var(--gold)}
.form-input::placeholder{color:var(--text-dim)}
select.form-input option{background:var(--bg-card)}
.form-hint{font-size:.75rem;color:var(--text-dim);margin-top:.5rem}
.form-row{display:flex;gap:.75rem;flex-wrap:wrap}
.form-row .form-group{flex:1;min-width:160px}
.form-row .form-input{width:100%}
.btn{display:inline-flex;align-items:center;gap:.4rem;padding:.6rem 1.25rem;border:none;border-radius:var(--radius-sm);cursor:pointer;font-family:var(--font-sans);font-size:.875rem;font-weight:500;transition:all .15s;white-space:nowrap}
.btn-primary{background:var(--gold);color:#0a0f1a}
.btn-primary:hover{background:#d4b67e}
.btn-full{width:100%;justify-content:center}
.btn-sm{background:none;border:1px solid var(--border);color:var(--text-dim);border-radius:var(--radius-sm);cursor:pointer;font-size:.75rem;padding:.25rem .6rem;font-family:var(--font-sans);transition:all .15s}
.btn-sm:hover{border-color:var(--border-light);color:var(--text)}
.btn-danger-sm{background:none;border:1px solid rgba(224,82,82,.3);color:var(--red);border-radius:var(--radius-sm);cursor:pointer;font-size:.75rem;padding:.25rem .6rem;font-family:var(--font-sans);transition:all .15s}
.btn-danger-sm:hover{background:rgba(224,82,82,.1)}
.guide-note{font-size:.75rem;color:var(--text-dim);margin-top:.5rem}
.guide-badge{display:inline-block;font-family:var(--font-mono);font-size:.65rem;letter-spacing:.1em;padding:.2rem .5rem;border-radius:3px;margin-bottom:.6rem;background:rgba(124,159,166,.12);color:var(--teal);border:1px solid rgba(124,159,166,.2)}
.guide-table,.data-table{width:100%;border-collapse:collapse;font-size:.825rem}
.guide-table th,.data-table th{text-align:left;padding:.5rem .75rem;color:var(--text-dim);font-size:.7rem;letter-spacing:.06em;text-transform:uppercase;border-bottom:1px solid var(--border);font-weight:400}
.guide-table td,.data-table td{padding:.6rem .75rem;border-bottom:1px solid var(--border);color:var(--text-mid)}
.guide-table code{font-family:var(--font-mono);color:var(--gold);font-size:.8rem}
.data-table td.num{font-family:var(--font-mono);text-align:right}
.data-table td.dim{color:var(--text-dim);font-size:.8rem}
.data-table tfoot td{padding:.6rem .75rem;border-top:1px solid var(--border-light);color:var(--text)}
.empty-row{text-align:center;color:var(--text-dim)!important;padding:1.5rem!important}
.row-inactive{opacity:.5}
.table-wrap{overflow-x:auto;margin-top:1rem}
.lookup-layout{display:grid;grid-template-columns:320px 1fr;gap:1.5rem;align-items:start}
.lookup-form{display:flex;flex-direction:column;gap:.75rem}
.results-header{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:1rem;margin-bottom:1.25rem}
.results-summary{display:flex;gap:1.5rem;flex-wrap:wrap;font-size:.8rem;color:var(--text-mid)}
.results-summary strong{color:var(--text)}
.admin-grid{display:flex;flex-direction:column;gap:1.5rem}
.inline-form{margin-top:1.5rem;padding-top:1.5rem;border-top:1px solid var(--border)}
.inline-form-title{font-size:.8rem;color:var(--text-dim);margin-bottom:.75rem;letter-spacing:.04em}
.inline-form .form-row{align-items:flex-end;flex-wrap:wrap}
.inline-form .form-row .form-group{margin-bottom:0}
.checkbox-label{display:flex;align-items:center;gap:.4rem;font-size:.875rem;color:var(--text-mid);cursor:pointer;white-space:nowrap;align-self:flex-end;padding-bottom:.625rem}
.badge{display:inline-block;font-size:.65rem;letter-spacing:.06em;padding:.15rem .5rem;border-radius:3px;font-family:var(--font-mono)}
.badge-admin{background:rgba(200,169,110,.12);color:var(--gold);border:1px solid rgba(200,169,110,.2)}
.badge-user{background:rgba(100,116,139,.12);color:var(--text-dim);border:1px solid var(--border)}
.badge-active{background:rgba(82,196,135,.1);color:var(--green);border:1px solid rgba(82,196,135,.2)}
.badge-inactive{background:rgba(100,116,139,.1);color:var(--text-dim);border:1px solid var(--border)}
.badge-error{background:rgba(224,82,82,.1);color:var(--red);border:1px solid rgba(224,82,82,.2);font-family:var(--font-mono);font-size:.65rem;padding:.15rem .5rem;border-radius:3px}
.badge-mixed{background:rgba(139,126,200,.12);color:var(--purple);border:1px solid rgba(139,126,200,.2);font-family:var(--font-mono);font-size:.65rem;padding:.15rem .5rem;border-radius:3px}
.badge-pms-hostify{background:rgba(82,196,135,.1);color:var(--green);border:1px solid rgba(82,196,135,.2);font-family:var(--font-mono);font-size:.65rem;letter-spacing:.06em;padding:.15rem .5rem;border-radius:3px}
.badge-pms-cloudbeds{background:rgba(124,159,166,.1);color:var(--teal);border:1px solid rgba(124,159,166,.2);font-family:var(--font-mono);font-size:.65rem;letter-spacing:.06em;padding:.15rem .5rem;border-radius:3px}
.mono{font-family:var(--font-mono);font-size:.8rem}
.empty-state{text-align:center;padding:4rem 2rem;color:var(--text-dim)}
.empty-icon{font-size:2rem;color:var(--border-light);margin-bottom:1rem}
.empty-state h3{color:var(--text-mid);margin-bottom:.5rem}
.empty-state p{font-size:.875rem}
.monthly-toggle-row{margin-top:.75rem}
.monthly-btn{background:none;border:1px solid var(--border);color:var(--text-dim);cursor:pointer;font-size:.75rem;padding:.3rem .75rem;border-radius:var(--radius-sm);width:100%;font-family:var(--font-sans);transition:all .15s}
.monthly-btn:hover{border-color:var(--gold);color:var(--gold)}
.monthly-table tfoot td{padding:.6rem .75rem;border-top:1px solid var(--border-light);color:var(--text)}
.ch-summary{margin-bottom:1.25rem}
.ch-kpi-row{display:flex;gap:.75rem;flex-wrap:wrap}
.ch-kpi-row .kpi-card{flex:1;min-width:120px}
.ch-charts{display:grid;grid-template-columns:1fr 1fr;gap:1.25rem}
.ch-dot{display:inline-block;width:8px;height:8px;border-radius:50%;margin-right:.5rem;vertical-align:middle}
.actions-cell{display:flex;gap:.4rem;flex-wrap:wrap}
.inline-rooms-form{display:flex;gap:.4rem;align-items:center}
.rooms-input{width:80px!important;padding:.3rem .5rem!important;font-size:.8rem!important}
.api-status-row{display:flex;flex-direction:column;gap:.75rem}
.api-status-item{display:flex;align-items:center;gap:.75rem;font-size:.875rem}
.api-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}
.dot-ok{background:var(--green);box-shadow:0 0 6px rgba(82,196,135,.4)}
.dot-warn{background:var(--gold);box-shadow:0 0 6px rgba(200,169,110,.4)}
.dot-err{background:var(--red);box-shadow:0 0 6px rgba(224,82,82,.4)}
body.login-page{display:flex;align-items:stretch}
.login-wrap{display:flex;min-height:100vh;width:100%}
.login-left{flex:1;background:linear-gradient(145deg,#0a0f1a 0%,#0f1724 60%,#111b2e 100%);padding:4rem;display:flex;flex-direction:column;justify-content:center;border-right:1px solid var(--border);position:relative;overflow:hidden}
.login-left::before{content:'';position:absolute;top:-100px;right:-100px;width:400px;height:400px;background:radial-gradient(circle,rgba(200,169,110,.04) 0%,transparent 70%);border-radius:50%}
.login-brand{display:flex;align-items:center;gap:.75rem;margin-bottom:2rem}
.login-icon{font-size:2rem;color:var(--gold)}
.login-title{font-family:var(--font-mono);font-size:1.5rem;letter-spacing:.2em;color:var(--gold)}
.login-tagline{font-family:var(--font-display);font-size:1.75rem;line-height:1.4;color:var(--text);margin-bottom:3rem;font-weight:400}
.login-metrics{display:flex;flex-direction:column;gap:.5rem}
.lm-item{font-family:var(--font-mono);font-size:.75rem;letter-spacing:.12em;color:var(--text-dim);padding-left:1rem;border-left:2px solid var(--border)}
.login-right{width:420px;padding:4rem 3rem;display:flex;align-items:center}
.login-form-box{width:100%}
.login-heading{font-family:var(--font-display);font-size:1.5rem;font-weight:400;margin-bottom:.25rem}
.login-sub{color:var(--text-dim);font-size:.875rem;margin-bottom:2rem}
@media(max-width:900px){.login-left{display:none}.login-right{width:100%}.lookup-layout{grid-template-columns:1fr}.sources-grid{grid-template-columns:1fr}.ch-charts{grid-template-columns:1fr}}
@media(max-width:600px){.main{padding:1rem}.nav{padding:0 1rem}.page-header{flex-direction:column}}

/* ── Modals ─────────────────────────────────────────────── */
.modal { position:fixed; inset:0; z-index:200; display:flex; align-items:center; justify-content:center; }
.modal-box { background:var(--bg-card); border:1px solid var(--border-light); border-radius:var(--radius); padding:2rem; width:100%; max-width:460px; position:relative; z-index:201; }
.modal-title { font-family:var(--font-display); font-size:1.2rem; font-weight:400; margin-bottom:.25rem; }
.modal-sub { font-size:.875rem; color:var(--text-dim); margin-bottom:1.5rem; }
.modal-actions { display:flex; gap:.75rem; justify-content:flex-end; margin-top:1.25rem; }
.modal-overlay { position:fixed; inset:0; background:rgba(0,0,0,.6); z-index:199; }
