
:root{
  --nav:#073763; --nav2:#052845; --blue:#0b5ed7; --green:#169b45;
  --red:#d71920; --bg:#f4f7fb; --card:#ffffff; --text:#102033;
  --muted:#667085; --line:#d9e2ef; --shadow:0 8px 24px rgba(16,32,51,.08);
}
*{box-sizing:border-box}
body{margin:0;font-family:Arial,Helvetica,sans-serif;background:var(--bg);color:var(--text)}
a{text-decoration:none;color:inherit}.app{display:flex;min-height:100vh}
.sidebar{width:250px;background:linear-gradient(180deg,var(--nav),var(--nav2));color:#fff;padding:22px 16px;position:fixed;left:0;top:0;bottom:0}
.brand{font-size:26px;font-weight:800;letter-spacing:.2px;margin-bottom:4px;line-height:1.1}
.logo-pin{font-size:36px;margin-right:8px;vertical-align:-4px}
.brand small{display:block;font-size:13px;font-weight:400;opacity:.9;margin-top:4px;margin-left:48px}
.menu{margin-top:30px;display:flex;flex-direction:column;gap:8px}
.menu a{padding:13px 14px;border-radius:12px;display:flex;align-items:center;gap:10px;opacity:.92}
.menu a.active,.menu a:hover{background:rgba(255,255,255,.12)}
.logout{position:absolute;bottom:22px;left:16px;right:16px}.main{margin-left:250px;width:calc(100% - 250px)}
.topbar{height:74px;background:#fff;border-bottom:1px solid var(--line);display:flex;align-items:center;justify-content:space-between;padding:0 32px}
.topbar select,.input,select,textarea{border:1px solid var(--line);border-radius:10px;padding:11px 13px;background:#fff;font-size:15px}
.content{padding:28px 34px 44px}h1{font-size:30px;margin:0 0 22px}h2{font-size:20px;margin:0 0 14px}
.grid{display:grid;gap:18px}.grid.cols-4{grid-template-columns:repeat(4,1fr)}.grid.cols-3{grid-template-columns:repeat(3,1fr)}.grid.cols-2{grid-template-columns:repeat(2,1fr)}
.card{background:var(--card);border:1px solid var(--line);border-radius:16px;box-shadow:var(--shadow);padding:20px}
.metric .label{color:var(--muted);font-size:14px}.metric .value{font-size:28px;font-weight:800;margin-top:8px}
.toolbar{display:flex;gap:12px;align-items:center;justify-content:space-between;margin-bottom:18px;flex-wrap:wrap}
.left-actions,.right-actions{display:flex;gap:10px;align-items:center;flex-wrap:wrap}
.btn{border:1px solid var(--line);background:#fff;color:var(--text);border-radius:10px;padding:11px 15px;font-size:15px;cursor:pointer}
.btn.primary{background:var(--blue);color:#fff;border-color:var(--blue)}.btn.green{background:var(--green);color:#fff;border-color:var(--green)}.btn.danger{background:var(--red);color:#fff;border-color:var(--red)}
.table-wrap{background:#fff;border:1px solid var(--line);border-radius:16px;overflow:hidden;box-shadow:var(--shadow)}
table{width:100%;border-collapse:collapse}th,td{padding:15px 16px;border-bottom:1px solid var(--line);text-align:left;font-size:15px}th{background:#fbfcfe;font-weight:700}tr:last-child td{border-bottom:0}
.money-red{color:var(--red);font-weight:700}.money-green{color:var(--green);font-weight:700}.pin{font-size:25px;line-height:1}
.badge{display:inline-flex;align-items:center;gap:6px;border-radius:999px;padding:6px 10px;background:#fff4f4;color:#b00020;border:1px solid #ffd2d2;font-weight:700}
.tabs{display:flex;gap:10px;margin-bottom:18px;flex-wrap:wrap}.tab{padding:10px 14px;border:1px solid var(--line);border-radius:10px;background:#fff}.tab.active{border-color:#8bb7ff;color:#0b5ed7;font-weight:700}
.form-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:14px}.form-row label{display:block;font-size:13px;color:var(--muted);margin-bottom:6px}.form-row input,.form-row select,.form-row textarea{width:100%}
.summary-line{display:flex;justify-content:space-between;border-bottom:1px solid var(--line);padding:11px 0}.summary-line:last-child{border-bottom:0}
.student-head{display:flex;align-items:flex-start;justify-content:space-between;gap:18px}.student-name{font-size:26px;font-weight:800}.muted{color:var(--muted)}
.receipt{width:760px;max-width:100%;margin:auto;background:#fff;border:1px solid #111;padding:28px}.receipt h1{text-align:center;font-size:24px;margin-bottom:8px}.receipt .box{border:1px solid #111;padding:12px;margin-top:16px}
.report-link{display:block;padding:16px;border:1px solid var(--line);border-radius:14px;background:#fff;margin-bottom:12px}
.report-link b{display:block;margin-bottom:4px}
@media(max-width:900px){.sidebar{position:relative;width:100%;height:auto}.app{display:block}.main{margin-left:0;width:100%}.grid.cols-4,.grid.cols-3,.grid.cols-2,.form-grid{grid-template-columns:1fr}.topbar{padding:0 16px}.content{padding:22px 16px}}
@media print{body{background:#fff}.sidebar,.topbar,.no-print{display:none!important}.main{margin:0;width:100%}.content{padding:0}.card,.table-wrap{box-shadow:none}.receipt{border:1px solid #000}}

.level-report .balance-col{text-align:right;font-weight:700}
.level-report .vip-row td{background:#fff}
.level-report .name-col{font-weight:600}
.level-report .amount-col{text-align:right}
.level-report .total-row td{font-weight:800}
.level-report .total-row .amount-col{background:#fbfcfe}
.receipt-series-card code{background:#f1f5f9;padding:3px 6px;border-radius:6px}

.sync-box{border:1px dashed #9db7d8;background:#f8fbff;border-radius:16px;padding:18px}
.sync-status{display:inline-flex;align-items:center;gap:8px;border-radius:999px;padding:7px 11px;background:#eef6ff;color:#0b5ed7;font-weight:700;font-size:14px}
.small-note{font-size:13px;color:var(--muted)}
.vip-cell{width:48px;text-align:center}

.comment-box{background:#fffdf5;border:1px solid #f2d48a;border-radius:12px;padding:12px;margin-top:10px}
.comment-text{white-space:pre-wrap;color:#344054}

.comments-hint{font-size:14px;color:#667085;margin-top:6px}

.comment-box textarea{width:100%;min-height:120px}
.confirm-payment-box{border:2px solid #169b45}

.modal-backdrop{position:fixed;inset:0;background:rgba(0,0,0,.35);display:none;align-items:center;justify-content:center;z-index:50;padding:20px}
.modal{background:#fff;border-radius:18px;box-shadow:0 24px 80px rgba(16,32,51,.25);width:760px;max-width:96%;max-height:92vh;overflow:auto;padding:22px;border:1px solid var(--line)}
.modal-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}
.icon-btn{border:0;background:transparent;font-size:24px;cursor:pointer}
.actions-inline{display:flex;gap:8px;flex-wrap:wrap}
.search-count{font-size:14px;color:var(--muted)}
.toast{position:fixed;right:22px;bottom:22px;background:#102033;color:#fff;padding:12px 16px;border-radius:12px;display:none;z-index:100}

.students-table th,.students-table td{font-size:13px;padding:10px 9px}
.action-btn{width:34px;height:34px;display:inline-flex;align-items:center;justify-content:center;border-radius:9px;padding:0;font-size:15px}
.action-btn.danger{background:#d71920;color:#fff;border-color:#d71920;font-weight:900}
.actions-inline{gap:5px;justify-content:flex-start}
.vip-check{display:flex!important;align-items:center;gap:4px;margin-top:12px}
.discount-row{display:grid;grid-template-columns:1fr 90px 1fr;gap:10px}
.discount-amount-preview{font-weight:800;color:#0b5ed7}

.vip-reason-row{display:grid;grid-template-columns:120px 1fr;gap:10px;align-items:end}
.vip-inline{display:flex!important;align-items:center;gap:4px;margin-top:12px;white-space:nowrap}

.installment-preview{background:#f8fbff;border:1px solid #d9e2ef;border-radius:12px;padding:12px;margin-top:10px}

.discount-breakdown{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-top:8px}
.readonly-mini{background:#f8fbff!important;font-weight:800;color:#0b5ed7}

.flexi-count-field{display:none}
.flexi-count-field.show{display:block}

.date-input{
  border:1px solid var(--line);
  border-radius:10px;
  padding:11px 13px;
  background:#fff;
  font-size:15px;
  width:100%;
  font-family:Arial, Helvetica, sans-serif;
}
.date-input::-webkit-calendar-picker-indicator{cursor:pointer;opacity:.75}

.unassigned-badge{display:inline-flex;align-items:center;border-radius:999px;padding:4px 8px;background:#fff7e6;border:1px solid #ffd591;color:#8a4b00;font-weight:700;font-size:12px}

.reenroll-list{max-height:260px;overflow:auto;border:1px solid var(--line);border-radius:12px;background:#fff}
.reenroll-item{display:flex;justify-content:space-between;gap:10px;align-items:center;padding:10px 12px;border-bottom:1px solid var(--line)}
.reenroll-item:last-child{border-bottom:0}
.reenroll-item b{display:block}
.reenroll-prev{font-size:13px;color:var(--muted)}

.accordion{border:1px solid var(--line);border-radius:16px;background:#fff;overflow:hidden;box-shadow:0 10px 35px rgba(16,32,51,.06)}
.accordion + .accordion{margin-top:16px}
.accordion summary{cursor:pointer;list-style:none;padding:18px 22px;font-size:20px;font-weight:800;display:flex;justify-content:space-between;align-items:center}
.accordion summary::-webkit-details-marker{display:none}
.accordion summary:after{content:"⌄";font-size:22px;color:var(--muted)}
.accordion[open] summary:after{content:"⌃"}
.accordion-body{padding:0 22px 22px}

.receipt-search-row{display:grid;grid-template-columns:1.2fr 1fr 1fr 1fr;gap:10px;align-items:end}
.receipt-date-pair{display:flex;gap:10px}
.receipt-preview-modal{position:fixed;inset:0;background:rgba(0,0,0,.35);display:none;align-items:center;justify-content:center;z-index:100;padding:20px}
.receipt-preview-card{background:#fff;border-radius:18px;box-shadow:0 24px 80px rgba(16,32,51,.25);width:620px;max-width:96%;padding:26px;border:1px solid var(--line)}
.receipt-mini{border:1px solid var(--line);border-radius:14px;padding:18px;background:#fff}
.receipt-mini h2{text-align:center;margin-top:0}
@media(max-width:900px){.receipt-search-row{grid-template-columns:1fr}.receipt-date-pair{display:grid;grid-template-columns:1fr 1fr}}

.live-search-help{font-size:12px;color:var(--muted);margin-top:6px}
.receipt-row-hidden{display:none!important}

/* Student ERP card */
.student-hero{display:flex;justify-content:space-between;gap:16px;align-items:flex-start;margin-bottom:18px}
.student-title h1{margin:0 0 6px;font-size:30px;letter-spacing:.2px}
.student-meta{color:var(--muted);font-weight:600}
.vip-pill{display:inline-flex;align-items:center;gap:6px;background:#fff1f4;color:#c1121f;border:1px solid #ffc9d2;border-radius:999px;padding:6px 12px;font-weight:800;margin-left:10px}
.student-actions{display:flex;gap:10px;flex-wrap:wrap;justify-content:flex-end}
.kpi-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:14px;margin-bottom:16px}
.kpi-card{display:flex;align-items:center;gap:15px;padding:18px;border-radius:16px;background:#fff;border:1px solid var(--line);box-shadow:0 10px 30px rgba(16,32,51,.06)}
.kpi-icon{width:54px;height:54px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:26px;background:#eef6ff}
.kpi-card .label{color:var(--muted);font-size:14px;font-weight:700}
.kpi-card .value{font-size:24px;font-weight:900;margin-top:3px}
.student-grid-2{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:16px}
.info-card{background:#fff;border:1px solid var(--line);border-radius:16px;box-shadow:0 10px 30px rgba(16,32,51,.06);padding:18px}
.info-card h2{margin:0 0 14px;font-size:18px}
.info-two-cols{display:grid;grid-template-columns:1fr 1fr;gap:14px 28px}
.info-item{display:flex;gap:10px;align-items:flex-start;border-bottom:1px solid #edf2f7;padding:9px 0}
.info-item:last-child{border-bottom:0}
.info-item .ico{font-size:18px;min-width:24px}
.info-item .cap{font-size:12px;color:var(--muted);font-weight:700}
.info-item .val{font-size:15px;font-weight:800;margin-top:2px}
.fin-row{display:grid;grid-template-columns:1fr auto;border:1px solid var(--line);border-radius:10px;padding:10px 12px;margin-bottom:8px;background:#fbfcfe}
.fin-row span{color:var(--muted);font-weight:700}
.fin-row b{font-weight:900}
.comments-view{background:#fff;border:1px solid var(--line);border-radius:16px;padding:16px;margin-bottom:16px}
.student-bottom{display:grid;grid-template-columns:1fr 1fr .7fr;gap:16px;align-items:start}
.mini-panel{background:#fff;border:1px solid var(--line);border-radius:16px;box-shadow:0 10px 30px rgba(16,32,51,.06);overflow:hidden}
.mini-panel-head{display:flex;justify-content:space-between;align-items:center;padding:14px 16px;border-bottom:1px solid var(--line);font-weight:900}
.mini-panel-body{padding:0}
.mini-panel table{font-size:13px}
.mini-panel th,.mini-panel td{padding:9px 10px}
.side-stack{display:grid;gap:12px}
.side-info{background:#fff;border:1px solid var(--line);border-radius:16px;padding:16px;display:flex;gap:12px;align-items:center;box-shadow:0 10px 30px rgba(16,32,51,.06)}
.side-info .round{width:50px;height:50px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:23px;background:#eef6ff}
.progress-bar{height:10px;background:#e8eef6;border-radius:999px;overflow:hidden;margin-top:8px}
.progress-bar span{display:block;height:100%;background:#f59e0b;border-radius:999px}
@media(max-width:1200px){.kpi-grid{grid-template-columns:repeat(2,1fr)}.student-grid-2,.student-bottom{grid-template-columns:1fr}.student-hero{flex-direction:column}.student-actions{justify-content:flex-start}}

.student-bottom-combined{display:grid;grid-template-columns:1.45fr .55fr;gap:16px;align-items:start}
@media(max-width:1200px){.student-bottom-combined{grid-template-columns:1fr}}

/* Student payments / receipts polished card */
.student-pay-card{background:#fff;border:1px solid var(--line);border-radius:16px;box-shadow:0 10px 30px rgba(16,32,51,.06);overflow:hidden}
.student-pay-head{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:16px 18px;border-bottom:1px solid var(--line);background:#fff}
.student-pay-title{display:flex;align-items:center;gap:10px;font-size:18px;font-weight:900;color:var(--text)}
.student-pay-title .icon{font-size:22px;color:#7c6fd6}
.student-pay-new{display:inline-flex;align-items:center;gap:8px;background:#16a34a;color:#fff!important;border:0;border-radius:9px;padding:9px 14px;font-weight:800;text-decoration:none;box-shadow:0 6px 16px rgba(22,163,74,.22)}
.student-pay-new:hover{filter:brightness(.97)}
.student-pay-table{width:100%;border-collapse:collapse;font-size:14px}
.student-pay-table thead th{background:#fbfcfe;color:#102033;font-weight:900;padding:13px 14px;border-bottom:1px solid var(--line);text-align:left}
.student-pay-table tbody td{padding:12px 14px;border-bottom:1px solid var(--line);vertical-align:middle}
.student-pay-table tbody tr:last-child td{border-bottom:0}
.student-pay-print{display:inline-flex;align-items:center;justify-content:center;gap:6px;background:#0d6efd;color:#fff!important;border-radius:8px;border:0;padding:7px 11px;font-size:13px;font-weight:800;text-decoration:none;box-shadow:0 4px 12px rgba(13,110,253,.20);white-space:nowrap}
.student-pay-print:hover{filter:brightness(.96)}
.student-pay-footer{display:flex;justify-content:center;border-top:1px solid var(--line);padding:10px 14px;background:#fbfcfe}
.student-pay-more{font-weight:800;color:#0d6efd;text-decoration:none}
.student-pay-wrap{display:grid;grid-template-columns:1.45fr .55fr;gap:16px;align-items:start}
@media(max-width:1200px){.student-pay-wrap{grid-template-columns:1fr}.student-pay-head{flex-direction:column;align-items:flex-start}.student-pay-new{width:100%;justify-content:center}}

.installment-label{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-width:34px;
  padding:4px 8px;
  border-radius:999px;
  background:#fff7e6;
  color:#9a5b00;
  font-weight:900;
  font-size:12px;
  border:1px solid #ffd591;
}

/* v64 - Financials: smaller summary numbers, safe CSS only */
.financials-compact .metric{
  padding:16px 18px!important;
  min-height:112px;
}
.financials-compact .metric .label{
  font-size:14px!important;
  line-height:1.25!important;
  color:#667085;
}
.financials-compact .metric .value{
  font-size:28px!important;
  line-height:1.12!important;
  letter-spacing:-0.4px;
  font-weight:800!important;
  margin-top:10px!important;
}
.financials-compact .metric .small-note{
  font-size:13px!important;
  margin-top:4px!important;
}
.quick-date-active{
  border:2px solid #0d6efd!important;
  background:#eaf3ff!important;
  color:#0d47a1!important;
  box-shadow:0 0 0 3px rgba(13,110,253,.12);
}
@media (max-width:1200px){
  .financials-compact .metric .value{font-size:24px!important;}
}

/* v65 - Force smaller KPI numbers in Financials */
.card.metric .value{
  font-size:26px!important;
  line-height:1.1!important;
  font-weight:800!important;
  letter-spacing:-0.3px!important;
}
.card.metric .label{
  font-size:13px!important;
  line-height:1.25!important;
}
.card.metric{
  padding:16px 18px!important;
  min-height:104px!important;
}

/* Extra-safe targeting for the financial KPI grid */
.grid.cols-4 .card.metric .value,
.grid.cols-3 .card.metric .value{
  font-size:26px!important;
}
.grid.cols-4 .card.metric .label,
.grid.cols-3 .card.metric .label{
  font-size:13px!important;
}

@media(max-width:1200px){
  .card.metric .value,
  .grid.cols-4 .card.metric .value,
  .grid.cols-3 .card.metric .value{
    font-size:23px!important;
  }
}

/* v66 - Exact Financial KPI sizing */
.financial-kpi{
  padding:14px 18px!important;
  min-height:96px!important;
}
.financial-kpi .label{
  font-size:13px!important;
  line-height:1.2!important;
  font-weight:600!important;
}
.financial-kpi .value{
  font-size:24px!important;
  line-height:1.05!important;
  font-weight:800!important;
  letter-spacing:-0.3px!important;
  margin-top:8px!important;
}
.financial-kpi .small-note{
  font-size:12px!important;
}

/* v72 Dashboard registration widgets */
.dashboard-reg-card{cursor:pointer;transition:.15s ease}
.dashboard-reg-card:hover{transform:translateY(-2px);box-shadow:0 14px 34px rgba(16,32,51,.10)}
.dashboard-date-card .date-row{display:flex;gap:10px;align-items:center;flex-wrap:wrap}
.dashboard-date-card input{max-width:220px}
.dashboard-reg-list{margin-top:14px;border-top:1px solid var(--line)}
.dashboard-reg-item{display:grid;grid-template-columns:1fr auto auto;gap:12px;align-items:center;padding:11px 0;border-bottom:1px solid var(--line)}
.dashboard-reg-item b{font-size:14px}
.dashboard-reg-item span{font-size:13px;color:var(--muted)}
.dashboard-empty{color:var(--muted);padding:14px 0}

/* v73 Dashboard quick actions */
.dashboard-actions-grid{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:16px;
}
.dashboard-action{
  display:flex;
  align-items:center;
  justify-content:center;
  gap:10px;
  min-height:86px;
  border-radius:16px;
  font-size:18px;
  font-weight:900;
  text-decoration:none;
  box-shadow:0 10px 28px rgba(16,32,51,.08);
}
.dashboard-action.pay{background:#eaf8ef;color:#157347;border:1px solid #b7ebc6}
.dashboard-action.new{background:#eaf3ff;color:#0d47a1;border:1px solid #b6d7ff}
.dashboard-action.re{background:#fff7e6;color:#9a5b00;border:1px solid #ffd591}
@media(max-width:900px){.dashboard-actions-grid{grid-template-columns:1fr}}

/* v74 Dashboard period selector */
.dashboard-period-card{
  display:flex;
  align-items:end;
  justify-content:space-between;
  gap:14px;
  flex-wrap:wrap;
}
.dashboard-period-fields{
  display:flex;
  gap:12px;
  flex-wrap:wrap;
  align-items:end;
}
.dashboard-period-fields .form-row{
  min-width:190px;
}
.dashboard-period-label{
  font-size:13px;
  color:var(--muted);
  font-weight:700;
  margin-bottom:6px;
}
.dashboard-active-period{
  font-weight:900;
  color:#073763;
  background:#eaf3ff;
  border:1px solid #b6d7ff;
  border-radius:999px;
  padding:8px 12px;
}

/* v76 Dashboard direct reenroll modal */
.reenroll-modal-backdrop{
  position:fixed;
  inset:0;
  background:rgba(15,23,42,.42);
  z-index:2000;
  display:none;
  align-items:center;
  justify-content:center;
  padding:24px;
}
.reenroll-modal{
  width:min(940px,96vw);
  max-height:86vh;
  overflow:hidden;
  background:#fff;
  border:1px solid var(--line);
  border-radius:22px;
  box-shadow:0 30px 90px rgba(15,23,42,.28);
  padding:28px;
}
.reenroll-modal-head{
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:16px;
  margin-bottom:20px;
}
.reenroll-modal-head h2{
  margin:0;
  font-size:30px;
}
.reenroll-close{
  border:0;
  background:#fff;
  font-size:30px;
  font-weight:900;
  cursor:pointer;
  line-height:1;
}
.reenroll-modal-note{
  color:var(--muted);
  font-size:17px;
  margin-bottom:18px;
}
.reenroll-search{
  width:min(320px,100%);
  margin-bottom:22px;
}
.reenroll-search input{
  font-size:18px;
  padding:14px 16px;
  border-radius:12px;
}
.reenroll-modal-list{
  border:1px solid var(--line);
  border-radius:14px;
  max-height:420px;
  overflow:auto;
}
.reenroll-modal-row{
  display:grid;
  grid-template-columns:1fr auto;
  gap:18px;
  align-items:center;
  padding:18px 16px;
  border-bottom:1px solid var(--line);
}
.reenroll-modal-row:last-child{border-bottom:0}
.reenroll-modal-row b{
  font-size:20px;
  letter-spacing:.2px;
}
.reenroll-modal-row .prev{
  display:block;
  color:var(--muted);
  font-size:16px;
  margin-top:6px;
}
.reenroll-select-btn{
  background:#0d6efd;
  color:#fff!important;
  border:0;
  border-radius:12px;
  padding:14px 22px;
  font-size:18px;
  font-weight:900;
  text-decoration:none;
}
.reenroll-empty{
  padding:18px;
  color:var(--muted);
}
@media(max-width:700px){
  .reenroll-modal{padding:20px}
  .reenroll-modal-row{grid-template-columns:1fr}
  .reenroll-select-btn{text-align:center}
}

/* v82 login card */
.login-page{
  min-height:100vh;
  margin:0;
  background:linear-gradient(135deg,#547796,#b7c9d8);
  display:flex;
  align-items:center;
  justify-content:center;
}
.login-shell{
  width:min(620px,92vw);
}
.login-card{
  background:#fff;
  border:1px solid #d8e3ef;
  border-radius:22px;
  box-shadow:0 28px 80px rgba(15,23,42,.18);
  padding:42px;
}
.login-brand{
  display:flex;
  align-items:center;
  gap:18px;
  margin-bottom:34px;
}
.pin-logo{
  font-size:46px;
}
.brand-title{
  font-size:40px;
  line-height:1;
  font-weight:900;
  color:#073763;
}
.brand-subtitle{
  font-size:18px;
  color:#073763;
  margin-top:10px;
}
.login-card h1{
  font-size:38px;
  margin:0 0 28px;
  color:#102033;
}
.login-card .form-row{
  margin-bottom:18px;
}
.login-card label{
  display:block;
  font-size:16px;
  font-weight:700;
  color:#667085;
  margin-bottom:8px;
}
.login-card input{
  height:54px;
  font-size:18px;
  border-radius:14px;
}
.login-btn{
  width:100%;
  height:56px;
  font-size:20px;
  border-radius:14px;
  margin-top:10px;
}
.login-note{
  color:#667085;
  font-size:16px;
  line-height:1.35;
  margin:22px 0 0;
}
.login-error{
  background:#fff1f1;
  color:#dc2626;
  border:1px solid #ffc9c9;
  border-radius:12px;
  padding:12px 14px;
  font-weight:800;
  margin-top:14px;
}

/* v83 compact login */
.login-shell{
  width:min(480px,90vw)!important;
}
.login-card{
  padding:28px!important;
  border-radius:18px!important;
}
.login-brand{
  gap:14px!important;
  margin-bottom:24px!important;
}
.pin-logo{
  font-size:38px!important;
}
.brand-title{
  font-size:34px!important;
}
.brand-subtitle{
  font-size:15px!important;
  font-style:italic!important;
  color:#64748b!important;
  margin-top:6px!important;
}
.login-card h1{
  font-size:30px!important;
  margin:0 0 18px!important;
}
.login-card .form-row{
  margin-bottom:14px!important;
}
.login-card label{
  font-size:14px!important;
  margin-bottom:6px!important;
}
.login-card input{
  height:48px!important;
  font-size:16px!important;
  border-radius:12px!important;
}
.login-btn{
  height:50px!important;
  font-size:18px!important;
  border-radius:12px!important;
  margin-top:8px!important;
}
.login-note{
  font-size:13px!important;
  margin-top:16px!important;
}

/* v84 Settings system */
.settings-page{display:grid;gap:18px}
.settings-accordion{background:#fff;border:1px solid var(--line);border-radius:16px;box-shadow:0 10px 28px rgba(16,32,51,.06);overflow:hidden}
.settings-head{display:flex;justify-content:space-between;align-items:center;gap:12px;padding:18px 20px;cursor:pointer;background:#fbfcfe}
.settings-head h2{margin:0;font-size:18px}
.settings-body{padding:18px 20px;border-top:1px solid var(--line);display:none}
.settings-accordion.open .settings-body{display:block}
.settings-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px}
.settings-grid-3{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:14px}
.settings-row{display:flex;gap:10px;align-items:end;flex-wrap:wrap}
.settings-danger{border:1px solid #ffc9c9;background:#fff7f7;border-radius:14px;padding:16px}
.settings-danger h3{color:#b42318;margin:0 0 8px}
.settings-danger .btn-danger{background:#dc2626;color:#fff;border:0}
.settings-note{font-size:13px;color:var(--muted);line-height:1.4}
.settings-pill{display:inline-flex;align-items:center;gap:8px;border-radius:999px;padding:8px 12px;background:#eaf3ff;border:1px solid #b6d7ff;font-weight:900;color:#073763}
.settings-admin-only{border:1px solid #ffd591;background:#fffaf0;border-radius:14px;padding:16px}
.settings-table th,.settings-table td{font-size:13px;padding:9px 10px}
.settings-cloud-url{font-family:monospace;font-size:12px;color:#475467}
@media(max-width:900px){.settings-grid,.settings-grid-3{grid-template-columns:1fr}}

/* v85 reset modal and admin/user settings */
.settings-page{display:grid;gap:18px}
.settings-accordion{background:#fff;border:1px solid var(--line);border-radius:16px;box-shadow:0 10px 28px rgba(16,32,51,.06);overflow:hidden}
.settings-head{display:flex;justify-content:space-between;align-items:center;gap:12px;padding:18px 20px;cursor:pointer;background:#fbfcfe}
.settings-head h2{margin:0;font-size:18px}
.settings-body{padding:18px 20px;border-top:1px solid var(--line);display:none}
.settings-accordion.open .settings-body{display:block}
.settings-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px}
.settings-grid-3{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:14px}
.settings-row{display:flex;gap:10px;align-items:end;flex-wrap:wrap}
.settings-note{font-size:13px;color:var(--muted);line-height:1.4}
.settings-pill{display:inline-flex;align-items:center;gap:8px;border-radius:999px;padding:8px 12px;background:#eaf3ff;border:1px solid #b6d7ff;font-weight:900;color:#073763}
.settings-danger{border:1px solid #ffc9c9;background:#fff7f7;border-radius:14px;padding:16px}
.settings-danger h3{color:#b42318;margin:0 0 8px}
.settings-danger .btn-danger{background:#dc2626;color:#fff;border:0}
.settings-danger.user-reset{border-color:#ffd591;background:#fffaf0}.settings-danger.user-reset h3{color:#9a5b00}.settings-danger.user-reset .btn-danger{background:#b7791f}
.settings-admin-only{border:1px solid #ffd591;background:#fffaf0;border-radius:14px;padding:16px}
.settings-table th,.settings-table td{font-size:13px;padding:9px 10px}
.reset-modal-backdrop{position:fixed;inset:0;background:rgba(15,23,42,.48);z-index:5000;display:none;align-items:center;justify-content:center;padding:24px}
.reset-modal-card{width:min(620px,94vw);background:#fff;border:1px solid #ffc9c9;border-radius:20px;box-shadow:0 30px 90px rgba(15,23,42,.32);padding:28px}
.reset-modal-card h2{margin:0 0 12px;color:#b42318;font-size:28px}
.reset-modal-card p{color:#475467;line-height:1.45}
.reset-scope-badge{display:inline-flex;align-items:center;gap:8px;background:#fff1f1;border:1px solid #ffc9c9;color:#b42318;font-weight:900;border-radius:999px;padding:8px 12px;margin:10px 0 16px}
.reset-key{display:inline-flex;align-items:center;justify-content:center;width:42px;height:42px;border-radius:10px;background:#111827;color:#fff;font-size:22px;font-weight:900;margin:0 6px}
.hidden-pin-reset{position:fixed;left:18px;top:18px;width:70px;height:70px;opacity:0;cursor:default;z-index:9999}
@media(max-width:900px){.settings-grid,.settings-grid-3{grid-template-columns:1fr}}

/* v88 settings delete X */
.delete-x-btn{
  width:34px;
  height:34px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  border-radius:999px;
  border:1px solid #ffc9c9;
  background:#fff1f1;
  color:#dc2626;
  font-size:22px;
  font-weight:900;
  line-height:1;
  cursor:pointer;
}
.delete-x-btn:hover{
  background:#dc2626;
  color:#fff;
}

/* v101 VIP stealth and logo reset */
.hidden-logo-reset{
  position:fixed;
  left:70px;
  top:14px;
  width:150px;
  height:54px;
  opacity:0;
  cursor:default;
  z-index:9999;
}
.vip-hidden .pin-logo,
.vip-hidden .brand-pin,
.vip-hidden .logo-pin,
.vip-hidden .recall-pin{
  filter:hue-rotate(95deg) saturate(1.8) brightness(.95);
}

/* v102 hidden tools */
.reset-modal-backdrop{position:fixed;inset:0;background:rgba(15,23,42,.48);z-index:5000;display:none;align-items:center;justify-content:center;padding:24px}
.reset-modal-card{width:min(620px,94vw);background:#fff;border:1px solid #ffc9c9;border-radius:20px;box-shadow:0 30px 90px rgba(15,23,42,.32);padding:28px}
.reset-modal-card h2{margin:0 0 12px;color:#b42318;font-size:28px}
.reset-scope-badge{display:inline-flex;background:#fff1f1;border:1px solid #ffc9c9;color:#b42318;font-weight:900;border-radius:999px;padding:8px 12px;margin:10px 0 16px}
.reset-key{display:inline-flex;align-items:center;justify-content:center;width:42px;height:42px;border-radius:10px;background:#111827;color:#fff;font-size:22px;font-weight:900;margin:0 6px}
.vip-hidden .pin-logo,.vip-hidden .brand-pin,.vip-hidden .logo-pin,.vip-hidden .recall-pin{
  display:inline-flex!important;
  visibility:visible!important;
  opacity:1!important;
  filter:hue-rotate(95deg) saturate(2.2) brightness(1.05)!important;
}

/* v103 fixes */
.pin-logo,.brand-pin,.logo-pin,.recall-pin{
  display:inline-flex!important;
  visibility:visible!important;
  opacity:1!important;
  cursor:default!important;
}
.vip-hidden .pin-logo,.vip-hidden .brand-pin,.vip-hidden .logo-pin,.vip-hidden .recall-pin{
  display:inline-flex!important;
  visibility:visible!important;
  opacity:1!important;
  filter:hue-rotate(95deg) saturate(2.2) brightness(1.05)!important;
  cursor:default!important;
}
.brand-title,.logo-title,.app-title{
  cursor:default!important;
}

/* v104 VIP UI hide + logo reset hotspot */
.pin-logo,.brand-pin,.logo-pin,.recall-pin,
.brand-title,.logo-title,.app-title{
  cursor:default!important;
}
.pin-logo[title],.brand-pin[title],.logo-pin[title],.recall-pin[title]{
  pointer-events:auto;
}
.vip-hidden .pin-logo,
.vip-hidden .brand-pin,
.vip-hidden .logo-pin,
.vip-hidden .recall-pin{
  display:inline-flex!important;
  visibility:visible!important;
  opacity:1!important;
  filter:hue-rotate(95deg) saturate(2.2) brightness(1.05)!important;
}

/* v105 safe hidden tools */
.pin-logo,.brand-pin,.logo-pin,.recall-pin,.brand-title,.logo-title,.app-title{
  cursor:default!important;
}
.vip-hidden .pin-logo,.vip-hidden .brand-pin,.vip-hidden .logo-pin,.vip-hidden .recall-pin{
  display:inline-flex!important;
  visibility:visible!important;
  opacity:1!important;
  filter:hue-rotate(95deg) saturate(2.2) brightness(1.05)!important;
}
.reset-modal-backdrop{position:fixed;inset:0;background:rgba(15,23,42,.48);z-index:5000;display:none;align-items:center;justify-content:center;padding:24px}
.reset-modal-card{width:min(620px,94vw);background:#fff;border:1px solid #ffc9c9;border-radius:20px;box-shadow:0 30px 90px rgba(15,23,42,.32);padding:28px}
.reset-modal-card h2{margin:0 0 12px;color:#b42318;font-size:28px}
.reset-scope-badge{display:inline-flex;background:#fff1f1;border:1px solid #ffc9c9;color:#b42318;font-weight:900;border-radius:999px;padding:8px 12px;margin:10px 0 16px}
.reset-key{display:inline-flex;align-items:center;justify-content:center;width:42px;height:42px;border-radius:10px;background:#111827;color:#fff;font-size:22px;font-weight:900;margin:0 6px}

/* v106 invisible hotspot exactly over the ReCall logo text */
#recallLogoResetHotspot{
  position:fixed;
  left:86px;
  top:30px;
  width:205px;
  height:76px;
  opacity:0;
  background:transparent;
  border:0;
  padding:0;
  margin:0;
  z-index:99999;
  cursor:default!important;
}
#recallLogoResetHotspot:hover,
#recallLogoResetHotspot:focus{
  cursor:default!important;
  outline:none!important;
}
