@import url('assets/colors_and_type.css');
@import url('https://fonts.googleapis.com/css2?family=Outfit:wght@400;600;800&display=swap');

*{box-sizing:border-box}
html,body{margin:0;background:#f4f6fa;color:var(--fg);font-family:var(--font-sans);min-height:100%}
body{font-size:14px;line-height:1.5}

.app{min-height:100vh;display:flex;flex-direction:column}
.container{max-width:1400px;margin:0 auto;padding:0 24px;width:100%}

/* Nav */
.nav{position:sticky;top:0;z-index:50;height:64px;border-bottom:1px solid var(--border);background:rgba(255,255,255,.95);backdrop-filter:blur(8px)}
.nav-inner{height:100%;display:flex;align-items:center;gap:24px}
.nav-brand{display:flex;align-items:center;gap:10px;flex-shrink:0}
.nav-brand img{width:32px;height:32px;object-fit:contain}
.nav-brand .wm{font-family:var(--font-logo);font-weight:800;font-size:18px;letter-spacing:-.015em;color:var(--fg)}
.nav-brand .sep{width:1px;height:18px;background:var(--border);margin:0 2px}
.nav-brand .sub{font-size:13px;color:var(--muted-fg);font-weight:600}
.nav-links{display:flex;gap:4px;margin-left:16px}
.nav-links a{padding:8px 12px;border-radius:6px;font-size:13px;font-weight:600;color:var(--muted-fg);text-decoration:none;cursor:pointer;transition:var(--transition-smooth)}
.nav-links a.active{background:rgba(29,79,215,.12);color:var(--link)}
.nav-links a:hover:not(.active){background:var(--muted);color:var(--fg)}
.nav-right{margin-left:auto;display:flex;gap:10px;align-items:center;font-size:12px;color:var(--muted-fg);position:relative}

/* Date range picker */
.date-picker{position:relative}
.date-trigger{display:inline-flex;align-items:center;gap:10px;padding:10px 16px;border-radius:4px;border:1px solid var(--border);background:#fff;font-family:var(--font-sans);font-size:13px;font-weight:600;color:var(--fg);cursor:pointer;transition:var(--transition-smooth);font-variant-numeric:tabular-nums;letter-spacing:-.01em}
.date-trigger:hover{border-color:var(--primary);color:var(--primary)}
.date-trigger.open{border-color:var(--primary);color:var(--primary);box-shadow:var(--shadow-glow)}
.date-trigger .cal{color:var(--primary)}
.date-trigger .chev{color:var(--muted-fg);transition:transform .15s;margin-left:2px}
.date-trigger.open .chev{transform:rotate(180deg);color:var(--primary)}

.date-panel{position:absolute;top:calc(100% + 8px);right:0;z-index:100;background:#fff;border:1px solid var(--border);border-radius:4px;box-shadow:var(--shadow-lg);display:grid;grid-template-columns:148px 320px;width:468px;overflow:hidden;font-family:var(--font-sans)}
.date-presets{border-right:1px solid var(--border);background:#f8fafc;padding:8px 0;display:flex;flex-direction:column;gap:1px}
.date-presets .preset{text-align:left;padding:9px 16px;font-family:var(--font-sans);font-size:13px;font-weight:600;color:var(--muted-fg);background:transparent;border:none;border-left:2px solid transparent;cursor:pointer;transition:var(--transition-smooth);letter-spacing:-.01em}
.date-presets .preset:hover{background:var(--muted);color:var(--fg)}
.date-presets .preset.active{background:rgba(29,79,215,.10);color:var(--link);border-left-color:var(--primary)}

.date-body{padding:18px 18px 14px;display:flex;flex-direction:column;gap:14px}
.date-body .hdr{font-size:11px;font-weight:700;color:var(--muted-fg);letter-spacing:.08em;text-transform:uppercase}
.date-field{display:flex;flex-direction:column;gap:6px;flex:1;min-width:0}
.date-field label{font-size:11px;font-weight:700;color:var(--muted-fg);letter-spacing:.04em;text-transform:uppercase}
.date-inputs{display:grid;grid-template-columns:1fr 12px 1fr;align-items:end;gap:10px}
.date-inputs input[type=date]{padding:9px 10px;border:1px solid var(--border);border-radius:4px;font-family:var(--font-sans);font-size:13px;font-weight:600;color:var(--fg);font-variant-numeric:tabular-nums;background:#fff;width:100%;letter-spacing:-.01em}
.date-inputs input[type=date]:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px rgba(29,79,215,.12)}
.date-inputs input[type=date]::-webkit-calendar-picker-indicator{cursor:pointer;opacity:.6;filter:invert(18%) sepia(83%) saturate(1683%) hue-rotate(210deg) brightness(.9)}
.date-inputs .dash{align-self:end;padding-bottom:10px;color:var(--muted-fg);font-weight:700;text-align:center}

.date-summary{padding:10px 12px;background:var(--muted);border-radius:4px;font-family:var(--font-sans);font-size:12px;color:var(--muted-fg);font-variant-numeric:tabular-nums;letter-spacing:-.01em;display:flex;align-items:center;gap:6px}
.date-summary .days{color:var(--primary);font-weight:800;font-size:13px}
.date-summary .rng{color:var(--fg);font-weight:600}
.date-actions{display:flex;gap:8px;justify-content:flex-end;padding-top:4px;border-top:1px solid var(--border);margin-top:2px;padding-top:12px}
.date-actions .btn{padding:8px 16px;font-size:13px}
.btn{display:inline-flex;align-items:center;gap:6px;padding:8px 14px;border-radius:4px;border:1px solid var(--border);background:#fff;font-size:12px;font-weight:600;color:var(--muted-fg);cursor:pointer;transition:var(--transition-smooth);font-family:inherit}
.btn:hover{border-color:var(--primary);color:var(--primary)}
.btn.primary{background:var(--primary);color:#fff;border-color:var(--primary)}
.btn.primary:hover{background:var(--primary-dark);color:#fff}

/* Page head */
.page-head{padding:32px 0 20px;display:flex;justify-content:space-between;align-items:flex-end;gap:24px;flex-wrap:wrap}
.page-head .ov{font-size:11px;font-weight:700;letter-spacing:.12em;color:var(--primary);text-transform:uppercase;margin-bottom:6px}
.page-head h1{font-size:32px;font-weight:900;letter-spacing:-.02em;margin-bottom:6px}
.page-head .domain{font-family:var(--font-logo);font-weight:600;color:var(--muted-fg)}
.page-head p{color:var(--muted-fg);font-size:6pt;letter-spacing:-.01em}
.page-head .range{display:flex;align-items:center;gap:10px;padding:10px 16px;background:#fff;border:1px solid var(--border);border-radius:4px;font-weight:600;font-size:13px;color:var(--fg);font-variant-numeric:tabular-nums}
.page-head .range i{color:var(--primary)}

/* Summary grid */
.metric-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-bottom:24px}
@media(max-width:900px){.metric-grid{grid-template-columns:repeat(2,1fr)}}
.metric-card{background:#fff;border:1px solid var(--border);border-radius:4px;padding:20px 22px;box-shadow:var(--shadow-sm);position:relative;overflow:hidden}
.metric-card .m-top{display:flex;justify-content:space-between;align-items:center;margin-bottom:14px}
.metric-card .m-title{font-size:12px;font-weight:700;color:var(--muted-fg);letter-spacing:.02em}
.metric-card .m-icon{width:32px;height:32px;border-radius:4px;background:rgba(29,79,215,.08);color:var(--primary);display:inline-flex;align-items:center;justify-content:center}
.metric-card .m-icon.g{background:rgba(0,69,22,.08);color:var(--success)}
.metric-card .m-icon.a{background:rgba(251,191,36,.15);color:#9a6f00}
.metric-card .m-icon.r{background:rgba(199,57,79,.08);color:var(--danger)}
.metric-card .m-value{font-size:32px;font-weight:800;letter-spacing:-.02em;font-variant-numeric:tabular-nums;line-height:1.05;color:var(--fg)}
.metric-card .m-value .unit{font-size:16px;font-weight:700;color:var(--muted-fg);margin-left:2px}
.metric-card .m-foot{display:flex;justify-content:space-between;align-items:center;margin-top:14px;font-size:12px;color:var(--muted-fg);padding-top:12px;border-top:1px dashed var(--border)}
.metric-card .m-foot b{color:var(--fg);font-weight:700;font-variant-numeric:tabular-nums}

/* Two-col */
.split{display:grid;grid-template-columns:1.35fr 1fr;gap:14px;margin-bottom:14px}
@media(max-width:1100px){.split{grid-template-columns:1fr}}

/* Panel */
.panel{background:#fff;border:1px solid var(--border);border-radius:4px;box-shadow:var(--shadow-sm);overflow:hidden;display:flex;flex-direction:column}
.panel-head{padding:18px 22px 14px;border-bottom:1px solid var(--border);display:flex;justify-content:space-between;align-items:flex-start;gap:12px;flex-wrap:wrap}
.panel-head h3{font-size:15px;font-weight:800;letter-spacing:-.01em;margin-bottom:2px}
.panel-head .sub{font-size:12px;color:var(--muted-fg)}
.panel-head .legend{display:flex;gap:14px;font-size:11px;color:var(--muted-fg);font-weight:600}
.panel-head .legend span{display:inline-flex;align-items:center;gap:6px}
.panel-head .legend i{width:10px;height:10px;border-radius:1px;display:inline-block}
.panel-body{padding:22px}
/* Charts fill the panel edge-to-edge */
.panel-body > svg{width:100%;display:block}

/* Cap chart text size on wide screens.
   SVG text scales with viewBox by default; CSS font-size in px
   overrides that and keeps a pixel-based max regardless of width. */
@media(min-width:900px){
  .panel-body > svg text{font-size:13px}
  .panel-body > svg text.big,
  .panel-body > svg text[data-role="total"]{font-size:20px}
  .panel-body > svg text[data-role="small"]{font-size:11px}
}

/* Daily chart */
.daychart{position:relative}
.daychart .axis-y text{font-size:12px;fill:var(--muted-fg);font-variant-numeric:tabular-nums}
.daychart .axis-x text{font-size:13px;fill:var(--muted-fg);font-weight:600}
.daychart .axis-x .dow{font-size:12px;fill:var(--muted-fg);font-weight:400}
.daychart .gridline{stroke:#eef1f5;stroke-width:1}
.daychart .bar-hits{fill:var(--chart-1);transition:fill .2s}
.daychart .bar-visits{fill:var(--primary);transition:fill .2s}
.daychart g.bar:hover .bar-hits{fill:#002a55}
.daychart g.bar:hover .bar-visits{fill:#1839a3}
.daychart .line-ip{fill:none;stroke:var(--accent);stroke-width:2}
.daychart .dot-ip{fill:#fff;stroke:var(--accent);stroke-width:2}
.daychart .val-lbl{font-size:12px;font-weight:700;fill:var(--fg);font-variant-numeric:tabular-nums;text-anchor:middle}

/* Country list */
.country-list{display:flex;flex-direction:column}
.country-row{display:grid;grid-template-columns:28px 28px 1fr auto auto;gap:12px;align-items:center;padding:10px 22px;border-bottom:1px solid var(--border);font-size:13px}
.country-row:last-child{border-bottom:none}
.country-row:hover{background:rgba(0,61,122,.03)}
.country-row .rank{color:var(--muted-fg);font-weight:700;font-variant-numeric:tabular-nums;text-align:center}
.country-row .rank.top{color:var(--primary)}
.country-row .flag{width:26px;height:18px;border-radius:2px;overflow:hidden;display:inline-flex;align-items:center;justify-content:center;background:#f1f3f7;border:1px solid var(--border);font-size:9px;font-weight:700;color:var(--muted-fg);font-family:var(--font-logo)}
.country-row .name{font-weight:600;color:var(--fg)}
.country-row .name .cc{color:var(--muted-fg);font-weight:500;margin-left:6px;font-family:var(--font-logo);font-size:11px}
.country-row .bar{width:140px;height:6px;background:#eef1f5;border-radius:2px;overflow:hidden;position:relative}
.country-row .bar-fill{position:absolute;inset:0 auto 0 0;background:var(--primary);border-radius:2px}
.country-row .hits{font-weight:800;font-variant-numeric:tabular-nums;color:var(--fg);min-width:54px;text-align:right}
.country-row .pct{font-weight:600;color:var(--muted-fg);font-variant-numeric:tabular-nums;min-width:48px;text-align:right;font-size:12px}

.country-tail{padding:14px 22px;background:var(--muted);border-top:1px solid var(--border);font-size:12px;color:var(--muted-fg);display:flex;justify-content:space-between;align-items:center}
.country-tail b{color:var(--fg);font-weight:700;font-variant-numeric:tabular-nums}

/* Heatmap table */
.heat-wrap{overflow-x:auto}
.heat-table{width:100%;border-collapse:separate;border-spacing:0;font-size:12px;font-variant-numeric:tabular-nums;table-layout:auto}
.heat-table th{position:sticky;top:0;background:#f8fafc;font-weight:700;color:var(--muted-fg);padding:10px 8px;border-bottom:1px solid var(--border);font-size:11px;text-transform:uppercase;letter-spacing:.04em}
.heat-table th.country-col{text-align:left;padding-left:22px;width:auto;min-width:160px}
.heat-table th.total-col{text-align:right;padding-right:16px;width:auto;min-width:80px}
.heat-table th.pct-col{text-align:right;padding-right:22px;width:auto;min-width:60px}
.heat-table th.day{text-align:center;width:auto}
.heat-table th.day .dow{display:block;font-size:10px;font-weight:500;text-transform:none;letter-spacing:0;color:var(--muted-fg);margin-top:2px}
.heat-table td{padding:0;border-bottom:1px solid #f1f3f7}
.heat-table td.country-cell{padding:10px 8px 10px 22px;font-weight:600;color:var(--fg);white-space:nowrap}
.heat-table td.country-cell .cc{color:var(--muted-fg);font-weight:500;margin-left:6px;font-family:var(--font-logo);font-size:11px}
.heat-table td.cell{text-align:center;padding:0}
.heat-table td.cell .v{display:block;height:38px;line-height:38px;font-weight:600;position:relative}
.heat-table td.cell.zero .v{color:#cbd4e0}
.heat-table td.total-cell{text-align:right;padding:10px 16px;font-weight:800;color:var(--fg)}
.heat-table td.pct-cell{text-align:right;padding:10px 22px;font-weight:600;color:var(--muted-fg)}
.heat-table tr:hover td.country-cell,.heat-table tr:hover td.total-cell,.heat-table tr:hover td.pct-cell{background:rgba(0,61,122,.03)}
.heat-table tfoot td{background:#f8fafc;font-weight:800;border-top:2px solid var(--border);border-bottom:none;padding:12px 8px}
.heat-table tfoot td.country-cell{color:var(--fg);padding-left:22px}
.heat-table tfoot td.total-cell{padding-right:16px}
.heat-table tfoot td.pct-cell{padding-right:22px}

/* Footer */
.site-foot{background:var(--footer-bg);color:#bcc7d6;padding:24px 0;margin-top:32px;font-size:12px}
.site-foot .container{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:12px}
.site-foot strong{color:#fff;font-weight:800}

[data-lucide]{width:14px;height:14px;stroke-width:1.75}
.btn [data-lucide]{width:14px;height:14px}
.metric-card .m-icon [data-lucide]{width:16px;height:16px}

/* Insight strip */
.insights{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin-bottom:14px}
@media(max-width:900px){.insights{grid-template-columns:1fr}}
.insight{background:#fff;border:1px solid var(--border);border-left:3px solid var(--primary);border-radius:4px;padding:14px 18px;box-shadow:var(--shadow-sm)}
.insight.g{border-left-color:var(--success)}
.insight.a{border-left-color:var(--accent)}
.insight .lbl{font-size:11px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--muted-fg);margin-bottom:4px}
.insight .msg{font-size:13px;color:var(--fg);line-height:1.45}
.insight .msg b{font-weight:800;color:var(--primary);font-variant-numeric:tabular-nums}
.insight.g .msg b{color:var(--success)}
.insight.a .msg b{color:#9a6f00}

/* ============================================================
   Mobile optimization — ≤768px tablet, ≤480px phone
   Minimum font size: 12px (except axis ticks/overlays: 11px)
   ============================================================ */
@media(max-width:768px){
  body{font-size:13px}
  .container{padding:0 16px}

  /* Nav — compact, hide secondary items, keep brand + actions */
  .nav{height:56px}
  .nav-inner{gap:10px}
  .nav-brand .sep,.nav-brand .sub{display:none}
  .nav-brand .wm{font-size:16px}
  .nav-links{display:none}
  .nav-right{gap:6px;margin-left:auto}
  .nav-right .btn{padding:8px 10px;font-size:11px;min-height:36px}
  .nav-right .btn [data-lucide]{width:14px;height:14px}

  /* Page head — stack vertically, range picker full-width */
  .page-head{padding:20px 0 16px;flex-direction:column;align-items:stretch;gap:14px}
  .page-head h1{font-size:24px}
  .page-head .ov{font-size:10px}
  .page-head p{font-size:6pt}
  .page-head .range{justify-content:center;padding:12px 16px;min-height:44px}

  /* Date picker — full-screen bottom sheet */
  .date-picker{width:100%}
  .date-trigger{width:100%;justify-content:space-between;padding:12px 14px;min-height:44px;font-size:12px}
  .date-trigger > span{flex:1;text-align:left;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
  .date-panel{
    position:fixed;inset:auto 0 0 0;top:auto;right:0;
    width:100%;max-height:85vh;grid-template-columns:1fr;
    border-radius:12px 12px 0 0;overflow-y:auto;
    box-shadow:0 -12px 40px rgba(0,0,0,.25);
    animation:sheetUp .25s ease-out
  }
  @keyframes sheetUp{from{transform:translateY(100%)}to{transform:translateY(0)}}
  .date-panel::before{
    content:'';display:block;width:40px;height:4px;border-radius:2px;
    background:#cbd4e0;margin:10px auto 4px;flex-shrink:0
  }
  .date-presets{
    flex-direction:row;flex-wrap:wrap;gap:6px;
    padding:12px 16px;border-right:none;border-bottom:1px solid var(--border);
    background:#fff
  }
  .date-presets .preset{
    padding:8px 14px;border:1px solid var(--border);border-radius:20px;
    border-left:1px solid var(--border);font-size:12px;min-height:36px
  }
  .date-presets .preset.active{
    background:var(--primary);color:#fff;border-color:var(--primary)
  }
  .date-body{padding:16px}
  .date-inputs input[type=date]{padding:12px 10px;font-size:14px;min-height:44px}
  .date-actions .btn{padding:12px 20px;font-size:14px;flex:1;justify-content:center;min-height:44px}

  /* Metrics — 2 cols on tablet, 1 on phone */
  .metric-grid{grid-template-columns:repeat(2,1fr);gap:10px;margin-bottom:16px}
  .metric-card{padding:14px 16px}
  .metric-card .m-title{font-size:12px}
  .metric-card .m-value{font-size:24px}
  .metric-card .m-value .unit{font-size:13px}
  .metric-card .m-foot{font-size:12px;flex-direction:column;align-items:flex-start;gap:4px;margin-top:10px;padding-top:10px}

  /* Insights — single column */
  .insights{grid-template-columns:1fr;gap:10px;margin-bottom:12px}
  .insight{padding:12px 14px}
  .insight .lbl{font-size:12px}
  .insight .msg{font-size:12px}

  /* Split layouts collapse */
  .split{grid-template-columns:1fr;gap:12px}

  /* Panels */
  .panel-head{padding:14px 16px 12px}
  .panel-head h3{font-size:14px}
  .panel-head .sub{font-size:12px}
  .panel-head .legend{font-size:12px;gap:8px;flex-wrap:wrap}
  .panel-body{padding:14px}

  /* Charts — horizontal scroll container for wide SVGs */
  .panel > .panel-body:has(> svg){overflow-x:auto;-webkit-overflow-scrolling:touch;padding:12px 10px 14px}
  .panel > .panel-body:has(> svg) > svg{min-width:720px;display:block}

  /* Country list — narrow name, fixed 2-line stats on right */
  .country-row{
    grid-template-columns:22px 24px minmax(0,1fr) 72px;gap:8px;
    padding:10px 14px;font-size:12px;align-items:center
  }
  .country-row .bar{display:none}
  .country-row .name{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;font-size:12px}
  .country-row .name .cc{display:none}
  .country-row .hits{
    grid-column:4;grid-row:1;
    font-size:12px;min-width:auto;text-align:right;line-height:1.2
  }
  .country-row .pct{
    grid-column:4;grid-row:2;
    font-size:12px;min-width:auto;text-align:right;padding:0;border:none;margin:0;line-height:1.1
  }
  .country-row .rank{grid-row:1 / span 2}
  .country-row .flag{grid-row:1 / span 2}
  .country-row .name{grid-row:1 / span 2;align-self:center}
  .country-tail{padding:12px 14px;font-size:12px}

  /* Heatmap — horizontal scroll, sticky country col */
  .heat-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch;max-width:100%}
  .heat-table{font-size:12px;min-width:640px}
  .heat-table th.country-col,
  .heat-table td.country-cell{
    position:sticky;left:0;background:#fff;z-index:2;
    width:130px;min-width:130px;padding-left:14px;padding-right:6px
  }
  .heat-table th.country-col{background:#f8fafc;z-index:3}
  .heat-table tr:hover td.country-cell{background:#f4f8ff}
  .heat-table tfoot td.country-cell{background:#f8fafc}
  .heat-table th.day{width:54px;padding:8px 4px;font-size:12px}
  .heat-table th.total-col,.heat-table td.total-cell{padding-right:10px;width:auto}
  .heat-table th.pct-col,.heat-table td.pct-cell{padding-right:14px;width:48px}
  .heat-table td.cell .v{height:32px;line-height:32px;font-size:12px}
  .heat-table td.country-cell{font-size:12px}
  .heat-table td.country-cell .cc{display:none}

  /* Footer */
  .site-foot{padding:18px 0;margin-top:20px}
  .site-foot .container{flex-direction:column;align-items:flex-start;gap:6px;font-size:12px}
}

@media(max-width:480px){
  .page-head h1{font-size:20px}
  .metric-grid{grid-template-columns:1fr}
  .metric-card{padding:16px 18px}
  .metric-card .m-value{font-size:28px}
  .metric-card .m-foot{flex-direction:row;align-items:center}

  /* Donut panel body stacks */
  .panel-body[style*="flex-wrap"]{flex-direction:column}

  .nav-right .btn span,
  .nav-right .btn:not(.primary){display:none}
  .nav-right .btn{padding:10px 12px}
  .nav-right .btn.primary{padding:10px 14px}
}

/* Login */
.login-wrap{min-height:100vh;display:flex;align-items:center;justify-content:center;background:#f4f6fa}
.login-box{background:#fff;border-radius:12px;padding:40px;width:380px;max-width:90vw;box-shadow:0 4px 24px rgba(0,0,0,.08);text-align:left}
.login-logo{width:48px;height:48px;margin-bottom:12px}
.login-box h2{margin:0 0 4px;font-size:22px;font-weight:700;color:var(--primary,#1d4fd7)}
.login-sub{color:#888;font-size:13px;margin:0 0 20px}
.login-box label{display:block;font-size:12px;font-weight:600;color:#555;margin:12px 0 4px;text-transform:uppercase;letter-spacing:.5px}
.login-box input[type="text"],
.login-box input[type="password"]{width:100%;padding:10px 12px;border:1px solid #ddd;border-radius:6px;font-size:14px;outline:none;transition:border .2s}
.login-box input:focus{border-color:var(--primary,#1d4fd7)}
.login-btn{width:100%;margin-top:20px;padding:12px;font-size:15px;font-weight:600;border-radius:8px}
.login-err{background:#fef2f2;color:#dc2626;padding:8px 12px;border-radius:6px;font-size:13px;margin-bottom:12px;border:1px solid #fecaca}

/* Spinner */
.spinner{width:40px;height:40px;border:4px solid #e2e8f0;border-top-color:var(--primary,#1d4fd7);border-radius:50%;animation:spin .8s linear infinite;margin:0 auto}
@keyframes spin{to{transform:rotate(360deg)}}

/* Nav additions */
.user-name{font-size:13px;color:#666;margin-right:8px}
.logout-btn{font-size:12px;padding:6px 12px;background:transparent;border:1px solid #ddd;border-radius:6px;cursor:pointer;color:#666}
.logout-btn:hover{background:#f5f5f5}
.domain-select{padding:6px 10px;border:1px solid #ddd;border-radius:6px;font-size:13px;background:#fff;cursor:pointer}

/* Settings page */
.settings-table{width:100%;border-collapse:collapse;font-size:13px}
.settings-table th{text-align:left;padding:10px 16px;background:#f8fafc;border-bottom:1px solid #e2e8f0;font-weight:600;color:#555;font-size:12px;text-transform:uppercase;letter-spacing:.5px}
.settings-table td{padding:10px 16px;border-bottom:1px solid #f0f3f7;vertical-align:middle}
.settings-table input{width:100%;padding:7px 10px;border:1px solid #ddd;border-radius:5px;font-size:13px;outline:none}
.settings-table input:focus{border-color:var(--primary,#1d4fd7)}
.domain-cell{font-weight:600;color:#1a1a1a;min-width:160px}
.action-cell{display:flex;gap:6px;white-space:nowrap}
.action-cell .btn{padding:5px 12px;font-size:12px}
.empty{color:#bbb;font-style:italic}
.masked{color:#999;letter-spacing:2px}
.settings-msg{padding:10px 16px;font-size:13px;background:#ecfdf5;color:#065f46;border-bottom:1px solid #d1fae5}
.settings-msg.err{background:#fef2f2;color:#dc2626;border-color:#fecaca}
.nav-right{display:flex;align-items:center;gap:8px}

/* Password form */
.pw-form{max-width:400px}
.pw-field{margin-bottom:14px}
.pw-field label{display:block;font-size:12px;font-weight:600;color:#555;margin-bottom:4px;text-transform:uppercase;letter-spacing:.5px}
.pw-field input{width:100%;padding:9px 12px;border:1px solid #ddd;border-radius:6px;font-size:14px;outline:none}
.pw-field input:focus{border-color:var(--primary,#1d4fd7)}
