  :root{
    --ink:#143454;
    --ink-soft:#47627f;
    --line:#dbe6f2;
    --sky:#2cbcff;
    --navy:#143f79;
    --navy-deep:#0f2f5d;
    --bg:#eaf1f8;
    --surface:#ffffff;
    --surface-soft:#f5f9fd;
    --danger:#c34d4d;
    --success:#1e9b5a;
    --radius-xl:28px;
    --radius-lg:20px;
    --radius-md:14px;
  }

  /* Admin visual correction: keep geometry aligned with Aiklava-Portal-Redesign/screens/home-admin.html */
  body.portal-admin-dashboard{
    --adm-r:14px;
    --adm-r-lg:22px;
    --adm-r-xl:28px;
    --adm-sp-4:18px;
    --adm-sp-5:24px;
    --adm-sp-6:38px;
    --adm-shadow:0 10px 30px rgba(120,95,50,.08);
    --adm-shadow-hi:0 22px 56px rgba(120,95,50,.14);
    --adm-warn:#b07d12;
    --adm-warn-soft:#fbf0d6;
    --adm-surface:rgba(255,255,255,.72);
    --adm-surface-2:rgba(255,255,255,.55);
    --adm-line:rgba(120,100,70,.13);
    --adm-brd:rgba(255,255,255,.7);
    --adm-tab-on-bg:#fff;
    --adm-tab-on-ink:var(--adm-accent-ink);
    --adm-backdrop:rgba(40,28,14,.34);
    background:var(--adm-bg);
    color:var(--adm-ink);
    overflow-x:hidden;
  }
  body.portal-admin-dashboard .shell{
    width:100%;
    max-width:none;
    min-height:100vh;
    margin:0;
    padding:0;
  }
  body.portal-admin-dashboard .shell > .hero,
  body.portal-admin-dashboard .grid{
    display:none;
  }
  body.portal-admin-dashboard #dashboardPanel:not(.hidden){
    width:100%;
    min-height:100vh;
    margin:0;
    padding:0;
    border:0;
    border-radius:0;
    background:transparent;
    box-shadow:none;
    overflow:visible;
  }
  body.portal-admin-dashboard #dashboardPanel:not(.hidden)::before,
  body.portal-admin-dashboard #dashboardPanel:not(.hidden)::after{
    display:none;
  }
  body.portal-admin-dashboard #dashboardPanel:not(.hidden) .panel-body{
    min-height:100vh;
    display:block;
    padding:0;
  }
  body.portal-admin-dashboard #dashboardToolbar,
  body.portal-admin-dashboard #dashboardMessage,
  body.portal-admin-dashboard #servicesSection{
    display:none!important;
  }
  html[data-theme="dark"] body.portal-admin-dashboard{
    --adm-shadow:0 16px 40px rgba(0,0,0,.45);
    --adm-shadow-hi:0 26px 56px rgba(0,0,0,.55);
    --adm-warn:#e9b04a;
    --adm-warn-soft:rgba(233,176,74,.16);
    --adm-surface:rgba(40,34,28,.55);
    --adm-surface-2:rgba(54,46,38,.5);
    --adm-line:rgba(255,255,255,.08);
    --adm-brd:rgba(255,255,255,.08);
    --adm-tab-on-bg:rgba(255,170,90,.16);
    --adm-tab-on-ink:var(--adm-accent-2);
    --adm-backdrop:rgba(0,0,0,.55);
  }
  body.portal-admin-dashboard .admin-dashboard{
    min-height:100vh;
    padding:0;
    overflow:visible;
  }
  body.portal-admin-dashboard .admin-dashboard .glass{
    background:var(--adm-surface);
    border:1px solid var(--adm-brd);
    box-shadow:var(--adm-shadow);
    backdrop-filter:blur(16px) saturate(1.3);
    -webkit-backdrop-filter:blur(16px) saturate(1.3);
  }
  body.portal-admin-dashboard .admin-blob{
    filter:blur(95px);
  }
  body.portal-admin-dashboard .admin-blob.a{
    top:-150px;
    right:-60px;
  }
  body.portal-admin-dashboard .admin-blob.b{
    bottom:-160px;
    left:-100px;
  }
  body.portal-admin-dashboard .admin-wrap{
    position:relative;
    z-index:1;
    width:auto;
    max-width:none;
    margin:0;
  }
  body.portal-admin-dashboard .admin-appbar{
    position:sticky;
    top:0;
    z-index:5;
    display:flex;
    align-items:center;
    gap:14px;
    min-height:0;
    padding:8px 16px;
    border:0;
    border-bottom:1px solid var(--adm-line);
    border-radius:0;
    box-shadow:var(--adm-shadow);
  }
  body.portal-admin-dashboard .admin-brand{
    display:flex;
    align-items:center;
    gap:10px;
    min-width:0;
    color:var(--adm-ink);
    font-size:18px;
    font-weight:800;
    letter-spacing:0;
  }
  body.portal-admin-dashboard .admin-logo{
    width:32px;
    height:32px;
    border-radius:10px;
    box-shadow:none;
    font-size:14px;
  }
  body.portal-admin-dashboard .admin-seg{
    position:absolute;
    left:0;
    right:0;
    top:50%;
    transform:translateY(-50%);
    width:fit-content;
    min-width:0;
    max-width:max(160px,calc(100% - 520px));
    margin-inline:auto;
    display:flex;
    justify-content:flex-start;
    gap:4px;
    padding:5px;
    overflow-x:auto;
    scrollbar-width:none;
    border:1px solid var(--adm-line);
    border-radius:999px;
    background:var(--adm-surface-2);
    box-shadow:inset 0 1px 3px rgba(120,100,70,.08);
  }
  body.portal-admin-dashboard .admin-seg::-webkit-scrollbar{
    display:none;
  }
  body.portal-admin-dashboard .admin-tab{
    display:inline-flex;
    align-items:center;
    gap:8px;
    min-height:0;
    padding:9px 16px;
    border:0;
    border-radius:999px;
    background:transparent;
    color:var(--adm-ink-soft);
    font-size:13px;
    font-weight:700;
    white-space:nowrap;
    transition:.2s cubic-bezier(.4,0,.2,1);
  }
  body.portal-admin-dashboard .admin-tab:hover{
    color:var(--adm-ink);
  }
  body.portal-admin-dashboard .admin-tab.on{
    color:var(--adm-tab-on-ink);
    background:var(--adm-tab-on-bg);
    border:0;
    box-shadow:var(--adm-shadow);
  }
  body.portal-admin-dashboard .admin-tab-ic{
    width:24px;
    height:24px;
    border-radius:7px;
    background:var(--adm-accent-soft);
    color:var(--adm-accent-ink);
  }
  body.portal-admin-dashboard .admin-tab-ic svg{
    width:14px;
    height:14px;
  }
  body.portal-admin-dashboard .admin-actions-top{
    display:flex;
    align-items:center;
    gap:8px;
    margin-left:auto;
  }
  body.portal-admin-dashboard .admin-iconbtn{
    width:38px;
    height:38px;
    min-height:0;
    border-radius:999px;
    border:1px solid var(--adm-line);
    background:var(--adm-surface-2);
    color:var(--adm-ink-soft);
    display:grid;
    place-items:center;
    transition:.2s cubic-bezier(.4,0,.2,1);
  }
  body.portal-admin-dashboard .admin-iconbtn:hover{
    color:var(--adm-ink);
  }
  body.portal-admin-dashboard #adminLogoutButton{
    display:grid;
  }
  body.portal-admin-dashboard .admin-me{
    min-height:0;
    display:flex;
    align-items:center;
    gap:10px;
    padding:0 0 0 4px;
    border:0;
    background:transparent;
    color:var(--adm-ink);
  }
  body.portal-admin-dashboard .admin-me-text{
    display:block;
    text-align:right;
  }
  body.portal-admin-dashboard .admin-me-text b{
    color:var(--adm-ink);
    font-size:13px;
    font-weight:800;
  }
  body.portal-admin-dashboard .admin-me-text span{
    color:var(--adm-ink-faint);
    font-size:11px;
  }
  body.portal-admin-dashboard .admin-avatar{
    width:38px;
    height:38px;
    border-radius:999px;
    box-shadow:none;
    font-size:13px;
    font-weight:800;
  }
  body.portal-admin-dashboard .admin-page{
    max-width:1180px;
    margin:0 auto;
    padding:var(--adm-sp-5) var(--adm-sp-6) var(--adm-sp-6);
    display:grid;
    gap:var(--adm-sp-4);
  }
  body.portal-admin-dashboard .admin-pane{
    display:grid;
    gap:var(--adm-sp-4);
  }
  body.portal-admin-dashboard .admin-pane.hidden{
    display:none!important;
  }
  body.portal-admin-dashboard .admin-hero{
    display:flex;
    align-items:flex-end;
    justify-content:space-between;
    gap:18px;
    padding:0;
    border-radius:0;
  }
  body.portal-admin-dashboard .admin-hero h1,
  body.portal-admin-dashboard .admin-page-head h1{
    margin:0 0 5px;
    color:var(--adm-ink);
    font-size:26px;
    line-height:1.15;
    letter-spacing:-.01em;
  }
  body.portal-admin-dashboard .admin-hero p,
  body.portal-admin-dashboard .admin-page-head p{
    margin:0;
    color:var(--adm-ink-soft);
    font-size:14px;
    line-height:1.45;
  }
  body.portal-admin-dashboard .admin-hero p{
    display:flex;
    align-items:center;
    gap:8px;
  }
  body.portal-admin-dashboard .admin-dot{
    width:8px;
    height:8px;
    margin:0;
    border-radius:50%;
    background:var(--adm-ok);
    box-shadow:0 0 0 4px var(--adm-ok-soft);
  }
  body.portal-admin-dashboard .admin-hero-actions{
    display:flex;
    gap:10px;
    flex-wrap:nowrap;
  }
  body.portal-admin-dashboard .admin-hero-actions .btn{
    border-radius:999px;
    padding:11px 18px;
    font-size:14px;
    font-weight:800;
  }
  body.portal-admin-dashboard .admin-hero-actions .btn.soft{
    background:var(--adm-surface);
    border:1px solid var(--adm-line);
    color:var(--adm-ink);
  }
  body.portal-admin-dashboard .btn.primary,
  body.portal-admin-dashboard .btn.dark{
    color:#fff;
    background:linear-gradient(135deg,color-mix(in srgb,var(--adm-accent) 90%,transparent),color-mix(in srgb,var(--adm-accent-2) 90%,transparent));
    border-color:transparent;
    box-shadow:var(--adm-shadow);
  }
  body.portal-admin-dashboard .btn.soft{
    background:var(--adm-surface);
    border:1px solid var(--adm-line);
    color:var(--adm-accent-ink);
  }
  body.portal-admin-dashboard .admin-kpis{
    display:grid;
    grid-template-columns:repeat(4,1fr);
    gap:var(--adm-sp-4);
  }
  body.portal-admin-dashboard .admin-kpi{
    min-height:0;
    position:relative;
    display:block;
    padding:18px 20px;
    border-radius:var(--adm-r-lg);
    color:var(--adm-ink);
    text-align:left;
    transition:.2s cubic-bezier(.4,0,.2,1);
  }
  body.portal-admin-dashboard .admin-kpi:hover{
    transform:translateY(-3px);
    box-shadow:var(--adm-shadow-hi);
  }
  body.portal-admin-dashboard .admin-kpi::after{
    content:"↗";
    position:absolute;
    top:15px;
    right:17px;
    color:var(--adm-ink-faint);
    font-size:13px;
    font-weight:800;
  }
  body.portal-admin-dashboard .admin-kpi-icon{
    width:36px;
    height:36px;
    margin-bottom:12px;
    border-radius:11px;
    background:var(--adm-accent-soft);
    color:var(--adm-accent-ink);
  }
  body.portal-admin-dashboard .admin-kpi-icon svg{
    width:18px;
    height:18px;
  }
  body.portal-admin-dashboard .admin-kpi strong{
    display:block;
    margin:0;
    color:var(--adm-ink);
    font-size:26px;
    line-height:1;
    font-weight:800;
    letter-spacing:-.02em;
  }
  body.portal-admin-dashboard .admin-kpi > span:not(.admin-kpi-icon){
    display:block;
    margin-top:2px;
    color:var(--adm-ink-soft);
    font-size:13px;
    font-weight:400;
  }
  body.portal-admin-dashboard .admin-kpi small{
    display:inline-block;
    margin-top:7px;
    padding:3px 9px;
    border-radius:999px;
    background:var(--adm-ok-soft);
    color:var(--adm-ok);
    font-size:12px;
    font-weight:800;
  }
  body.portal-admin-dashboard .admin-kpi:nth-child(4) small:not(:empty){
    background:var(--adm-ok-soft);
    color:var(--adm-ok);
  }
  body.portal-admin-dashboard .admin-two{
    display:grid;
    grid-template-columns:1fr 1fr;
    gap:var(--adm-sp-4);
  }
  body.portal-admin-dashboard .admin-card-panel{
    min-height:0;
    padding:var(--adm-sp-5);
    border-radius:var(--adm-r-lg);
  }
  body.portal-admin-dashboard .admin-panel-head{
    display:flex;
    align-items:flex-start;
    justify-content:space-between;
    gap:14px;
    margin-bottom:14px;
  }
  body.portal-admin-dashboard .admin-panel-head h2{
    margin:0;
    color:var(--adm-ink);
    font-size:15px;
    line-height:1.25;
    letter-spacing:0;
  }
  body.portal-admin-dashboard .admin-panel-head .btn.sm{
    min-height:0;
    padding:8px 14px;
    border-radius:12px;
    font-size:12px;
    font-weight:800;
  }
  body.portal-admin-dashboard .admin-status-list{
    display:block;
    margin-top:0;
  }
  body.portal-admin-dashboard .admin-health-group{
    margin:14px 0 9px;
    color:var(--adm-ink-faint);
    font-size:11px;
    font-weight:800;
    text-transform:uppercase;
    letter-spacing:.05em;
  }
  body.portal-admin-dashboard .admin-health-group:first-child{
    margin-top:0;
  }
  body.portal-admin-dashboard .admin-status-chips{
    display:flex;
    flex-wrap:wrap;
    gap:9px;
  }
  body.portal-admin-dashboard .admin-status-chip{
    display:flex;
    align-items:center;
    gap:8px;
    padding:7px 13px;
    border:1px solid var(--adm-line);
    border-radius:999px;
    background:var(--adm-surface-2);
    color:var(--adm-ink-soft);
    font-size:13px;
    font-weight:700;
  }
  body.portal-admin-dashboard .admin-status-chip .sd{
    width:8px;
    height:8px;
    border-radius:50%;
    background:currentColor;
  }
  body.portal-admin-dashboard .admin-status-chip.ok{
    color:var(--adm-ink-soft);
  }
  body.portal-admin-dashboard .admin-status-chip.ok .sd{
    color:var(--adm-ok);
    background:var(--adm-ok);
  }
  body.portal-admin-dashboard .admin-status-chip.warn{
    color:var(--adm-warn);
  }
  body.portal-admin-dashboard .admin-status-chip.warn .sd{
    background:var(--adm-warn);
  }
  body.portal-admin-dashboard .admin-status-chip.danger{
    color:var(--adm-danger);
  }
  body.portal-admin-dashboard .admin-status-chip.danger .sd{
    background:var(--adm-danger);
  }
  body.portal-admin-dashboard .admin-events{
    display:grid;
    gap:2px;
    margin-top:0;
  }
  body.portal-admin-dashboard .admin-event{
    display:flex;
    align-items:center;
    gap:13px;
    min-height:0;
    padding:11px 6px;
    border:0;
    border-radius:12px;
    background:transparent;
    color:var(--adm-ink);
  }
  body.portal-admin-dashboard .admin-event + .admin-event{
    border-top:1px solid var(--adm-line);
  }
  body.portal-admin-dashboard .admin-event::before{
    content:none;
  }
  body.portal-admin-dashboard .admin-event-icon{
    width:34px;
    height:34px;
    flex:0 0 34px;
    display:grid;
    place-items:center;
    border-radius:10px;
    background:var(--adm-accent-soft);
    color:var(--adm-accent-ink);
  }
  body.portal-admin-dashboard .admin-event.ok .admin-event-icon{
    background:var(--adm-ok-soft);
    color:var(--adm-ok);
  }
  body.portal-admin-dashboard .admin-event.warn .admin-event-icon{
    background:var(--adm-warn-soft);
    color:var(--adm-warn);
  }
  body.portal-admin-dashboard .admin-event.danger .admin-event-icon{
    background:var(--adm-danger-soft);
    color:var(--adm-danger);
  }
  body.portal-admin-dashboard .admin-event-icon svg{
    width:16px;
    height:16px;
  }
  body.portal-admin-dashboard .admin-event-text{
    flex:1;
    min-width:0;
  }
  body.portal-admin-dashboard .admin-event-text strong{
    display:block;
    color:var(--adm-ink);
    font-size:13.5px;
    line-height:1.25;
  }
  body.portal-admin-dashboard .admin-event-text span{
    display:block;
    margin-top:2px;
    color:var(--adm-ink-faint);
    font-size:12px;
    line-height:1.25;
  }
  body.portal-admin-dashboard .admin-hintbar{
    position:fixed;
    left:50%;
    bottom:16px;
    z-index:6;
    transform:translateX(-50%);
    padding:9px 18px;
    border-radius:999px;
    color:var(--adm-ink-soft);
    font-size:12px;
    line-height:1;
    white-space:nowrap;
  }
  body.portal-admin-dashboard .admin-page-head{
    display:flex;
    align-items:center;
    justify-content:space-between;
    gap:18px;
    margin:0 0 4px;
  }
  body.portal-admin-dashboard .admin-service-grid,
  body.portal-admin-dashboard .admin-control-grid{
    display:grid;
    grid-template-columns:repeat(4,minmax(0,1fr));
    gap:var(--adm-sp-4);
  }
  body.portal-admin-dashboard .admin-service-card,
  body.portal-admin-dashboard .admin-control-card{
    min-height:210px;
    border-radius:var(--adm-r-lg);
    padding:20px;
  }
  @media(max-width:1120px){
    body.portal-admin-dashboard .admin-seg{
      position:static;
      transform:none;
      order:3;
      width:100%;
      max-width:none;
      margin:6px 0 0;
    }
    body.portal-admin-dashboard .admin-appbar{
      flex-wrap:wrap;
    }
    body.portal-admin-dashboard .admin-kpis,
    body.portal-admin-dashboard .admin-service-grid,
    body.portal-admin-dashboard .admin-control-grid{
      grid-template-columns:repeat(2,minmax(0,1fr));
    }
    body.portal-admin-dashboard .admin-two{
      grid-template-columns:1fr;
    }
  }
  @media(max-width:720px){
    body.portal-admin-dashboard .admin-page{
      padding:18px;
    }
    body.portal-admin-dashboard .admin-brand span:not(.admin-logo),
    body.portal-admin-dashboard .admin-me-text{
      display:none;
    }
    body.portal-admin-dashboard .admin-hero,
    body.portal-admin-dashboard .admin-page-head{
      flex-direction:column;
      align-items:flex-start;
    }
    body.portal-admin-dashboard .admin-hero-actions,
    body.portal-admin-dashboard .admin-hero-actions .btn,
    body.portal-admin-dashboard .admin-page-head .btn{
      width:100%;
    }
    body.portal-admin-dashboard .admin-kpis,
    body.portal-admin-dashboard .admin-service-grid,
    body.portal-admin-dashboard .admin-control-grid{
      grid-template-columns:1fr;
    }
    body.portal-admin-dashboard .admin-hintbar{
      display:none;
    }
  }

/* Final viewport guard for the redesigned admin shell. */
body.portal-admin-dashboard .shell{
  width:100%;
  max-width:none;
  min-height:100vh;
  margin:0;
  padding:0;
}
body.portal-admin-dashboard .shell > .hero,
body.portal-admin-dashboard .grid{
  display:none;
}
body.portal-admin-dashboard #dashboardPanel:not(.hidden){
  width:100%;
  min-height:100vh;
  margin:0;
  padding:0;
  border:0;
  border-radius:0;
  background:transparent;
  box-shadow:none;
  overflow:visible;
}
body.portal-admin-dashboard #dashboardPanel:not(.hidden)::before,
body.portal-admin-dashboard #dashboardPanel:not(.hidden)::after{
  display:none;
}
body.portal-admin-dashboard #dashboardPanel:not(.hidden) .panel-body{
  min-height:100vh;
  display:block;
  padding:0;
}
body.portal-admin-dashboard .admin-dashboard{
  padding:0;
  overflow:visible;
}
body.portal-admin-dashboard #dashboardToolbar,
body.portal-admin-dashboard #dashboardMessage,
body.portal-admin-dashboard #servicesSection{
  display:none!important;
}

/* The redesigned admin shell must own the full viewport. */
body.portal-admin-dashboard .shell{
  width:100%;
  max-width:none;
  min-height:100vh;
  margin:0;
  padding:0;
}
body.portal-admin-dashboard .shell > .hero,
body.portal-admin-dashboard .grid{
  display:none;
}
body.portal-admin-dashboard #dashboardPanel:not(.hidden){
  width:100%;
  min-height:100vh;
  margin:0;
  padding:0;
  border:0;
  border-radius:0;
  background:transparent;
  box-shadow:none;
  overflow:visible;
}
body.portal-admin-dashboard #dashboardPanel:not(.hidden)::before,
body.portal-admin-dashboard #dashboardPanel:not(.hidden)::after{
  display:none;
}
body.portal-admin-dashboard #dashboardPanel:not(.hidden) .panel-body{
  min-height:100vh;
  display:block;
  padding:0;
}
body.portal-admin-dashboard .admin-dashboard{
  padding:0;
  overflow:visible;
}
body.portal-admin-dashboard #dashboardToolbar,
body.portal-admin-dashboard #dashboardMessage,
body.portal-admin-dashboard #servicesSection{
  display:none!important;
}

  body.portal-admin-dashboard .modal-backdrop{
    background:var(--adm-backdrop,rgba(45,32,16,.32));
    backdrop-filter:blur(16px);
    -webkit-backdrop-filter:blur(16px);
    padding:24px;
  }
  body.portal-admin-dashboard .modal{
    background:var(--adm-surface);
    border:1px solid var(--adm-brd);
    border-radius:var(--adm-r-lg);
    box-shadow:var(--adm-shadow-hi);
    color:var(--adm-ink);
    backdrop-filter:blur(20px) saturate(1.25);
    -webkit-backdrop-filter:blur(20px) saturate(1.25);
  }
  body.portal-admin-dashboard .modal.full-modal{
    width:min(1180px,100%);
  }
  body.portal-admin-dashboard .modal.queue-modal{
    width:min(1280px,100%);
  }
  body.portal-admin-dashboard .modal-head{
    padding:20px 24px 14px;
    border-bottom:1px solid var(--adm-line);
  }
  body.portal-admin-dashboard .modal-head h3{
    color:var(--adm-ink);
    font-size:22px;
    letter-spacing:-.01em;
  }
  body.portal-admin-dashboard .modal-head p{
    color:var(--adm-ink-soft);
    font-size:13px;
    line-height:1.45;
  }
  body.portal-admin-dashboard .modal-body{
    padding:20px 24px 24px;
  }
  body.portal-admin-dashboard .icon-btn{
    width:38px;
    height:38px;
    border:1px solid var(--adm-line);
    border-radius:999px;
    background:var(--adm-surface-2);
    color:var(--adm-ink-soft);
    box-shadow:none;
  }
  body.portal-admin-dashboard .modal label,
  body.portal-admin-dashboard .modal .pick-label{
    color:var(--adm-ink-soft);
    font-size:13px;
    font-weight:700;
  }
  body.portal-admin-dashboard .modal input,
  body.portal-admin-dashboard .modal textarea,
  body.portal-admin-dashboard .modal select{
    width:100%;
    border:1px solid var(--adm-line);
    border-radius:14px;
    background:rgba(255,255,255,.68);
    color:var(--adm-ink);
    font:inherit;
    min-height:42px;
    padding:10px 12px;
    outline:none;
  }
  html[data-theme="dark"] body.portal-admin-dashboard .modal input,
  html[data-theme="dark"] body.portal-admin-dashboard .modal textarea,
  html[data-theme="dark"] body.portal-admin-dashboard .modal select{
    background:rgba(255,255,255,.05);
  }
  body.portal-admin-dashboard .modal input:focus,
  body.portal-admin-dashboard .modal textarea:focus,
  body.portal-admin-dashboard .modal select:focus{
    border-color:var(--adm-accent);
    box-shadow:0 0 0 4px var(--adm-accent-soft);
  }
  body.portal-admin-dashboard .modal-toolbar,
  body.portal-admin-dashboard .modal-foot{
    display:flex;
    align-items:center;
    justify-content:flex-end;
    gap:10px;
    flex-wrap:wrap;
  }
  body.portal-admin-dashboard .selection-card,
  body.portal-admin-dashboard .metric-card{
    border:1px solid var(--adm-line);
    border-radius:var(--adm-r-lg);
    background:var(--adm-surface-2);
    color:var(--adm-ink);
  }
  body.portal-admin-dashboard .metric-card span{
    color:var(--adm-ink-faint);
  }
  body.portal-admin-dashboard .metric-card small,
  body.portal-admin-dashboard .field-note,
  body.portal-admin-dashboard .subhint{
    color:var(--adm-ink-faint);
  }
  body.portal-admin-dashboard .admin-new-badge{
    display:inline-flex;
    align-items:center;
    padding:2px 8px;
    border-radius:999px;
    background:var(--adm-accent-soft);
    color:var(--adm-accent-ink);
    font-size:11px;
    font-weight:800;
    vertical-align:middle;
  }
  body.portal-admin-dashboard .branding-grid{
    display:grid;
    grid-template-columns:1.3fr 1fr;
    gap:var(--adm-sp-4);
    align-items:start;
  }
  body.portal-admin-dashboard .branding-form{
    display:grid;
    gap:14px;
  }
  body.portal-admin-dashboard .branding-swatches{
    display:flex;
    flex-wrap:wrap;
    align-items:center;
    gap:10px;
    margin-top:8px;
  }
  body.portal-admin-dashboard .branding-swatch{
    width:32px;
    height:32px;
    padding:0;
    border:2px solid transparent;
    border-radius:10px;
    background:var(--sw);
    cursor:pointer;
    transition:.2s cubic-bezier(.4,0,.2,1);
  }
  body.portal-admin-dashboard .branding-swatch:hover{
    transform:scale(1.06);
  }
  body.portal-admin-dashboard .branding-swatch.on{
    border-color:var(--adm-ink);
    box-shadow:0 0 0 3px var(--adm-surface);
  }
  body.portal-admin-dashboard .branding-custom{
    position:relative;
    overflow:hidden;
    display:grid;
    place-items:center;
    background:conic-gradient(from 0deg,#ff5d5d,#ffb24d,#ffe14d,#5fd36b,#4dd0e1,#6d8cff,#c46dff,#ff5d5d);
    color:#fff;
  }
  body.portal-admin-dashboard .branding-custom svg{
    width:15px;
    height:15px;
    pointer-events:none;
    filter:drop-shadow(0 1px 2px rgba(0,0,0,.4));
  }
  body.portal-admin-dashboard .branding-custom input{
    position:absolute;
    inset:0;
    opacity:0;
    cursor:pointer;
  }
  body.portal-admin-dashboard .theme-segment{
    display:inline-flex;
    gap:4px;
    width:fit-content;
    padding:4px;
    border:1px solid var(--adm-line);
    border-radius:999px;
    background:var(--adm-surface-2);
  }
  body.portal-admin-dashboard .theme-segment button{
    border:0;
    border-radius:999px;
    background:transparent;
    color:var(--adm-ink-soft);
    cursor:pointer;
    font:inherit;
    font-size:13px;
    font-weight:700;
    padding:7px 14px;
  }
  body.portal-admin-dashboard .theme-segment button.on{
    background:var(--adm-surface);
    color:var(--adm-accent-ink);
    box-shadow:var(--adm-shadow);
  }
  body.portal-admin-dashboard .branding-preview{
    display:grid;
    gap:12px;
  }
  body.portal-admin-dashboard .brand-preview-bar{
    display:flex;
    align-items:center;
    gap:10px;
    border:1px solid var(--adm-line);
    border-radius:var(--adm-r-lg);
    padding:13px 15px;
    background:var(--adm-surface-2);
  }
  body.portal-admin-dashboard .brand-preview-logo{
    width:34px;
    height:34px;
    display:grid;
    place-items:center;
    border-radius:10px;
    background:linear-gradient(135deg,var(--adm-accent),var(--adm-accent-2));
    color:#fff;
    font-weight:900;
    overflow:hidden;
  }
  body.portal-admin-dashboard .brand-preview-logo img{
    width:100%;
    height:100%;
    object-fit:cover;
  }
  [data-brand-logo] img{
    width:100%;
    height:100%;
    display:block;
    object-fit:cover;
    border-radius:inherit;
  }
  body.portal-admin-dashboard .brand-preview-bar b{
    display:block;
    color:var(--adm-ink);
    font-size:15px;
  }
  body.portal-admin-dashboard .brand-preview-bar span:not(.brand-preview-logo){
    display:block;
    color:var(--adm-ink-faint);
    font-size:11px;
  }
  body.portal-admin-dashboard .branding-palette{
    display:flex;
    flex-direction:column;
    gap:12px;
  }
  body.portal-admin-dashboard .branding-palette-row{
    display:flex;
    flex-wrap:wrap;
    align-items:center;
    gap:12px;
  }
  body.portal-admin-dashboard .branding-palette-row b{
    width:74px;
    color:var(--adm-ink);
    font-size:12px;
  }
  body.portal-admin-dashboard .branding-palette span{
    display:flex;
    flex-direction:column;
    align-items:center;
    gap:5px;
    color:var(--adm-ink-faint);
    font-size:10px;
    font-weight:700;
  }
  body.portal-admin-dashboard .branding-palette i{
    width:38px;
    height:38px;
    display:block;
    border:1px solid var(--adm-line);
    border-radius:11px;
  }
  body.portal-admin-dashboard .status-row{
    display:flex;
    flex-wrap:wrap;
    gap:8px;
  }
  body.portal-admin-dashboard .chip{
    display:inline-flex;
    align-items:center;
    padding:5px 10px;
    border-radius:999px;
    font-size:12px;
    font-weight:800;
    background:var(--adm-surface-2);
    color:var(--adm-ink-soft);
  }
  body.portal-admin-dashboard .chip.ok{
    background:var(--adm-ok-soft);
    color:var(--adm-ok);
  }
  body.portal-admin-dashboard .chip.warn{
    background:var(--adm-warn-soft);
    color:var(--adm-warn);
  }
  body.portal-admin-dashboard .chip.bad{
    background:var(--adm-danger-soft);
    color:var(--adm-danger);
  }
  @media(max-width:900px){
    body.portal-admin-dashboard .branding-grid{
      grid-template-columns:1fr;
    }
  }
  *{box-sizing:border-box}
  body{
    margin:0;
    font-family:"Segoe UI","Segoe UI Variable",Arial,sans-serif;
    color:var(--ink);
    background:
      radial-gradient(circle at top left, rgba(43,188,255,.18), transparent 30%),
      radial-gradient(circle at top right, rgba(20,63,121,.14), transparent 28%),
      var(--bg);
    min-height:100vh;
  }
  .shell{max-width:1380px;margin:0 auto;padding:28px}
  .hero{
    background:linear-gradient(135deg,var(--navy) 0%,var(--navy-deep) 100%);
    color:#fff;
    border-radius:24px;
    padding:28px;
    display:grid;
    grid-template-columns:minmax(0,1fr) 320px;
    gap:24px;
    border:1px solid rgba(255,255,255,.12);
  }
  .eyebrow{
    text-transform:uppercase;
    letter-spacing:.18em;
    font-size:12px;
    color:rgba(255,255,255,.72);
    margin-bottom:14px;
  }
  .hero h1{
    margin:0 0 14px;
    font-size:42px;
    line-height:1.02;
    letter-spacing:-.04em;
  }
  .hero p{
    margin:0;
    max-width:760px;
    color:rgba(255,255,255,.82);
    line-height:1.6;
    font-size:15px;
  }
  .hero-side{
    background:rgba(255,255,255,.08);
    border:1px solid rgba(255,255,255,.12);
    border-radius:18px;
    padding:18px;
    align-self:start;
  }
  .hero-side .label{
    font-size:12px;
    text-transform:uppercase;
    letter-spacing:.16em;
    color:rgba(255,255,255,.72);
    margin-bottom:10px;
  }
  .hero-side .value{
    font-size:28px;
    font-weight:700;
    margin-bottom:10px;
  }
  .hero-side .meta{
    color:rgba(255,255,255,.8);
    font-size:13px;
    line-height:1.5;
  }
  .grid{
    display:block;
    margin-top:20px;
  }
  .panel{
    background:var(--surface);
    border:1px solid rgba(255,255,255,.75);
    border-radius:var(--radius-xl);
    overflow:hidden;
  }
  .panel-head{
    padding:20px 22px 0;
  }
  .panel-title{
    margin:0;
    font-size:16px;
    text-transform:uppercase;
    letter-spacing:.14em;
    color:var(--ink-soft);
  }
  .panel-body{
    padding:20px 22px 22px;
  }
  .login-card{
    display:flex;
    flex-direction:column;
    gap:14px;
  }
  label{
    display:flex;
    flex-direction:column;
    gap:8px;
    font-size:13px;
    color:var(--ink-soft);
    font-weight:600;
  }
  input,textarea,select{
    width:100%;
    border:1px solid var(--line);
    border-radius:12px;
    padding:12px 14px;
    background:#fff;
    color:var(--ink);
    font:inherit;
    outline:none;
  }
  textarea{min-height:90px;resize:vertical}
  input:focus,textarea:focus,select:focus{
    border-color:#8bc6ff;
    box-shadow:0 0 0 3px rgba(44,188,255,.14);
  }
  .btn{
    appearance:none;
    border:none;
    border-radius:12px;
    padding:12px 16px;
    font:inherit;
    font-weight:700;
    cursor:pointer;
    transition:transform .16s ease, opacity .16s ease;
  }
  .btn:hover{transform:translateY(-1px)}
  .btn.primary{background:var(--sky);color:#fff}
  .btn.dark{background:var(--navy);color:#fff}
  .btn.soft{background:#eef6ff;color:var(--navy);border:1px solid #cfe3fb}
  .btn.danger{background:#fff4f4;color:var(--danger);border:1px solid #efcaca}
  .stack{display:flex;flex-direction:column;gap:14px}
  .message{
    min-height:20px;
    font-size:13px;
    line-height:1.5;
    color:var(--ink-soft);
  }
  .message.error{color:var(--danger)}
  .message.success{color:var(--success)}
  .field-note{
    margin:0;
    font-size:12px;
    line-height:1.5;
    color:var(--ink-soft);
  }
  .toolbar{
    display:flex;
    flex-wrap:wrap;
    justify-content:space-between;
    gap:12px;
    align-items:center;
    margin-bottom:18px;
  }
  .toolbar h2{
    margin:0;
    font-size:28px;
    letter-spacing:-.04em;
  }
  .toolbar p{
    margin:6px 0 0;
    color:var(--ink-soft);
    font-size:14px;
  }
  .toolbar-actions{display:flex;gap:10px;flex-wrap:wrap}
  .content-section{
    display:grid;
    gap:18px;
  }
  .section-intro{
    display:grid;
    gap:6px;
  }
  .section-intro h3{
    margin:0;
    font-size:18px;
    letter-spacing:-.03em;
  }
  .section-intro p{
    margin:0;
    color:var(--ink-soft);
    line-height:1.6;
    font-size:14px;
  }
  .service-grid{
    display:grid;
    grid-template-columns:repeat(auto-fit,minmax(240px,1fr));
    gap:16px;
  }
  .service-card{
    border:1px solid var(--line);
    background:linear-gradient(180deg,#fff,#f8fbff);
    border-radius:20px;
    padding:18px;
    display:flex;
    flex-direction:column;
    gap:14px;
    min-height:220px;
  }
  .service-icon{
    width:46px;height:46px;border-radius:14px;
    display:inline-flex;align-items:center;justify-content:center;
    background:#e9f5ff;color:var(--navy);font-size:24px;
  }
  .service-card h3{margin:0;font-size:22px;letter-spacing:-.03em}
  .service-card p{margin:0;color:var(--ink-soft);line-height:1.55;font-size:14px}
  .service-meta{
    margin-top:auto;
    font-size:12px;
    text-transform:uppercase;
    letter-spacing:.14em;
    color:var(--ink-soft);
  }
  .hidden{display:none!important}
  .admin-section{
    display:grid;
    gap:18px;
  }
  .admin-actions{
    display:grid;
    grid-template-columns:repeat(auto-fit,minmax(260px,1fr));
    gap:18px;
  }
  .admin-card{
    background:var(--surface);
    border:1px solid rgba(255,255,255,.75);
    border-radius:var(--radius-xl);
    padding:24px;
    display:flex;
    flex-direction:column;
    gap:16px;
    min-height:220px;
  }
  .admin-card h3{
    margin:0;
    font-size:16px;
    text-transform:uppercase;
    letter-spacing:.14em;
    color:var(--ink-soft);
  }
  .admin-card p{
    margin:0;
    color:var(--ink-soft);
    line-height:1.6;
  }
  .admin-card .btn{
    margin-top:auto;
  }
  table{
    width:100%;
    border-collapse:collapse;
    background:#fff;
    border:1px solid var(--line);
    border-radius:16px;
    overflow:hidden;
  }
  th,td{
    padding:12px 14px;
    text-align:left;
    border-bottom:1px solid var(--line);
    vertical-align:top;
    font-size:13px;
  }
  th{
    font-size:12px;
    text-transform:uppercase;
    letter-spacing:.12em;
    color:var(--ink-soft);
    background:#f7fbff;
  }
  tr:last-child td{border-bottom:none}
  .role-pill,.status-pill{
    display:inline-flex;
    align-items:center;
    justify-content:center;
    padding:6px 10px;
    border-radius:999px;
    font-size:12px;
    font-weight:700;
  }
  .role-pill.admin{background:#e8f0ff;color:#1d4f93}
  .role-pill.user{background:#edf7f2;color:#28744a}
  .status-pill.active{background:#edf7f2;color:#28744a}
  .status-pill.inactive{background:#f6eff1;color:#95526a}
  .mini-actions{display:flex;gap:8px;flex-wrap:wrap}
  .clickable-row{
    cursor:pointer;
    transition:background .16s ease;
  }
  .clickable-row:hover{
    background:#f7fbff;
  }
  .clickable-row.selected{
    background:#eef6ff;
  }
  .usage-event-detail{
    margin-top:12px;
    padding:14px;
    border:1px solid var(--border);
    border-radius:18px;
    background:#fbfdff;
  }
  .usage-event-detail-grid{
    display:grid;
    grid-template-columns:repeat(auto-fit,minmax(180px,1fr));
    gap:10px;
  }
  .usage-event-detail-grid span{
    display:block;
    color:var(--ink-soft);
    font-size:11px;
    text-transform:uppercase;
    letter-spacing:.08em;
  }
  .usage-event-detail-grid strong{
    display:block;
    margin-top:2px;
    color:var(--ink);
    font-size:13px;
    word-break:break-word;
  }
  .empty{
    padding:18px;
    border:1px dashed #c7d8ea;
    border-radius:16px;
    color:var(--ink-soft);
    background:#fbfdff;
    text-align:center;
    font-size:14px;
  }
  .modal-backdrop{
    position:fixed;
    inset:0;
    background:rgba(15,47,93,.38);
    backdrop-filter:blur(6px);
    display:flex;
    align-items:center;
    justify-content:center;
    padding:24px;
    z-index:30;
  }
  .modal{
    width:min(980px,100%);
    max-height:min(88vh,920px);
    background:var(--surface);
    border-radius:28px;
    border:1px solid rgba(255,255,255,.7);
    box-shadow:0 30px 80px rgba(15,47,93,.22);
    overflow:hidden;
    display:flex;
    flex-direction:column;
  }
  .modal-head{
    padding:22px 24px 14px;
    display:flex;
    justify-content:space-between;
    gap:12px;
    align-items:flex-start;
    border-bottom:1px solid var(--line);
  }
  .modal-head h3{
    margin:0;
    font-size:24px;
    letter-spacing:-.04em;
  }
  .modal-head p{
    margin:8px 0 0;
    color:var(--ink-soft);
    font-size:14px;
    line-height:1.6;
  }
  .icon-btn{
    width:42px;
    height:42px;
    border-radius:12px;
    border:1px solid var(--line);
    background:#fff;
    color:var(--ink);
    font:inherit;
    font-size:22px;
    cursor:pointer;
  }
  .modal-body{
    padding:22px 24px 24px;
    overflow:auto;
    display:grid;
    gap:18px;
  }
  #changePasswordModal{
    background:rgba(45,32,16,.32);
  }
  #changePasswordModal .profile-modal{
    --pf-accent:#ec7a1c;
    --pf-accent-2:#ffb24d;
    --pf-accent-soft:#fdeedd;
    --pf-accent-ink:#c4641a;
    --pf-ok:#5e8519;
    --pf-ok-soft:#eef5dd;
    --pf-surface:rgba(255,255,255,.86);
    --pf-surface-2:rgba(255,255,255,.62);
    --pf-field:rgba(255,255,255,.72);
    --pf-ink:#2a2620;
    --pf-ink-soft:#6c6457;
    --pf-ink-faint:#9c9484;
    --pf-line:rgba(120,100,70,.14);
    --pf-brd:rgba(255,255,255,.76);
    width:min(780px,100%);
    max-height:92vh;
    border-radius:26px;
    border:1px solid var(--pf-brd);
    background:var(--pf-surface);
    box-shadow:0 24px 70px rgba(80,55,20,.22);
    backdrop-filter:blur(22px) saturate(1.3);
    -webkit-backdrop-filter:blur(22px) saturate(1.3);
  }
  html[data-theme="dark"] #changePasswordModal .profile-modal{
    --pf-accent:#ff7a1a;
    --pf-accent-2:#ffae5c;
    --pf-accent-soft:rgba(255,140,40,.16);
    --pf-accent-ink:#ffae5c;
    --pf-ok:#a7d34e;
    --pf-ok-soft:rgba(167,211,78,.16);
    --pf-surface:rgba(42,36,30,.92);
    --pf-surface-2:rgba(255,255,255,.05);
    --pf-field:rgba(255,255,255,.05);
    --pf-ink:#f4efe6;
    --pf-ink-soft:#b3a899;
    --pf-ink-faint:#80766a;
    --pf-line:rgba(255,255,255,.09);
    --pf-brd:rgba(255,255,255,.09);
    box-shadow:0 30px 80px rgba(0,0,0,.6);
  }
  #changePasswordModal .profile-modal-head{
    flex:0 0 auto;
    display:flex;
    align-items:center;
    justify-content:space-between;
    gap:12px;
    padding:18px 22px 0;
    border-bottom:0;
  }
  #changePasswordModal .profile-modal-head h3{
    margin:0;
    color:var(--pf-ink);
    font-size:19px;
    letter-spacing:-.01em;
  }
  #changePasswordModal .profile-close{
    width:32px;
    height:32px;
    border-radius:999px;
    border:1px solid var(--pf-line);
    background:var(--pf-surface-2);
    color:var(--pf-ink-soft);
    display:grid;
    place-items:center;
    cursor:pointer;
    font:inherit;
    font-size:15px;
  }
  #changePasswordModal .profile-modal-body{
    flex:1 1 auto;
    min-height:0;
    overflow:auto;
    padding:12px 22px 4px;
  }
  #changePasswordModal .profile-who{
    display:flex;
    align-items:center;
    gap:13px;
    margin-bottom:14px;
  }
  #changePasswordModal .profile-avatar{
    width:48px;
    height:48px;
    border-radius:14px;
    background:linear-gradient(135deg,var(--pf-accent),var(--pf-accent-2));
    color:#fff;
    display:grid;
    place-items:center;
    font-weight:800;
    font-size:18px;
    flex:0 0 auto;
  }
  #changePasswordModal .profile-who b{
    display:block;
    color:var(--pf-ink);
    font-size:16px;
  }
  #changePasswordModal .profile-who span{
    display:block;
    margin-top:2px;
    color:var(--pf-ink-faint);
    font-size:12px;
  }
  #changePasswordModal .profile-grid{
    display:grid;
    grid-template-columns:1fr 1fr;
    gap:22px;
    align-items:start;
  }
  #changePasswordModal .profile-col{
    display:flex;
    flex-direction:column;
  }
  #changePasswordModal .profile-card{
    border:1px solid var(--pf-line);
    border-radius:22px;
    background:var(--pf-surface-2);
    padding:6px 14px;
  }
  #changePasswordModal .profile-kv{
    display:flex;
    justify-content:space-between;
    align-items:center;
    gap:14px;
    padding:8px 0;
    border-bottom:1px solid var(--pf-line);
    font-size:14px;
  }
  #changePasswordModal .profile-kv:last-child{
    border-bottom:0;
  }
  #changePasswordModal .profile-kv .k{
    color:var(--pf-ink-soft);
    font-weight:600;
    white-space:nowrap;
  }
  #changePasswordModal .profile-kv .v{
    color:var(--pf-ink);
    font-weight:700;
    text-align:right;
    overflow-wrap:anywhere;
  }
  #changePasswordModal .profile-lock{
    display:flex;
    align-items:flex-start;
    gap:6px;
    margin:7px 2px 0;
    color:var(--pf-ink-faint);
    font-size:11px;
    line-height:1.45;
  }
  #changePasswordModal .profile-lock svg,
  #changePasswordModal .profile-input svg{
    width:16px;
    height:16px;
    flex:0 0 auto;
  }
  #changePasswordModal .profile-divider{
    display:flex;
    align-items:center;
    gap:12px;
    margin:13px 0 8px;
    color:var(--pf-ink-faint);
    font-size:12px;
    font-weight:800;
    letter-spacing:.06em;
    text-transform:uppercase;
  }
  #changePasswordModal .profile-divider.first{
    margin-top:0;
  }
  #changePasswordModal .profile-divider::before,
  #changePasswordModal .profile-divider::after{
    content:"";
    height:1px;
    flex:1;
    background:var(--pf-line);
  }
  #changePasswordModal .profile-hint{
    margin:-2px 0 9px;
    color:var(--pf-ink-faint);
    font-size:12px;
    line-height:1.45;
  }
  #changePasswordModal .profile-field{
    margin-bottom:9px;
  }
  #changePasswordModal .profile-field label{
    display:block;
    margin-bottom:5px;
    color:var(--pf-ink-soft);
    font-size:13px;
    font-weight:700;
  }
  #changePasswordModal .profile-input{
    display:flex;
    align-items:center;
    gap:10px;
    background:var(--pf-field);
    border:1px solid var(--pf-line);
    border-radius:14px;
    padding:0 13px;
    transition:.2s cubic-bezier(.4,0,.2,1);
  }
  #changePasswordModal .profile-input:focus-within{
    border-color:var(--pf-accent);
    box-shadow:0 0 0 4px var(--pf-accent-soft);
  }
  #changePasswordModal .profile-input svg{
    color:var(--pf-ink-faint);
  }
  #changePasswordModal .profile-input input{
    flex:1;
    min-width:0;
    border:0;
    border-radius:0;
    padding:10px 0;
    background:transparent;
    box-shadow:none;
    color:var(--pf-ink);
    font:inherit;
    font-size:15px;
    outline:none;
  }
  #changePasswordModal .profile-input input:focus{
    border-color:transparent;
    box-shadow:none;
  }
  #changePasswordModal .profile-input input::placeholder{
    color:var(--pf-ink-faint);
  }
  #changePasswordModal .profile-access-list{
    display:grid;
    gap:7px;
  }
  #changePasswordModal .profile-access-row{
    display:flex;
    align-items:center;
    justify-content:space-between;
    gap:10px;
    padding:8px 13px;
    border:1px solid var(--pf-line);
    border-radius:14px;
    background:var(--pf-field);
  }
  #changePasswordModal .profile-access-row .nm{
    color:var(--pf-ink);
    font-size:13px;
    font-weight:700;
  }
  #changePasswordModal .profile-access-row.off .nm{
    color:var(--pf-ink-faint);
    font-weight:600;
  }
  #changePasswordModal .profile-badge{
    display:inline-flex;
    align-items:center;
    gap:6px;
    padding:4px 11px;
    border-radius:999px;
    font-size:11px;
    font-weight:800;
    white-space:nowrap;
  }
  #changePasswordModal .profile-badge::before{
    content:"";
    width:7px;
    height:7px;
    border-radius:50%;
    background:currentColor;
  }
  #changePasswordModal .profile-badge.on{
    color:var(--pf-ok);
    background:var(--pf-ok-soft);
  }
  #changePasswordModal .profile-badge.off{
    color:var(--pf-ink-faint);
    background:var(--pf-surface-2);
  }
  #changePasswordModal .profile-modal .message{
    margin-top:10px;
  }
  #changePasswordModal .profile-modal-foot{
    flex:0 0 auto;
    display:flex;
    justify-content:flex-end;
    gap:10px;
    padding:14px 22px 18px;
  }
  #changePasswordModal .profile-modal .btn{
    border-radius:14px;
    padding:11px 18px;
    font-size:14px;
    font-weight:800;
    box-shadow:none;
  }
  #changePasswordModal .profile-modal .btn.ghost{
    border:1px solid var(--pf-line);
    background:var(--pf-surface-2);
    color:var(--pf-ink);
  }
  #changePasswordModal .profile-modal .btn.primary{
    border-color:transparent;
    background:linear-gradient(135deg,var(--pf-accent),var(--pf-accent-2));
    color:#fff;
    box-shadow:0 8px 22px rgba(120,95,50,.18);
  }
  @media(max-width:680px){
    #changePasswordModal .profile-grid{
      grid-template-columns:1fr;
    }
  }
  .modal-toolbar{
    display:flex;
    justify-content:space-between;
    align-items:center;
    gap:12px;
    flex-wrap:wrap;
  }
  .selection-card{
    border:1px solid var(--line);
    background:#f9fbfe;
    border-radius:18px;
    padding:16px;
    display:flex;
    flex-direction:column;
    gap:6px;
  }
  .selection-card strong{
    font-size:16px;
  }
  .metric-grid{
    display:grid;
    grid-template-columns:repeat(4,minmax(0,1fr));
    gap:14px;
  }
  .metric-card{
    border:1px solid var(--line);
    background:linear-gradient(180deg,#fff,#f8fbff);
    border-radius:18px;
    padding:16px;
    display:flex;
    flex-direction:column;
    gap:6px;
  }
  .metric-card span{
    font-size:12px;
    text-transform:uppercase;
    letter-spacing:.12em;
    color:var(--ink-soft);
  }
  .metric-card strong{
    font-size:26px;
    letter-spacing:-.04em;
  }
  .metric-card small{
    color:var(--ink-soft);
    line-height:1.5;
  }
  .form-grid{
    display:grid;
    grid-template-columns:repeat(2,minmax(0,1fr));
    gap:14px;
  }
  .form-grid .full{
    grid-column:1 / -1;
  }
  @media (max-width: 1100px){
    .hero,.admin-section{grid-template-columns:1fr}
    .metric-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
  }
  @media (max-width: 720px){
    .shell{padding:16px}
    .hero{padding:20px}
    .hero h1{font-size:34px}
    .toolbar{align-items:flex-start}
    .modal-backdrop{padding:12px}
    .form-grid{grid-template-columns:1fr}
    .metric-grid{grid-template-columns:1fr}
  }

  /* Aiklava UI kit v2 */
  :root{
    --ink:#1D2740;
    --ink-soft:#6B7894;
    --line:#AFC1DD;
    --sky:#79BCFF;
    --navy:#4B82FF;
    --navy-deep:#8066F0;
    --bg:#F6FAFF;
    --surface:rgba(255,255,255,.76);
    --surface-soft:rgba(253,254,255,.72);
    --success:#24966F;
    --danger:#CA4A8C;
    --radius-xl:22px;
    --radius-lg:18px;
    --radius-md:14px;
  }
  body{
    font-family:Inter,"SF Pro Display","Segoe UI",Arial,sans-serif;
    color:var(--ink);
    background:
      linear-gradient(135deg,#FCFEFF 0%,#F6FAFF 52%,#EDF6FF 100%);
    overflow-x:hidden;
  }
  .shell{max-width:1440px;padding:32px}
  .hero,.panel,.admin-card,.modal,.selection-card,.metric-card{
    background:linear-gradient(135deg,rgba(255,255,255,.92),rgba(248,251,255,.88) 52%,rgba(239,247,255,.86));
    border:1px solid rgba(175,193,221,.34);
    box-shadow:0 24px 56px rgba(77,111,166,.14);
    backdrop-filter:blur(18px);
  }
  .hero{
    color:var(--ink);
    border-radius:34px;
    padding:30px;
    grid-template-columns:minmax(0,1fr) 340px;
  }
  .eyebrow,.hero-side .label,.panel-title,.admin-card h3,th{
    color:#8A96AD;
    letter-spacing:.08em;
  }
  .hero h1{
    color:#4F83FF;
    letter-spacing:0;
    font-weight:850;
    overflow-wrap:anywhere;
  }
  .hero p,.hero-side .meta,.admin-card p,.service-card p,.field-note,.message{
    color:var(--ink-soft);
    overflow-wrap:anywhere;
  }
  .hero-side{
    background:rgba(255,255,255,.72);
    border:1px solid rgba(175,193,221,.28);
    border-radius:24px;
    box-shadow:0 16px 36px rgba(77,111,166,.10);
  }
  .hero-side .value{color:var(--ink);font-weight:850;letter-spacing:0}
  .panel{border-radius:28px}
  #authPanel{
    width:min(560px,100%);
    margin:22px auto 0;
  }
  #dashboardPanel{
    width:100%;
    margin-top:22px;
  }
  @media (min-width:961px){
    .portal-authenticated .hero{
      grid-template-columns:minmax(0,1fr) 300px;
      align-items:center;
      padding:20px 24px;
      margin-bottom:20px;
      border-radius:30px;
    }
    .portal-authenticated .hero h1{
      margin-bottom:8px;
      font-size:32px;
      line-height:1.05;
    }
    .portal-authenticated .hero p{
      max-width:860px;
      font-size:14px;
      line-height:1.48;
    }
    .portal-authenticated .hero-side{
      padding:14px 16px;
      border-radius:20px;
    }
    .portal-authenticated .hero-side .value{
      margin-bottom:6px;
      font-size:22px;
    }
    .portal-authenticated .grid{
      margin-top:0;
    }
    #dashboardPanel:not(.hidden){
      position:relative;
      overflow:hidden;
      padding:18px;
      border-radius:34px;
      background:linear-gradient(135deg,rgba(255,255,255,.96),rgba(248,251,255,.96) 50%,rgba(239,247,255,.94));
      border:1px solid rgba(201,216,238,.56);
      box-shadow:0 30px 70px rgba(77,111,166,.16);
    }
    #dashboardPanel:not(.hidden) .panel-body{
      position:relative;
      z-index:1;
      display:grid;
      grid-template-columns:minmax(0,1fr);
      gap:20px;
      min-height:640px;
      padding:0;
    }
    #dashboardPanel:not(.hidden) .toolbar{
      min-height:54px;
      margin:0;
      padding:12px 18px;
      border:1px solid rgba(175,193,221,.24);
      border-radius:22px;
      background:rgba(255,255,255,.64);
      box-shadow:0 14px 34px rgba(77,111,166,.08);
    }
    #dashboardPanel:not(.hidden) .toolbar h2{
      color:#4F83FF;
      font-size:30px;
      line-height:1.05;
    }
    #dashboardPanel:not(.hidden) .toolbar p{
      max-width:620px;
      font-size:13px;
    }
    #dashboardPanel:not(.hidden) .toolbar-actions{
      justify-content:flex-end;
      gap:8px;
    }
    #dashboardPanel:not(.hidden) .toolbar-actions .btn{
      min-height:38px;
      padding:9px 12px;
      border-radius:14px;
      font-size:13px;
    }
    #dashboardPanel:not(.hidden) #dashboardMessage{
      min-height:0;
      margin:0;
      padding:0 6px;
    }
    #dashboardPanel:not(.hidden) #dashboardMessage:empty{
      display:none;
    }
    #dashboardPanel:not(.hidden) .content-section,
    #dashboardPanel:not(.hidden) .admin-section{
      padding:24px;
      border:1px solid rgba(175,193,221,.22);
      border-radius:30px;
      background:rgba(255,255,255,.56);
      box-shadow:0 20px 44px rgba(77,111,166,.10);
    }
    #dashboardPanel:not(.hidden) .content-section.hidden,
    #dashboardPanel:not(.hidden) .admin-section.hidden{
      display:none!important;
    }
    #dashboardPanel:not(.hidden) .section-intro{
      gap:8px;
      max-width:720px;
    }
    #dashboardPanel:not(.hidden) .section-intro h3{
      color:#4F83FF;
      font-size:38px;
      line-height:1.04;
    }
    #dashboardPanel:not(.hidden) .section-intro p{
      font-size:15px;
      line-height:1.58;
    }
    #dashboardPanel:not(.hidden) .service-grid{
      grid-template-columns:repeat(3,minmax(0,1fr));
      gap:18px;
    }
    #dashboardPanel:not(.hidden) .service-card{
      min-height:188px;
      padding:18px;
      border-radius:24px;
    }
    #dashboardPanel:not(.hidden) .service-card h3{
      font-size:20px;
      line-height:1.12;
    }
    #dashboardPanel:not(.hidden) .service-card .btn{
      align-self:flex-start;
      margin-top:2px;
    }
    #dashboardPanel:not(.hidden) .admin-actions{
      grid-template-columns:repeat(4,minmax(0,1fr));
    }
    #dashboardPanel:not(.hidden) .admin-card{
      min-height:190px;
      padding:20px;
      border-radius:24px;
    }
  }
  @media (min-width:1180px){
    #dashboardPanel:not(.hidden)::before,
    #dashboardPanel:not(.hidden)::after{
      content:"";
      position:absolute;
      top:98px;
      bottom:34px;
      border:1px solid rgba(175,193,221,.20);
      border-radius:24px;
      pointer-events:none;
      box-shadow:0 18px 38px rgba(77,111,166,.08);
    }
    #dashboardPanel:not(.hidden)::before{
      left:18px;
      width:180px;
      background:
        linear-gradient(135deg,rgba(255,255,255,.64),rgba(253,254,255,.34)),
        repeating-linear-gradient(to bottom,rgba(79,131,255,.12) 0 40px,rgba(255,255,255,.38) 40px 78px);
    }
    #dashboardPanel:not(.hidden)::after{
      right:18px;
      width:128px;
      background:
        linear-gradient(135deg,rgba(255,255,255,.62),rgba(253,254,255,.36)),
        radial-gradient(circle at 50% 46px,rgba(122,216,197,.36),transparent 28px),
        radial-gradient(circle at 50% 138px,rgba(164,148,255,.28),transparent 28px),
        radial-gradient(circle at 50% 230px,rgba(255,200,160,.32),transparent 28px);
    }
    #dashboardPanel:not(.hidden) .panel-body{
      grid-template-columns:180px minmax(0,1fr) 128px;
      grid-template-areas:
        "top top top"
        "left main side"
        "admin admin admin";
    }
    #dashboardPanel:not(.hidden) .toolbar{
      grid-area:top;
    }
    #dashboardPanel:not(.hidden) #dashboardMessage{
      grid-area:left;
      align-self:start;
      justify-self:stretch;
      max-width:520px;
      padding:14px;
      border:1px solid rgba(175,193,221,.18);
      border-radius:18px;
      background:rgba(255,255,255,.34);
    }
    #dashboardPanel:not(.hidden) .content-section{
      grid-area:main;
    }
    #dashboardPanel:not(.hidden) .admin-section{
      grid-area:admin;
    }
  }
  @media (min-width:1320px){
    #dashboardPanel:not(.hidden) .service-grid{
      grid-template-columns:repeat(4,minmax(0,1fr));
    }
  }
  @media (min-width:961px) and (max-width:1179px){
    #dashboardPanel:not(.hidden) .service-grid,
    #dashboardPanel:not(.hidden) .admin-actions{
      grid-template-columns:repeat(2,minmax(0,1fr));
    }
  }
  .panel-head{padding:24px 26px 0}
  .panel-body{padding:22px 26px 26px}
  input,textarea,select{
    border-color:rgba(175,193,221,.38);
    border-radius:16px;
    background:rgba(255,255,255,.86);
    box-shadow:inset 0 1px 0 rgba(255,255,255,.8);
  }
  input:focus,textarea:focus,select:focus{
    border-color:rgba(121,188,255,.72);
    box-shadow:0 0 0 4px rgba(121,188,255,.18);
  }
  .btn{
    border-radius:16px;
    border:1px solid rgba(175,193,221,.34);
    box-shadow:0 12px 28px rgba(77,111,166,.10);
  }
  .btn.primary,.btn.dark{
    color:#fff;
    border-color:transparent;
    background:linear-gradient(135deg,#9AD8FF 0%,#6C98FF 58%,#A494FF 100%);
    box-shadow:0 16px 36px rgba(77,111,166,.18);
  }
  .btn.soft{
    background:rgba(255,255,255,.78);
    color:#4B82FF;
    border-color:rgba(121,188,255,.28);
  }
  .btn.danger{
    background:rgba(255,255,255,.78);
    color:#CA4A8C;
    border-color:rgba(202,74,140,.20);
  }
  .service-grid,.admin-actions{gap:18px}
  .service-card,.admin-card{
    border-radius:22px;
    background:rgba(255,255,255,.70);
    border:1px solid rgba(175,193,221,.24);
    box-shadow:0 16px 36px rgba(77,111,166,.10);
  }
  .service-card:hover,.admin-card:hover{
    transform:translateY(-2px);
    border-color:rgba(121,188,255,.38);
    box-shadow:0 22px 44px rgba(77,111,166,.16);
  }
  .service-icon{
    width:48px;
    height:48px;
    border-radius:16px;
    background:linear-gradient(135deg,#B2F2E6,#7AD8C5);
    color:#24966F;
  }
  .service-card:nth-child(4n+1) .service-icon{background:linear-gradient(135deg,#9AD8FF,#A494FF);color:#4B82FF}
  .service-card:nth-child(4n+2) .service-icon{background:linear-gradient(135deg,#B2F2E6,#7AD8C5);color:#24966F}
  .service-card:nth-child(4n+3) .service-icon{background:linear-gradient(135deg,#E5D8FF,#BFAEFF);color:#8066F0}
  .service-card:nth-child(4n+4) .service-icon{background:linear-gradient(135deg,#FFE5CF,#FFC8A0);color:#CE6F2B}
  .service-card h3,.toolbar h2,.section-intro h3,.modal-head h3,.metric-card strong{
    letter-spacing:0;
    color:var(--ink);
  }
  table{
    border-collapse:separate;
    border-spacing:0;
    border-color:rgba(175,193,221,.24);
    overflow:hidden;
    box-shadow:0 12px 28px rgba(77,111,166,.08);
  }
  th{background:#F7FBFF}
  td{background:rgba(255,255,255,.84)}
  .role-pill.admin,.status-pill.active{background:#D9F3E8;color:#24966F}
  .role-pill.user{background:#EDF6FF;color:#4B82FF}
  .status-pill.inactive{background:#FFE1EF;color:#CA4A8C}
  .empty{
    border-color:rgba(175,193,221,.42);
    background:rgba(255,255,255,.58);
  }
  .modal-backdrop{background:rgba(29,39,64,.28);backdrop-filter:blur(16px)}
  .modal{border-radius:30px}
  .icon-btn{border-radius:14px;background:rgba(255,255,255,.82)}
  .modal.queue-modal{
    width:min(1280px,100%);
  }
  .modal.full-modal{
    width:min(1320px,calc(100vw - 32px));
    max-height:calc(100vh - 32px);
  }
  .user-table-wrap{
    overflow:auto;
    max-height:min(48vh,520px);
    border-radius:18px;
  }
  .user-select-cell{
    width:44px;
    text-align:center;
    vertical-align:middle;
  }
  .user-select-cell input,
  .bulk-check-grid input,
  .checkbox-inline input{
    width:auto;
  }
  .user-meta{
    color:var(--ink-soft);
    display:flex;
    flex-wrap:wrap;
    gap:6px 10px;
    margin-top:3px;
  }
  .user-meta span{
    overflow-wrap:anywhere;
  }
  .user-service-list{
    display:flex;
    flex-wrap:wrap;
    gap:6px;
  }
  .code-chip{
    display:inline-flex;
    align-items:center;
    border:1px solid rgba(175,193,221,.52);
    border-radius:999px;
    background:rgba(255,255,255,.76);
    color:var(--ink-soft);
    padding:4px 8px;
    font-size:12px;
    font-weight:700;
  }
  .admin-bulk-summary{
    display:flex;
    align-items:center;
    justify-content:space-between;
    gap:12px;
    flex-wrap:wrap;
    padding:12px 14px;
    border:1px solid rgba(175,193,221,.32);
    border-radius:18px;
    background:rgba(255,255,255,.62);
  }
  .bulk-check-grid{
    display:grid;
    grid-template-columns:repeat(auto-fit,minmax(230px,1fr));
    gap:10px;
  }
  .bulk-check-card{
    display:flex;
    align-items:flex-start;
    gap:10px;
    padding:12px;
    border:1px solid rgba(175,193,221,.32);
    border-radius:16px;
    background:rgba(255,255,255,.72);
    color:var(--ink);
  }
  .bulk-check-card strong{
    display:block;
    font-size:13px;
  }
  .bulk-check-card small{
    display:block;
    margin-top:3px;
    color:var(--ink-soft);
    line-height:1.35;
  }
  .import-preview{
    overflow:auto;
    max-height:340px;
    border-radius:18px;
  }
  .import-help{
    display:grid;
    gap:8px;
    padding:14px;
    border:1px solid rgba(175,193,221,.32);
    border-radius:18px;
    background:rgba(255,255,255,.62);
    color:var(--ink-soft);
    line-height:1.5;
  }
  .import-help code{
    color:var(--ink);
    font-weight:700;
  }
  .queue-dashboard{
    gap:18px;
  }
  .queue-toolbar{
    display:flex;
    align-items:center;
    gap:10px;
    flex-wrap:wrap;
  }
  .queue-budget-control{
    display:flex;
    align-items:center;
    gap:8px;
    color:var(--ink-soft);
    font-size:13px;
    font-weight:700;
  }
  .queue-budget-control input{
    width:96px;
  }
  .queue-budget-hint{
    flex:1;
    min-width:240px;
    color:var(--ink-soft);
    font-size:12px;
    line-height:1.35;
  }
  .queue-summary-grid{
    display:grid;
    grid-template-columns:repeat(4,minmax(0,1fr));
    gap:14px;
  }
  .queue-section{
    display:grid;
    gap:12px;
    padding:16px;
    border:1px solid rgba(175,193,221,.24);
    border-radius:22px;
    background:rgba(255,255,255,.54);
    box-shadow:0 14px 32px rgba(77,111,166,.08);
  }
  .queue-section-head{
    display:flex;
    justify-content:space-between;
    gap:12px;
    align-items:flex-start;
  }
  .queue-section-head h4{
    margin:0;
    font-size:16px;
    color:var(--ink);
  }
  .queue-section-head p{
    margin:6px 0 0;
    color:var(--ink-soft);
    font-size:13px;
    line-height:1.45;
  }
  .queue-table-wrap{
    overflow:auto;
    border-radius:16px;
  }
  .queue-table{
    min-width:920px;
  }
  .queue-table td{
    max-width:280px;
    overflow-wrap:anywhere;
  }
  .queue-status{
    display:inline-flex;
    align-items:center;
    justify-content:center;
    padding:6px 10px;
    border-radius:999px;
    font-size:12px;
    font-weight:800;
    white-space:nowrap;
  }
  .queue-status.queued{background:#EDF6FF;color:#4B82FF}
  .queue-status.running,.queue-status.extracting{background:#FFF0DB;color:#B4692C}
  .queue-status.failed{background:#FFE1EF;color:#CA4A8C}
  .queue-status.succeeded,.queue-status.done{background:#D9F3E8;color:#24966F}
  .queue-error{
    color:#CA4A8C;
    font-weight:700;
  }
  .queue-muted{
    color:var(--ink-soft);
  }
  .queue-mono{
    font-family:"SFMono-Regular",Consolas,"Liberation Mono",monospace;
    font-size:12px;
  }
  #aiBaseUrlStatusValue{
    font-size:16px;
    line-height:1.35;
    overflow-wrap:anywhere;
  }
  .gateway-section{
    border:1px solid rgba(175,193,221,.42);
    border-radius:18px;
    background:rgba(255,255,255,.58);
    padding:16px;
    display:grid;
    gap:14px;
  }
  .gateway-section-head{
    display:flex;
    justify-content:space-between;
    align-items:flex-start;
    gap:12px;
    flex-wrap:wrap;
  }
  .gateway-section-head h4{
    margin:0;
    font-size:16px;
    letter-spacing:-.02em;
  }
  .gateway-section-head p{
    margin:5px 0 0;
    color:var(--ink-soft);
    font-size:13px;
    line-height:1.5;
  }
  .gateway-list{
    display:grid;
    gap:12px;
  }
  .gateway-row{
    border:1px solid rgba(175,193,221,.48);
    border-radius:16px;
    background:linear-gradient(180deg,#fff,#f8fbff);
    padding:14px;
    display:grid;
    grid-template-columns:minmax(150px,1.2fr) minmax(170px,1.4fr) 120px 110px auto;
    gap:12px;
    align-items:end;
  }
  .gateway-row.local{
    grid-template-columns:minmax(140px,1fr) minmax(220px,1.6fr) minmax(150px,1fr) 120px auto;
  }
  .gateway-row .full-row{
    grid-column:1 / -1;
  }
  .gateway-row-actions{
    display:flex;
    gap:8px;
    justify-content:flex-end;
    flex-wrap:wrap;
  }
  .gateway-checks{
    display:flex;
    gap:12px;
    align-items:center;
    flex-wrap:wrap;
  }
  .checkbox-inline{
    flex-direction:row;
    align-items:center;
    gap:8px;
    color:var(--ink);
    font-size:13px;
  }
  .checkbox-inline input{
    width:auto;
  }
  .ai-policy-panel{
    border:1px solid var(--line);
    border-radius:18px;
    padding:14px;
    background:rgba(255,255,255,.68);
    box-shadow:0 10px 28px rgba(91,133,190,.08);
  }
  .ai-policy-panel strong{
    display:block;
    font-size:14px;
    margin-bottom:8px;
  }
  .ai-policy-grid{
    display:grid;
    grid-template-columns:repeat(2,minmax(0,1fr));
    gap:8px 14px;
  }
  .ai-policy-grid .checkbox-inline{
    font-size:14px;
    align-items:flex-start;
  }
  .ai-policy-grid small{
    display:block;
    color:var(--ink-soft);
    font-size:12px;
    line-height:1.35;
    margin-top:2px;
  }
  .gateway-models{
    color:var(--ink-soft);
    font-size:12px;
    line-height:1.45;
  }
  .model-capabilities-wrap{
    max-height:min(58vh,620px);
  }
  .model-capabilities-table th:nth-child(3),
  .model-capabilities-table th:nth-child(4),
  .model-capabilities-table th:nth-child(5),
  .model-capabilities-table th:nth-child(6),
  .model-capabilities-table td:nth-child(3),
  .model-capabilities-table td:nth-child(4),
  .model-capabilities-table td:nth-child(5),
  .model-capabilities-table td:nth-child(6){
    width:140px;
    text-align:center;
  }
  .model-cap-check{
    justify-content:center;
    min-width:0;
  }

  /* Admin modal polish: align production modals with redesign prototypes. */
  body.portal-admin-dashboard #usersModal .modal.full-modal{
    width:min(1160px,calc(100vw - 48px));
    max-height:calc(100dvh - 48px);
  }
  body.portal-admin-dashboard #bulkUsersModal .modal.full-modal{
    width:min(1060px,calc(100vw - 48px));
    max-height:calc(100dvh - 48px);
  }
  body.portal-admin-dashboard #aiSettingsModal .modal.wide{
    width:min(960px,calc(100vw - 48px));
    max-height:calc(100dvh - 48px);
  }
  body.portal-admin-dashboard #vacationModal .modal{
    width:min(760px,calc(100vw - 48px));
    max-height:calc(100dvh - 48px);
  }
  body.portal-admin-dashboard #bulkUsersModal .modal-body,
  body.portal-admin-dashboard #aiSettingsModal .modal-body,
  body.portal-admin-dashboard #vacationModal .modal-body{
    padding:18px 24px 24px;
    gap:16px;
  }
  body.portal-admin-dashboard .editor-grid{
    display:grid;
    grid-template-columns:minmax(0,1fr) minmax(0,1fr);
    gap:22px;
    align-items:start;
  }
  body.portal-admin-dashboard .editor-column{
    display:flex;
    flex-direction:column;
    gap:14px;
    min-width:0;
  }
  body.portal-admin-dashboard .form-grid.compact{
    grid-template-columns:repeat(2,minmax(0,1fr));
    gap:12px;
  }
  body.portal-admin-dashboard .form-grid.compact .full{
    grid-column:1 / -1;
  }
  body.portal-admin-dashboard .user-editor-panel{
    width:min(900px,100%);
    margin:0 auto;
    padding:18px 22px 20px;
    border-radius:28px;
    background:color-mix(in srgb,var(--adm-surface) 72%,transparent);
    box-shadow:0 18px 50px rgba(80,55,20,.10);
  }
  body.portal-admin-dashboard .user-editor-panel>strong{
    display:block;
    margin:0 0 4px;
    font-size:22px;
    color:var(--adm-ink);
  }
  body.portal-admin-dashboard .visually-hidden-control{
    position:absolute!important;
    width:1px!important;
    height:1px!important;
    padding:0!important;
    margin:-1px!important;
    overflow:hidden!important;
    clip:rect(0,0,0,0)!important;
    white-space:nowrap!important;
    border:0!important;
  }
  body.portal-admin-dashboard #bulkUsersModal .selection-card.compact-card,
  body.portal-admin-dashboard #userEditorCard .ai-policy-panel{
    padding:0;
    border:0;
    background:transparent;
    box-shadow:none;
  }
  body.portal-admin-dashboard #bulkUsersModal .selection-card.compact-card>strong,
  body.portal-admin-dashboard #userEditorCard .ai-policy-panel>strong,
  body.portal-admin-dashboard #userEditorCard .pick-label{
    display:block;
    margin:0 0 8px;
    color:var(--adm-ink-soft);
    font-size:13px;
    font-weight:800;
  }
  body.portal-admin-dashboard #bulkUsersModal .bulk-check-grid,
  body.portal-admin-dashboard #userEditorCard .pick-grid,
  body.portal-admin-dashboard #userEditorCard .ai-policy-grid{
    display:flex;
    flex-wrap:wrap;
    gap:8px;
  }
  body.portal-admin-dashboard #bulkUsersModal .bulk-check-card,
  body.portal-admin-dashboard #userEditorCard .pick-card,
  body.portal-admin-dashboard #userEditorCard .checkbox-inline,
  body.portal-admin-dashboard #aiSettingsModal .checkbox-inline,
  body.portal-admin-dashboard #modelCapabilitiesModal .checkbox-inline{
    display:inline-flex;
    flex-direction:row;
    align-items:center;
    gap:8px;
    width:auto;
    min-height:0;
    padding:8px 12px;
    border:1px solid var(--adm-line,var(--line));
    border-radius:999px;
    background:var(--adm-field,var(--field));
    color:var(--adm-ink-soft,var(--ink-soft));
    font-size:13px;
    font-weight:800;
    line-height:1.2;
    cursor:pointer;
    user-select:none;
  }
  body.portal-admin-dashboard #bulkUsersModal .bulk-check-card small,
  body.portal-admin-dashboard #userEditorCard .pick-card small,
  body.portal-admin-dashboard #userEditorCard .checkbox-inline small{
    display:none;
  }
  body.portal-admin-dashboard #bulkUsersModal .bulk-check-card:has(input:checked),
  body.portal-admin-dashboard #userEditorCard .pick-card:has(input:checked),
  body.portal-admin-dashboard #userEditorCard .checkbox-inline:has(input:checked),
  body.portal-admin-dashboard #aiSettingsModal .checkbox-inline:has(input:checked),
  body.portal-admin-dashboard #modelCapabilitiesModal .checkbox-inline:has(input:checked){
    border-color:transparent;
    background:var(--adm-accent-soft,var(--accent-soft));
    color:var(--adm-accent-ink,var(--accent-ink));
  }
  body.portal-admin-dashboard .user-select-cell input[type="checkbox"],
  body.portal-admin-dashboard #bulkUsersModal .bulk-check-card input[type="checkbox"],
  body.portal-admin-dashboard #userEditorCard .pick-card input[type="checkbox"],
  body.portal-admin-dashboard #userEditorCard .checkbox-inline input[type="checkbox"],
  body.portal-admin-dashboard #aiSettingsModal .checkbox-inline input[type="checkbox"],
  body.portal-admin-dashboard #modelCapabilitiesModal .checkbox-inline input[type="checkbox"]{
    appearance:none;
    -webkit-appearance:none;
    display:grid;
    place-items:center;
    flex:0 0 auto;
    width:16px!important;
    height:16px!important;
    min-height:0!important;
    margin:0!important;
    padding:0!important;
    border:1.5px solid var(--adm-ink-faint,var(--ink-faint));
    border-radius:5px;
    background:transparent;
    box-shadow:none;
  }
  body.portal-admin-dashboard .user-select-cell input[type="checkbox"]:checked,
  body.portal-admin-dashboard #bulkUsersModal .bulk-check-card input[type="checkbox"]:checked,
  body.portal-admin-dashboard #userEditorCard .pick-card input[type="checkbox"]:checked,
  body.portal-admin-dashboard #userEditorCard .checkbox-inline input[type="checkbox"]:checked,
  body.portal-admin-dashboard #aiSettingsModal .checkbox-inline input[type="checkbox"]:checked,
  body.portal-admin-dashboard #modelCapabilitiesModal .checkbox-inline input[type="checkbox"]:checked{
    border-color:var(--adm-accent-ink,var(--accent-ink));
    background:var(--adm-accent-ink,var(--accent-ink));
  }
  body.portal-admin-dashboard .user-select-cell input[type="checkbox"]:checked::before,
  body.portal-admin-dashboard #bulkUsersModal .bulk-check-card input[type="checkbox"]:checked::before,
  body.portal-admin-dashboard #userEditorCard .pick-card input[type="checkbox"]:checked::before,
  body.portal-admin-dashboard #userEditorCard .checkbox-inline input[type="checkbox"]:checked::before,
  body.portal-admin-dashboard #aiSettingsModal .checkbox-inline input[type="checkbox"]:checked::before,
  body.portal-admin-dashboard #modelCapabilitiesModal .checkbox-inline input[type="checkbox"]:checked::before{
    content:"";
    width:8px;
    height:5px;
    border:2px solid #fff;
    border-top:0;
    border-right:0;
    transform:rotate(-45deg) translate(1px,-1px);
  }
  body.portal-admin-dashboard #aiSettingsModal #aiSettingsForm{
    display:grid;
    grid-template-columns:minmax(0,1fr) minmax(0,1fr);
    gap:14px;
  }
  body.portal-admin-dashboard #aiSettingsModal #aiSettingsForm>.mini-actions,
  body.portal-admin-dashboard #aiSettingsModal #aiSettingsForm>.message{
    grid-column:1 / -1;
  }
  body.portal-admin-dashboard #aiSettingsModal .gateway-section{
    align-self:start;
    padding:16px;
    border-color:var(--adm-line,var(--line));
    border-radius:24px;
    background:color-mix(in srgb,var(--adm-surface) 76%,transparent);
  }
  body.portal-admin-dashboard #aiSettingsModal .gateway-row,
  body.portal-admin-dashboard #aiSettingsModal .gateway-row.local{
    grid-template-columns:minmax(0,1fr) minmax(0,1fr);
    align-items:end;
    padding:12px;
    border-radius:18px;
    background:var(--adm-surface,var(--surface));
  }
  body.portal-admin-dashboard #aiSettingsModal .gateway-row label:nth-child(3){
    max-width:130px;
  }
  body.portal-admin-dashboard #aiSettingsModal .gateway-row .checkbox-inline,
  body.portal-admin-dashboard #aiSettingsModal .gateway-row-actions,
  body.portal-admin-dashboard #aiSettingsModal .gateway-models,
  body.portal-admin-dashboard #aiSettingsModal .gateway-checks,
  body.portal-admin-dashboard #aiSettingsModal .full-row{
    grid-column:1 / -1;
  }
  body.portal-admin-dashboard #aiSettingsModal .gateway-row-actions{
    justify-content:flex-start;
  }
  body.portal-admin-dashboard #vacationModal .metric-grid{
    grid-template-columns:repeat(4,minmax(0,1fr));
  }
  body.portal-admin-dashboard #vacationModal .selection-card{
    padding:18px 20px;
    border-radius:24px;
  }
  body.portal-admin-dashboard #vacationModal .mini-actions{
    justify-content:flex-start;
  }
  @media(max-width:860px){
    body.portal-admin-dashboard .editor-grid,
    body.portal-admin-dashboard #aiSettingsModal #aiSettingsForm{
      grid-template-columns:1fr;
    }
    body.portal-admin-dashboard #vacationModal .metric-grid{
      grid-template-columns:repeat(2,minmax(0,1fr));
    }
  }

  /* Redesign slice 1: auth screen from Aiklava-Portal-Redesign/screens/login.html */
  body:not(.portal-authenticated){
    --auth-accent:#ec7a1c;
    --auth-accent-2:#ffb24d;
    --auth-accent-soft:#fdeedd;
    --auth-accent-ink:#c4641a;
    --auth-lime:#86b93b;
    --auth-bg:#f1ece3;
    --auth-surface:rgba(255,255,255,.74);
    --auth-surface-2:rgba(255,255,255,.6);
    --auth-ink:#2a2620;
    --auth-ink-soft:#6c6457;
    --auth-ink-faint:#9c9484;
    --auth-line:rgba(120,100,70,.14);
    --auth-brd:rgba(255,255,255,.7);
    --auth-shadow:0 10px 30px rgba(120,95,50,.08);
    --auth-shadow-hi:0 26px 60px rgba(120,95,50,.16);
    --auth-field:rgba(255,255,255,.7);
    --auth-blob-a:#ffcf8e;
    --auth-blob-b:#d6e7a6;
    --auth-blob-a-op:.55;
    --auth-blob-b-op:.5;
    min-height:100vh;
    color:var(--auth-ink);
    background:var(--auth-bg);
    overflow-x:hidden;
    transition:background .2s cubic-bezier(.4,0,.2,1),color .2s cubic-bezier(.4,0,.2,1);
  }
  [data-theme="dark"] body:not(.portal-authenticated){
    --auth-accent:#ff7a1a;
    --auth-accent-2:#ffae5c;
    --auth-accent-soft:rgba(255,140,40,.16);
    --auth-accent-ink:#ffae5c;
    --auth-lime:#a7d34e;
    --auth-bg:#16130f;
    --auth-surface:rgba(40,34,28,.6);
    --auth-surface-2:rgba(54,46,38,.5);
    --auth-ink:#f4efe6;
    --auth-ink-soft:#b3a899;
    --auth-ink-faint:#80766a;
    --auth-line:rgba(255,255,255,.08);
    --auth-brd:rgba(255,255,255,.08);
    --auth-shadow:0 16px 40px rgba(0,0,0,.45);
    --auth-shadow-hi:0 28px 64px rgba(0,0,0,.55);
    --auth-field:rgba(255,255,255,.05);
    --auth-blob-a:#ff8a2e;
    --auth-blob-b:#7a4a1f;
    --auth-blob-a-op:.24;
    --auth-blob-b-op:.32;
  }
  @keyframes bootbounce{
    0%,35%,100%{transform:translateY(0) scaleY(1)}
    45%{transform:translateY(-11px) scaleY(1.03)}
    56%{transform:translateY(0) scaleY(.92)}
    64%{transform:translateY(-5px) scaleY(1.01)}
    72%{transform:translateY(0) scaleY(.97)}
    78%{transform:translateY(0) scaleY(1)}
  }
  @keyframes bootspin{
    to{transform:rotate(360deg)}
  }
  @keyframes bootpop{
    from{transform:scale(.5);opacity:0}
    to{transform:scale(1);opacity:1}
  }
  @keyframes bootshim{
    0%{transform:translateX(-120%)}
    100%{transform:translateX(280%)}
  }
  .boot-gate{
    position:fixed;
    inset:0;
    z-index:20000;
    display:grid;
    place-items:center;
    background:var(--auth-bg,var(--bg,#f1ece3));
    color:var(--auth-ink,var(--ink,#2a2620));
    transition:opacity .45s ease,visibility .45s ease;
  }
  .boot-gate[hidden]{
    display:grid;
    visibility:hidden;
    opacity:0;
    pointer-events:none;
  }
  .boot-gate-inner{
    position:relative;
    z-index:1;
    display:flex;
    flex-direction:column;
    align-items:center;
    gap:20px;
    padding:32px;
    text-align:center;
  }
  .boot-gate-logo{
    width:76px;
    height:76px;
    display:block;
    object-fit:contain;
    transform-origin:center bottom;
    filter:drop-shadow(0 9px 16px rgba(236,122,28,.16));
    animation:bootbounce 2s ease-in-out infinite;
  }
  .boot-gate-wordmark{
    color:var(--auth-ink,var(--ink,#2a2620));
    font-size:20px;
    font-weight:800;
    letter-spacing:-.01em;
  }
  .boot-gate-eyebrow{
    display:block;
    margin-top:3px;
    color:var(--auth-ink-faint,var(--ink-faint,#9c9484));
    font-size:10.5px;
    font-weight:800;
    letter-spacing:.16em;
    text-transform:uppercase;
  }
  .boot-gate-indicator{
    height:40px;
    display:grid;
    place-items:center;
  }
  .boot-gate-spinner{
    width:34px;
    height:34px;
    border-radius:50%;
    border:3px solid var(--auth-accent-soft,var(--accent-soft,#fdeedd));
    border-top-color:var(--auth-accent,var(--accent,#ec7a1c));
    animation:bootspin .8s linear infinite;
  }
  .boot-gate-check{
    display:none;
    width:38px;
    height:38px;
    color:var(--auth-lime,var(--ok,#86b93b));
  }
  .boot-gate.ok .boot-gate-spinner{
    display:none;
  }
  .boot-gate.ok .boot-gate-check{
    display:block;
    animation:bootpop .4s cubic-bezier(.2,1.3,.4,1);
  }
  .boot-gate-status{
    min-height:20px;
    color:var(--auth-ink-soft,var(--ink-soft,#6c6457));
    font-size:14px;
    font-weight:600;
    letter-spacing:-.005em;
  }
  .boot-gate-shimmer{
    position:relative;
    width:190px;
    height:4px;
    overflow:hidden;
    border-radius:999px;
    background:var(--auth-accent-soft,var(--accent-soft,#fdeedd));
  }
  .boot-gate-shimmer::after{
    content:"";
    position:absolute;
    inset:0;
    width:42%;
    border-radius:999px;
    background:linear-gradient(90deg,transparent,var(--auth-accent,var(--accent,#ec7a1c)),transparent);
    animation:bootshim 1.25s ease-in-out infinite;
  }
  .boot-gate.ok .boot-gate-shimmer::after{
    width:100%;
    background:var(--auth-lime,var(--ok,#86b93b));
    animation:none;
  }
  @media(prefers-reduced-motion:reduce){
    .boot-gate-logo,
    .boot-gate-spinner,
    .boot-gate-check,
    .boot-gate-shimmer::after{
      animation:none;
    }
  }
  .auth-blob{
    position:fixed;
    border-radius:50%;
    filter:blur(100px);
    z-index:0;
    pointer-events:none;
  }
  .auth-blob.a{
    width:560px;
    height:560px;
    background:var(--auth-blob-a);
    opacity:var(--auth-blob-a-op);
    top:-180px;
    right:-60px;
  }
  .auth-blob.b{
    width:460px;
    height:460px;
    background:var(--auth-blob-b);
    opacity:var(--auth-blob-b-op);
    bottom:-180px;
    left:-120px;
  }
  .portal-authenticated .auth-blob,
  .portal-authenticated .themebtn{
    display:none;
  }
  .portal-authenticated .auth-brand,
  .portal-authenticated .auth-teaser,
  .portal-authenticated .auth-copy,
  .portal-authenticated .auth-fox,
  body:not(.portal-authenticated) .auth-dashboard-eyebrow,
  body:not(.portal-authenticated) .auth-dashboard-copy,
  body:not(.portal-authenticated) .dashboard-bang{
    display:none;
  }
  .themebtn{
    position:fixed;
    top:22px;
    right:24px;
    z-index:6;
    width:42px;
    height:42px;
    border-radius:999px;
    border:1px solid var(--auth-line);
    background:var(--auth-surface-2);
    color:var(--auth-ink-soft);
    display:grid;
    place-items:center;
    cursor:pointer;
    backdrop-filter:blur(12px);
    -webkit-backdrop-filter:blur(12px);
  }
  .themebtn svg{width:19px;height:19px}
  body:not(.portal-authenticated) .shell{
    position:relative;
    z-index:1;
    width:100%;
    max-width:none;
    min-height:100vh;
    padding:32px;
    display:grid;
    place-items:center;
  }
  body:not(.portal-authenticated) .shell::before,
  body:not(.portal-authenticated) .shell::after{
    content:none;
  }
  body:not(.portal-authenticated) .hero{
    width:100%;
    max-width:1000px;
    padding:0;
    background:transparent;
    border:0;
    box-shadow:none;
    color:var(--auth-ink);
    display:grid;
    grid-template-columns:1.05fr 440px;
    gap:40px;
    align-items:center;
  }
  body:not(.portal-authenticated) .auth-welcome{
    min-width:0;
  }
  body:not(.portal-authenticated) .auth-brand{
    display:flex;
    align-items:center;
    gap:12px;
    margin-bottom:30px;
  }
  body:not(.portal-authenticated) .auth-brand-logo{
    width:44px;
    height:44px;
    border-radius:13px;
    background:linear-gradient(135deg,var(--auth-accent),var(--auth-accent-2));
    display:grid;
    place-items:center;
    color:#fff;
    font-weight:900;
    font-size:20px;
    box-shadow:var(--auth-shadow);
  }
  body:not(.portal-authenticated) .auth-brand b{
    display:block;
    font-size:20px;
    letter-spacing:-.01em;
  }
  body:not(.portal-authenticated) .auth-brand .eyebrow{
    display:block;
    margin-top:2px;
    margin-bottom:0;
    color:var(--auth-ink-faint);
    font-size:11px;
    font-weight:800;
    letter-spacing:.16em;
  }
  body:not(.portal-authenticated) .hero h1{
    margin:0 0 14px;
    color:var(--auth-ink);
    font-size:40px;
    line-height:1.05;
    letter-spacing:-.02em;
    font-weight:800;
  }
  body:not(.portal-authenticated) .hero p{
    margin:0 0 28px;
    max-width:440px;
    color:var(--auth-ink-soft);
    font-size:15px;
    line-height:1.6;
  }
  body:not(.portal-authenticated) .hero-side{
    display:none;
  }
  body:not(.portal-authenticated) .auth-teaser{
    display:flex;
    flex-wrap:wrap;
    gap:10px;
  }
  body:not(.portal-authenticated) .auth-chip{
    display:flex;
    align-items:center;
    gap:9px;
    border-radius:999px;
    padding:9px 15px 9px 11px;
    color:var(--auth-ink-soft);
    font-size:13px;
    font-weight:700;
    background:var(--auth-surface);
    border:1px solid var(--auth-brd);
    box-shadow:var(--auth-shadow);
    backdrop-filter:blur(18px) saturate(1.3);
    -webkit-backdrop-filter:blur(18px) saturate(1.3);
  }
  body:not(.portal-authenticated) .auth-chip-icon{
    width:26px;
    height:26px;
    border-radius:8px;
    background:var(--auth-accent-soft);
    color:var(--auth-accent-ink);
    display:grid;
    place-items:center;
  }
  body:not(.portal-authenticated) .auth-chip-icon svg{
    width:15px;
    height:15px;
  }
  body:not(.portal-authenticated) .grid{
    width:100%;
    max-width:1000px;
    margin:0;
    position:absolute;
    left:50%;
    top:50%;
    transform:translate(-50%,-50%);
    display:grid;
    grid-template-columns:1.05fr 440px;
    gap:40px;
    pointer-events:none;
  }
  body:not(.portal-authenticated) #authPanel{
    grid-column:2;
    width:100%;
    margin:0;
    border-radius:28px;
    background:var(--auth-surface);
    border:1px solid var(--auth-brd);
    box-shadow:var(--auth-shadow);
    backdrop-filter:blur(18px) saturate(1.3);
    -webkit-backdrop-filter:blur(18px) saturate(1.3);
    pointer-events:auto;
  }
  body:not(.portal-authenticated) #authPanel .panel-head{
    padding:32px 32px 0;
  }
  body:not(.portal-authenticated) #authPanel .panel-title{
    margin:0;
    color:var(--auth-ink-faint);
    font-size:11px;
    font-weight:800;
    letter-spacing:.14em;
  }
  body:not(.portal-authenticated) #authPanel .panel-title::after{
    content:"Введите данные учётной записи";
    display:block;
    margin-top:6px;
    color:var(--auth-ink);
    font-size:23px;
    line-height:1.18;
    letter-spacing:-.01em;
    text-transform:none;
  }
  body:not(.portal-authenticated) #authPanel .panel-body{
    padding:22px 32px 32px;
  }
  body:not(.portal-authenticated) .login-card{
    gap:0;
  }
  body:not(.portal-authenticated) .auth-field{
    display:block;
    margin-bottom:16px;
  }
  body:not(.portal-authenticated) .auth-field label{
    display:block;
    margin-bottom:8px;
    color:var(--auth-ink-soft);
    font-size:13px;
    font-weight:700;
  }
  body:not(.portal-authenticated) .auth-input{
    display:flex;
    align-items:center;
    gap:10px;
    background:var(--auth-field);
    border:1px solid var(--auth-line);
    border-radius:14px;
    padding:0 14px;
    transition:.2s cubic-bezier(.4,0,.2,1);
  }
  body:not(.portal-authenticated) .auth-input:focus-within{
    border-color:var(--auth-accent);
    box-shadow:0 0 0 4px var(--auth-accent-soft);
  }
  body:not(.portal-authenticated) .auth-input svg{
    width:18px;
    height:18px;
    color:var(--auth-ink-faint);
    flex:0 0 18px;
  }
  body:not(.portal-authenticated) .auth-input input{
    flex:1;
    min-width:0;
    border:0;
    border-radius:0;
    padding:13px 0;
    background:transparent;
    color:var(--auth-ink);
    font-size:15px;
    box-shadow:none;
  }
  body:not(.portal-authenticated) .auth-input input:focus{
    border-color:transparent;
    box-shadow:none;
  }
  body:not(.portal-authenticated) .auth-input input::placeholder{
    color:var(--auth-ink-faint);
  }
  body:not(.portal-authenticated) .auth-submit{
    width:100%;
    margin-top:6px;
    border-radius:14px;
    padding:14px;
    color:#fff;
    background:linear-gradient(135deg,var(--auth-accent),var(--auth-accent-2));
    box-shadow:var(--auth-shadow);
    font-size:15px;
  }
  body:not(.portal-authenticated) .auth-submit:hover{
    box-shadow:var(--auth-shadow-hi);
    filter:brightness(1.05);
  }
  body:not(.portal-authenticated) #loginMessage{
    margin-top:14px;
    color:var(--auth-ink-faint);
  }
  body:not(.portal-authenticated) #loginMessage.error{
    color:var(--danger);
  }
  body:not(.portal-authenticated) .auth-note{
    margin-top:16px;
    display:flex;
    gap:8px;
    color:var(--auth-ink-faint);
    font-size:12px;
    line-height:1.5;
  }
  body:not(.portal-authenticated) .auth-note svg{
    width:15px;
    height:15px;
    flex:0 0 15px;
    margin-top:1px;
    color:var(--auth-accent-ink);
  }
  @media (max-width:720px){
    .shell{width:100%;max-width:100%;padding:16px;overflow-x:hidden}
    .hero,.panel{width:100%;max-width:100%;border-radius:24px}
    #authPanel{width:100%;margin-top:20px}
    .hero{grid-template-columns:minmax(0,1fr);padding:22px}
    .hero h1{font-size:clamp(32px,10vw,42px);line-height:1.06}
    .hero-side{width:100%;max-width:100%}
    .panel-head{padding:22px 20px 0}
    .panel-body{padding:20px}
    input,textarea,select{min-width:0}
    .queue-summary-grid{grid-template-columns:1fr}
    .gateway-row,.gateway-row.local{grid-template-columns:1fr}
  }
  @media (max-width:820px){
    body:not(.portal-authenticated) .shell{
      align-items:start;
      padding:78px 32px 32px;
    }
    body:not(.portal-authenticated) .hero{
      max-width:460px;
      grid-template-columns:1fr;
      gap:28px;
    }
    body:not(.portal-authenticated) .grid{
      position:static;
      width:100%;
      max-width:460px;
      transform:none;
      grid-template-columns:1fr;
      margin-top:28px;
    }
    body:not(.portal-authenticated) #authPanel{
      grid-column:auto;
    }
    body:not(.portal-authenticated) .hero h1{
      font-size:32px;
    }
  }

  /* User dashboard redesign */
  body.portal-user-dashboard{
    --dash-ink:#27334A;
    --dash-muted:#6E788C;
    --dash-line:rgba(150,128,103,.22);
    --dash-surface:rgba(255,255,255,.82);
    --dash-soft:rgba(255,249,240,.72);
    --dash-amber:#F5B65A;
    --dash-coral:#EA7A5C;
    --dash-green:#5CBF9E;
    --dash-blue:#5D93E8;
    color:var(--dash-ink);
    background:
      linear-gradient(135deg,#FFF8EA 0%,#F7F1E6 38%,#EAF4F1 100%);
  }
  html[data-theme="dark"] body.portal-user-dashboard{
    --dash-ink:#F5F0E8;
    --dash-muted:#BDB2A8;
    --dash-line:rgba(245,224,196,.18);
    --dash-surface:rgba(40,34,31,.76);
    --dash-soft:rgba(58,48,41,.66);
    background:
      linear-gradient(135deg,#241F1D 0%,#2D2724 48%,#1E2A2A 100%);
  }
  body.portal-user-dashboard .shell{
    width:100%;
    max-width:none;
    min-height:100vh;
    padding:0;
  }
  body.portal-user-dashboard .shell > .hero,
  body.portal-user-dashboard .grid{
    display:none;
  }
  body.portal-user-dashboard #dashboardPanel:not(.hidden){
    width:100%;
    min-height:100vh;
    margin:0;
    padding:0;
    border:0;
    border-radius:0;
    background:transparent;
    box-shadow:none;
    overflow:visible;
  }
  body.portal-user-dashboard #dashboardPanel:not(.hidden)::before,
  body.portal-user-dashboard #dashboardPanel:not(.hidden)::after{
    display:none;
  }
  body.portal-user-dashboard #dashboardPanel:not(.hidden) .panel-body{
    display:block;
    min-height:100vh;
    padding:0;
  }
  .user-dashboard{
    min-height:100vh;
    padding:18px;
  }
  .user-appbar{
    position:sticky;
    top:14px;
    z-index:10;
    display:grid;
    grid-template-columns:auto minmax(220px,1fr) auto;
    gap:16px;
    align-items:center;
    width:min(1240px,calc(100% - 12px));
    margin:0 auto 22px;
    padding:12px;
    border:1px solid var(--dash-line);
    border-radius:22px;
    background:var(--dash-surface);
    box-shadow:0 18px 44px rgba(68,49,28,.12);
    backdrop-filter:blur(18px);
  }
  .user-brand,
  .user-profile{
    display:flex;
    align-items:center;
    gap:10px;
    min-width:0;
  }
  .user-brand-mark,
  .user-avatar,
  .user-card-icon{
    width:42px;
    height:42px;
    border-radius:14px;
    display:inline-flex;
    align-items:center;
    justify-content:center;
    flex:0 0 auto;
    color:#fff;
    font-weight:850;
    background:linear-gradient(135deg,var(--dash-coral),var(--dash-amber));
    box-shadow:0 12px 24px rgba(234,122,92,.20);
  }
  .user-brand b,
  .user-profile b{
    display:block;
    color:var(--dash-ink);
    font-size:15px;
    line-height:1.1;
  }
  .user-brand small,
  .user-profile small{
    display:block;
    margin-top:2px;
    color:var(--dash-muted);
    font-size:12px;
    line-height:1.2;
  }
  .user-service-bar{
    display:flex;
    justify-content:center;
    gap:8px;
    min-width:0;
    overflow-x:auto;
    padding:2px;
    scrollbar-width:thin;
  }
  .user-svc{
    display:inline-flex;
    align-items:center;
    gap:8px;
    min-height:40px;
    max-width:190px;
    padding:8px 12px;
    border:1px solid rgba(150,128,103,.18);
    border-radius:999px;
    background:rgba(255,255,255,.56);
    color:var(--dash-ink);
    font:inherit;
    font-weight:750;
    cursor:pointer;
    white-space:nowrap;
    box-shadow:0 10px 22px rgba(68,49,28,.06);
  }
  .user-svc[aria-disabled="true"],
  .user-recent-card[aria-disabled="true"]{
    cursor:default;
  }
  html[data-theme="dark"] .user-svc{
    background:rgba(255,255,255,.08);
  }
  .user-svc:hover,
  .user-icon-btn:hover,
  .user-profile:hover,
  .user-cta:hover,
  .user-recent-card:hover{
    transform:translateY(-1px);
  }
  .user-svc-icon{
    width:24px;
    height:24px;
    border-radius:9px;
    display:inline-flex;
    align-items:center;
    justify-content:center;
    flex:0 0 auto;
    background:rgba(245,182,90,.20);
    color:#A85B28;
    font-size:13px;
    font-weight:850;
  }
  .user-svc-icon svg,
  .user-icon-btn svg,
  .user-cta svg,
  .user-card-icon svg,
  .user-recent-icon svg{
    width:18px;
    height:18px;
  }
  .user-svc-label{
    min-width:0;
    overflow:hidden;
    text-overflow:ellipsis;
  }
  .user-actions{
    display:flex;
    align-items:center;
    gap:8px;
  }
  .user-icon-btn,
  .user-profile,
  .user-cta,
  .user-recent-card{
    appearance:none;
    border:1px solid var(--dash-line);
    background:rgba(255,255,255,.64);
    color:var(--dash-ink);
    cursor:pointer;
    transition:transform .16s ease, box-shadow .16s ease, border-color .16s ease;
  }
  .user-icon-btn:disabled,
  .user-cta:disabled{
    cursor:not-allowed;
    opacity:.52;
    transform:none;
  }
  html[data-theme="dark"] .user-icon-btn,
  html[data-theme="dark"] .user-profile,
  html[data-theme="dark"] .user-cta,
  html[data-theme="dark"] .user-recent-card{
    background:rgba(255,255,255,.08);
  }
  .user-icon-btn{
    width:42px;
    height:42px;
    border-radius:14px;
    display:inline-flex;
    align-items:center;
    justify-content:center;
    flex:0 0 auto;
  }
  .user-icon-btn.danger{
    color:#C75364;
  }
  .user-profile{
    min-width:170px;
    max-width:220px;
    min-height:42px;
    padding:6px 10px 6px 6px;
    border-radius:16px;
    text-align:left;
  }
  .user-profile-text{
    min-width:0;
  }
  .user-profile-text b,
  .user-profile-text small{
    overflow:hidden;
    text-overflow:ellipsis;
    white-space:nowrap;
  }
  .user-avatar{
    width:30px;
    height:30px;
    border-radius:11px;
    font-size:13px;
  }
  .user-page{
    width:min(1180px,calc(100% - 24px));
    margin:0 auto;
    display:grid;
    gap:18px;
    padding-bottom:34px;
  }
  .user-hero,
  .user-reco,
  .user-weather,
  .user-recent{
    border:1px solid var(--dash-line);
    border-radius:24px;
    background:var(--dash-surface);
    box-shadow:0 18px 42px rgba(68,49,28,.10);
    backdrop-filter:blur(16px);
  }
  .user-hero{
    display:flex;
    align-items:flex-end;
    justify-content:space-between;
    gap:20px;
    padding:26px;
    background:
      linear-gradient(135deg,rgba(255,255,255,.84),rgba(255,246,230,.68) 58%,rgba(230,247,242,.70));
  }
  html[data-theme="dark"] .user-hero{
    background:
      linear-gradient(135deg,rgba(50,43,39,.82),rgba(63,48,40,.72) 58%,rgba(32,50,48,.74));
  }
  .user-kicker,
  .user-card-head,
  .user-section-title span{
    color:var(--dash-muted);
    font-size:12px;
    font-weight:850;
    letter-spacing:0;
    text-transform:uppercase;
  }
  .user-hero h2{
    margin:10px 0 10px;
    color:var(--dash-ink);
    font-size:42px;
    line-height:1.05;
    letter-spacing:0;
  }
  .user-hero p{
    max-width:720px;
    margin:0;
    color:var(--dash-muted);
    font-size:15px;
    line-height:1.55;
  }
  .user-cta{
    display:inline-flex;
    align-items:center;
    justify-content:center;
    gap:9px;
    min-height:46px;
    padding:12px 16px;
    border-radius:16px;
    color:#fff;
    font:inherit;
    font-weight:850;
    white-space:nowrap;
    border-color:transparent;
    background:linear-gradient(135deg,var(--dash-blue),var(--dash-green));
    box-shadow:0 16px 34px rgba(63,126,150,.18);
  }
  .user-widget-grid{
    display:grid;
    grid-template-columns:minmax(0,1.2fr) minmax(320px,.8fr);
    gap:18px;
  }
  .user-reco,
  .user-weather,
  .user-recent{
    padding:20px;
  }
  .user-card-head{
    display:flex;
    align-items:center;
    gap:10px;
    margin-bottom:16px;
  }
  .user-card-icon{
    width:34px;
    height:34px;
    border-radius:12px;
    font-size:13px;
  }
  .user-card-icon.weather{
    background:linear-gradient(135deg,var(--dash-blue),var(--dash-green));
  }
  .user-reco h3{
    margin:0 0 10px;
    font-size:24px;
    line-height:1.15;
    color:var(--dash-ink);
  }
  .user-reco p{
    margin:0;
    color:var(--dash-muted);
    font-size:15px;
    line-height:1.58;
  }
  .user-reco small{
    display:block;
    margin-top:18px;
    color:var(--dash-muted);
    font-size:12px;
  }
  .weather-now{
    display:flex;
    align-items:flex-end;
    gap:16px;
    margin-bottom:18px;
  }
  .weather-now strong{
    font-size:46px;
    line-height:.9;
    color:var(--dash-ink);
  }
  .weather-now b,
  .weather-now small{
    display:block;
    color:var(--dash-muted);
    line-height:1.35;
  }
  .weather-now b{
    color:var(--dash-ink);
    font-size:14px;
  }
  .weather-days{
    display:grid;
    grid-template-columns:repeat(4,minmax(0,1fr));
    gap:8px;
  }
  .weather-day{
    min-height:72px;
    padding:10px;
    border:1px solid var(--dash-line);
    border-radius:16px;
    background:var(--dash-soft);
  }
  .weather-day span,
  .weather-day small{
    display:block;
    color:var(--dash-muted);
    font-size:12px;
    line-height:1.35;
  }
  .weather-day b{
    display:block;
    margin-top:8px;
    color:var(--dash-ink);
    font-size:17px;
  }
  .user-recent{
    display:grid;
    gap:16px;
  }
  .user-section-title h3{
    margin:6px 0 0;
    color:var(--dash-ink);
    font-size:24px;
    line-height:1.15;
  }
  .user-recent-grid{
    display:grid;
    grid-template-columns:repeat(3,minmax(0,1fr));
    gap:12px;
  }
  .user-recent-card{
    display:flex;
    align-items:center;
    gap:12px;
    min-height:96px;
    padding:14px;
    border-radius:18px;
    text-align:left;
    font:inherit;
  }
  .user-recent-icon{
    width:42px;
    height:42px;
    border-radius:14px;
    display:inline-flex;
    align-items:center;
    justify-content:center;
    flex:0 0 auto;
    color:#fff;
    background:linear-gradient(135deg,var(--dash-coral),var(--dash-blue));
  }
  .user-recent-card b{
    display:block;
    color:var(--dash-ink);
    font-size:15px;
    line-height:1.25;
  }
  .user-recent-card small{
    display:block;
    margin-top:4px;
    color:var(--dash-muted);
    font-size:12px;
    line-height:1.35;
  }
  body.portal-user-dashboard #dashboardToolbar,
  body.portal-user-dashboard #dashboardMessage,
  body.portal-user-dashboard #servicesSection,
  body.portal-user-dashboard #adminSection{
    display:none!important;
  }
  @media (max-width:1020px){
    .user-appbar{
      grid-template-columns:1fr auto;
    }
    .user-service-bar{
      grid-column:1 / -1;
      grid-row:2;
      justify-content:flex-start;
    }
    .user-widget-grid{
      grid-template-columns:1fr;
    }
    .user-recent-grid{
      grid-template-columns:1fr;
    }
  }
  @media (max-width:720px){
    .user-dashboard{
      padding:10px;
    }
    .user-appbar{
      top:8px;
      width:100%;
      gap:10px;
      border-radius:18px;
    }
    .user-brand small,
    .user-profile-text{
      display:none;
    }
    .user-brand > span:not(.user-brand-mark){
      display:none;
    }
    .user-profile{
      min-width:auto;
      padding:6px;
    }
    .user-page{
      width:100%;
    }
    .user-actions{
      gap:6px;
    }
    .user-icon-btn{
      width:38px;
      height:38px;
      border-radius:13px;
    }
    .user-hero{
      align-items:flex-start;
      flex-direction:column;
      padding:22px;
    }
    .user-hero h2{
      font-size:32px;
    }
    .user-cta{
      width:100%;
    }
    .weather-days{
      grid-template-columns:repeat(2,minmax(0,1fr));
    }
  }

  /* dashboard.html prototype transfer: keep this block later than the old user-dashboard slice */
  body.portal-user-dashboard{
    --font:"Inter","Segoe UI",system-ui,sans-serif;
    --r:14px;
    --r-lg:22px;
    --r-xl:28px;
    --sp-3:12px;
    --sp-4:18px;
    --sp-5:26px;
    --sp-6:38px;
    --t:.2s cubic-bezier(.4,0,.2,1);
    --accent-fill:color-mix(in srgb,var(--accent) 90%,transparent);
    --accent-fill-2:color-mix(in srgb,var(--accent-2) 90%,transparent);
    font-family:var(--font);
    color:var(--ink);
    background:var(--bg);
    min-height:100vh;
    position:relative;
    overflow-x:hidden;
    transition:background var(--t),color var(--t);
  }
  html[data-theme="light"] body.portal-user-dashboard{
    --accent:#ec7a1c;
    --accent-2:#ffb24d;
    --accent-soft:#fdeedd;
    --accent-ink:#c4641a;
    --lime:#86b93b;
    --bg:#f1ece3;
    --surface:rgba(255,255,255,.72);
    --surface-2:rgba(255,255,255,.55);
    --ink:#2a2620;
    --ink-soft:#6c6457;
    --ink-faint:#9c9484;
    --line:rgba(120,100,70,.12);
    --brd:rgba(255,255,255,.7);
    --shadow:0 10px 30px rgba(120,95,50,.08);
    --shadow-hi:0 22px 56px rgba(120,95,50,.14);
    --blob-a:#ffcf8e;
    --blob-b:#d6e7a6;
    --blob-a-op:.5;
    --blob-b-op:.45;
    --tab-on-bg:#fff;
    --tab-on-ink:var(--accent-ink);
  }
  html[data-theme="dark"] body.portal-user-dashboard{
    --accent:#ff7a1a;
    --accent-2:#ffae5c;
    --accent-soft:rgba(255,140,40,.15);
    --accent-ink:#ffae5c;
    --lime:#a7d34e;
    --bg:#16130f;
    --surface:rgba(40,34,28,.55);
    --surface-2:rgba(54,46,38,.5);
    --ink:#f4efe6;
    --ink-soft:#b3a899;
    --ink-faint:#80766a;
    --line:rgba(255,255,255,.07);
    --brd:rgba(255,255,255,.08);
    --shadow:0 16px 40px rgba(0,0,0,.45);
    --shadow-hi:0 26px 60px rgba(0,0,0,.55);
    --blob-a:#ff8a2e;
    --blob-b:#7a4a1f;
    --blob-a-op:.22;
    --blob-b-op:.3;
    --tab-on-bg:rgba(255,170,90,.16);
    --tab-on-ink:var(--accent-2);
  }
  body.portal-user-dashboard .user-dashboard.portal-dash{
    min-height:100vh;
    padding:0;
    position:relative;
    z-index:1;
    color:var(--ink);
    background:transparent;
  }
  .portal-dash .dash-blob{
    position:fixed;
    border-radius:50%;
    filter:blur(95px);
    z-index:0;
    pointer-events:none;
  }
  .portal-dash .dash-blob.a{
    width:520px;
    height:520px;
    background:var(--blob-a);
    opacity:var(--blob-a-op);
    top:-150px;
    right:-60px;
  }
  .portal-dash .dash-blob.b{
    width:420px;
    height:420px;
    background:var(--blob-b);
    opacity:var(--blob-b-op);
    bottom:-160px;
    left:-100px;
  }
  .portal-dash .dash-wrap{
    position:relative;
    z-index:1;
  }
  .portal-dash .glass{
    background:var(--surface);
    border:1px solid var(--brd);
    box-shadow:var(--shadow);
    backdrop-filter:blur(16px) saturate(1.3);
    -webkit-backdrop-filter:blur(16px) saturate(1.3);
  }
  .portal-dash .appbar{
    display:grid;
    grid-template-columns:auto minmax(320px, 1fr) auto;
    align-items:center;
    gap:14px;
    padding:8px 4px;
    position:sticky;
    top:0;
    z-index:5;
    border:0;
    border-bottom:1px solid var(--line);
    border-radius:0;
    box-shadow:var(--shadow);
  }
  .portal-dash .appbar>.brand{
    padding-left:12px;
  }
  .portal-dash .appbar>.actions{
    padding-right:8px;
    margin-left:auto;
  }
  .portal-dash .brand{
    display:flex;
    align-items:center;
    gap:10px;
    font-weight:800;
    font-size:18px;
    color:var(--ink);
  }
  .portal-dash .brand .logo{
    width:32px;
    height:32px;
    border-radius:10px;
    background:linear-gradient(135deg,var(--accent),var(--accent-2));
    display:grid;
    place-items:center;
    color:#fff;
    font-weight:900;
  }
  .portal-dash .actions{
    display:flex;
    align-items:center;
    gap:8px;
    position:relative;
    justify-self:end;
    min-width:0;
  }
  .portal-dash .iconbtn{
    position:relative;
    width:40px;
    height:40px;
    border-radius:999px;
    border:1px solid var(--line);
    background:var(--surface-2);
    color:var(--ink-soft);
    display:grid;
    place-items:center;
    cursor:pointer;
    transition:var(--t);
    padding:0;
    box-shadow:none;
  }
  .portal-dash .iconbtn:hover{
    color:var(--ink);
    transform:none;
  }
  .portal-dash .iconbtn svg{
    width:18px;
    height:18px;
  }
  .portal-dash .iconbtn.has-unread::after{
    content:attr(data-count);
    position:absolute;
    top:-4px;
    right:-4px;
    min-width:18px;
    height:18px;
    padding:0 5px;
    border-radius:999px;
    background:var(--danger);
    color:#fff;
    display:grid;
    place-items:center;
    font-size:10px;
    font-weight:900;
    line-height:1;
    box-shadow:0 0 0 3px var(--surface);
  }
  .portal-dash .notifications-popover{
    position:absolute;
    right:0;
    top:calc(100% + 10px);
    width:min(360px, calc(100vw - 32px));
    max-height:min(480px, calc(100vh - 120px));
    overflow:auto;
    padding:12px;
    border:1px solid var(--line);
    border-radius:22px;
    background:var(--surface);
    box-shadow:var(--shadow-lg);
    z-index:50;
  }
  .portal-dash .notifications-popover.hidden{
    display:none;
  }
  .portal-dash .notifications-head{
    display:flex;
    align-items:center;
    justify-content:space-between;
    gap:10px;
    margin-bottom:10px;
  }
  .portal-dash .notifications-head strong{
    font-size:15px;
    color:var(--ink);
  }
  .portal-dash .notifications-head button{
    appearance:none;
    border:1px solid var(--line);
    border-radius:999px;
    background:var(--surface-2);
    color:var(--accent-ink);
    font:inherit;
    font-size:12px;
    font-weight:800;
    padding:7px 10px;
    cursor:pointer;
    box-shadow:none;
  }
  .portal-dash .notification-list{
    display:grid;
    gap:8px;
  }
  .portal-dash .notification-item{
    display:block;
    width:100%;
    text-align:left;
    border:1px solid var(--line);
    border-radius:16px;
    background:var(--surface-2);
    color:var(--ink);
    padding:10px 12px;
    cursor:pointer;
    box-shadow:none;
  }
  .portal-dash .notification-item.unread{
    border-color:color-mix(in srgb,var(--accent) 32%,var(--line));
    background:color-mix(in srgb,var(--accent-soft) 45%,var(--surface));
  }
  .portal-dash .notification-item b{
    display:block;
    font-size:13px;
    line-height:1.25;
    margin-bottom:4px;
  }
  .portal-dash .notification-item span{
    display:block;
    color:var(--ink-soft);
    font-size:12px;
    line-height:1.35;
  }
  .portal-dash .notification-empty{
    border:1px dashed var(--line);
    border-radius:16px;
    padding:18px;
    color:var(--ink-soft);
    text-align:center;
    font-weight:700;
  }
  .portal-dash .me{
    appearance:none;
    border:0;
    background:transparent;
    display:flex;
    align-items:center;
    gap:10px;
    padding:0 0 0 6px;
    color:var(--ink);
    font:inherit;
    cursor:pointer;
    box-shadow:none;
  }
  .portal-dash .me .txt{
    text-align:right;
  }
  .portal-dash .me .txt b{
    font-size:13px;
    display:block;
    color:var(--ink);
    max-width:150px;
    overflow:hidden;
    text-overflow:ellipsis;
    white-space:nowrap;
  }
  .portal-dash .me .txt span{
    font-size:11px;
    color:var(--ink-faint);
  }
  .portal-dash .avatar{
    width:40px;
    height:40px;
    border-radius:999px;
    background:linear-gradient(135deg,var(--accent),var(--accent-2));
    color:#fff;
    display:grid;
    place-items:center;
    font-weight:800;
    flex:0 0 auto;
  }
  .portal-dash .seg{
    display:flex;
    gap:4px;
    position:static;
    justify-self:center;
    width:min(1120px,100%);
    min-width:0;
    max-width:100%;
    background:var(--surface-2);
    border:1px solid var(--line);
    border-radius:999px;
    padding:5px;
    overflow-x:auto;
    scrollbar-width:none;
    box-shadow:inset 0 1px 3px rgba(120,100,70,.08);
  }
  .portal-dash .seg::-webkit-scrollbar{
    display:none;
  }
  .portal-dash .svc{
    appearance:none;
    border:0;
    background:transparent;
    display:flex;
    align-items:center;
    gap:8px;
    border-radius:999px;
    padding:9px 15px;
    font:inherit;
    font-size:13px;
    font-weight:700;
    color:var(--ink-soft);
    cursor:pointer;
    white-space:nowrap;
    transition:var(--t);
    box-shadow:none;
  }
  .portal-dash .svc:hover{
    color:var(--ink);
  }
  .portal-dash .svc.on{
    color:var(--tab-on-ink);
    background:var(--tab-on-bg);
    box-shadow:var(--shadow);
  }
  .portal-dash .svc .si{
    width:24px;
    height:24px;
    border-radius:7px;
    background:var(--accent-soft);
    color:var(--accent-ink);
    display:grid;
    place-items:center;
    flex:0 0 auto;
  }
  .portal-dash .svc .si svg{
    width:14px;
    height:14px;
  }
  .portal-dash .svc .cnt{
    font-size:11px;
    font-weight:800;
    color:var(--accent-ink);
    background:var(--accent-soft);
    border-radius:999px;
    padding:2px 7px;
  }
  .portal-dash .svc .lbl{
    white-space:nowrap;
  }
  .portal-dash .seg.compact-1 .svc .cnt{
    display:none;
  }
  .portal-dash .seg.compact-2 .svc:not(.on) .lbl{
    display:none;
  }
  .portal-dash .seg.compact-2 .svc{
    padding:9px 12px;
  }
  .portal-dash .seg.compact-3 .svc:not(.on) .lbl{
    display:none;
  }
  .portal-dash .seg.compact-3 .svc{
    padding:9px 11px;
  }
  .portal-dash .page{
    max-width:1140px;
    margin:0 auto;
    padding:var(--sp-4) var(--sp-6) var(--sp-5);
    display:grid;
    gap:var(--sp-4);
  }
  .portal-dash .hero{
    background:transparent;
    color:var(--ink);
    border:0;
    border-radius:0;
    box-shadow:none;
    display:flex;
    align-items:flex-end;
    justify-content:space-between;
    gap:18px;
    padding:0;
  }
  .portal-dash .hero h1{
    margin:0 0 5px;
    color:var(--ink);
    font-size:26px;
    letter-spacing:-.01em;
  }
  .portal-dash .hero p{
    margin:0;
    max-width:none;
    color:var(--ink-soft);
    font-size:14px;
  }
  .portal-dash .cta{
    border:0;
    border-radius:999px;
    padding:12px 22px;
    font:inherit;
    font-weight:800;
    font-size:14px;
    cursor:pointer;
    color:#fff;
    background:linear-gradient(135deg,var(--accent-fill),var(--accent-fill-2));
    box-shadow:var(--shadow);
    white-space:nowrap;
  }
  .portal-dash .row{
    display:grid;
    grid-template-columns:1.65fr 1fr;
    gap:var(--sp-4);
  }
  .portal-dash .reco{
    border-radius:var(--r-lg);
    padding:20px;
    display:flex;
    gap:16px;
    align-items:flex-start;
  }
  .portal-dash .reco .fox{
    width:52px;
    height:52px;
    border-radius:16px;
    flex:0 0 52px;
    background:var(--accent-soft);
    display:grid;
    place-items:center;
    font-size:28px;
  }
  .portal-dash .reco .lbl{
    font-size:11px;
    font-weight:800;
    letter-spacing:.12em;
    text-transform:uppercase;
    color:var(--accent-ink);
  }
  .portal-dash .reco h3{
    margin:6px 0 7px;
    font-size:18px;
    color:var(--ink);
    letter-spacing:-.01em;
  }
  .portal-dash .reco p{
    margin:0;
    color:var(--ink-soft);
    font-size:13.5px;
    line-height:1.55;
  }
  .portal-dash .reco .stamp{
    margin-top:10px;
    font-size:11px;
    color:var(--ink-faint);
  }
  .portal-dash .weather{
    border-radius:var(--r-lg);
    padding:20px;
  }
  .portal-dash .wx-top{
    display:flex;
    align-items:center;
    justify-content:space-between;
  }
  .portal-dash .wx-city{
    font-weight:800;
    font-size:15px;
    color:var(--ink);
  }
  .portal-dash .wx-city span{
    display:block;
    font-size:12px;
    color:var(--ink-faint);
    font-weight:600;
  }
  .portal-dash .wx-now{
    display:flex;
    align-items:center;
    gap:14px;
    margin:8px 0 4px;
  }
  .portal-dash .wx-now .t{
    font-size:38px;
    font-weight:800;
    letter-spacing:-.03em;
    color:var(--ink);
  }
  .portal-dash .wx-now svg{
    width:46px;
    height:46px;
    color:var(--accent);
  }
  .portal-dash .wx-desc{
    font-size:13px;
    color:var(--ink-soft);
    margin-bottom:16px;
  }
  .portal-dash .wx-days{
    display:flex;
    justify-content:space-between;
    gap:6px;
  }
  .portal-dash .wx-day{
    flex:1;
    text-align:center;
    background:var(--surface-2);
    border-radius:14px;
    padding:10px 4px;
  }
  .portal-dash .wx-day .d{
    font-size:11px;
    color:var(--ink-faint);
    font-weight:700;
  }
  .portal-dash .wx-day svg{
    width:20px;
    height:20px;
    color:var(--accent);
    margin:6px 0 4px;
  }
  .portal-dash .wx-day .dt{
    font-size:13px;
    font-weight:800;
    color:var(--ink);
  }
  .portal-dash .section-h{
    display:flex;
    align-items:baseline;
    justify-content:space-between;
    margin-bottom:var(--sp-3);
  }
  .portal-dash .section-h h2{
    margin:0;
    font-size:16px;
    color:var(--ink);
  }
  .portal-dash .section-h a{
    font-size:13px;
    font-weight:700;
    color:var(--accent-ink);
    text-decoration:none;
    cursor:pointer;
  }
  .portal-dash .recent{
    display:grid;
    grid-template-columns:repeat(3,1fr);
    gap:var(--sp-4);
  }
  .portal-dash .rcard{
    border-radius:var(--r-lg);
    overflow:hidden;
    cursor:pointer;
    transition:var(--t);
  }
  .portal-dash .rcard:hover{
    transform:translateY(-3px);
    box-shadow:var(--shadow-hi);
  }
  .portal-dash .rcard:focus-visible{
    outline:2px solid var(--accent);
    outline-offset:3px;
  }
  .portal-dash .rcard .thumb{
    aspect-ratio:16/9;
    position:relative;
    overflow:hidden;
    background:var(--surface-2);
  }
  .portal-dash .rcard .thumb svg{
    display:block;
    width:100%;
    height:100%;
  }
  .portal-dash .rcard .thumb .slide-svg-scene{
    background:#fff;
  }
  .portal-dash .rcard .thumb .deck-thumb-fallback{
    width:100%;
    height:100%;
    padding:18px;
    background:#f7f2ea;
    color:#2a2620;
    display:flex;
    flex-direction:column;
    justify-content:center;
    gap:7px;
  }
  .portal-dash .rcard .thumb .deck-thumb-fallback b{
    font-size:15px;
    line-height:1.18;
  }
  .portal-dash .rcard .thumb .deck-thumb-fallback span{
    font-size:11px;
    line-height:1.35;
    color:#6f6658;
  }
  .portal-dash .rcard .meta{
    padding:13px var(--sp-4);
    background:var(--surface);
  }
  .portal-dash .rcard .meta b{
    display:block;
    font-size:14px;
    color:var(--ink);
    overflow:hidden;
    text-overflow:ellipsis;
    white-space:nowrap;
  }
  .portal-dash .rcard .meta span{
    display:block;
    font-size:12px;
    color:var(--ink-faint);
    margin-top:3px;
  }
  @media(max-width:820px){
    .portal-dash .appbar{
      min-height:auto;
      grid-template-columns:auto auto;
      padding:10px;
      gap:10px;
    }
    .portal-dash .brand{
      min-width:auto;
      flex:1;
    }
    .portal-dash .brand>span:not(.logo){
      display:none;
    }
    .portal-dash .seg{
      grid-column:1 / -1;
      max-width:100%;
      width:100%;
      margin-inline:0;
    }
    .portal-dash .actions{
      margin-left:auto;
      gap:6px;
    }
    .portal-dash .iconbtn{
      width:40px;
      height:40px;
    }
    .portal-dash .avatar{
      width:40px;
      height:40px;
    }
    .portal-dash .page{
      padding:var(--sp-4) var(--sp-6) var(--sp-5);
    }
    .portal-dash .hero{
      align-items:flex-start;
      flex-direction:column;
    }
    .portal-dash .hero h1{
      font-size:26px;
    }
    .portal-dash .hero p{
      font-size:14px;
    }
    .portal-dash .cta{
      width:100%;
      min-width:0;
      font-size:14px;
    }
    .portal-dash .row{
      grid-template-columns:1fr;
    }
    .portal-dash .reco,
    .portal-dash .weather{
      min-height:auto;
      padding:20px;
    }
    .portal-dash .reco p{
      font-size:13.5px;
    }
    .portal-dash .reco h3{
      font-size:18px;
    }
    .portal-dash .weather .wx-days{
      display:grid;
      grid-template-columns:repeat(2,minmax(0,1fr));
    }
    .portal-dash .recent{
      grid-template-columns:1fr;
    }
  }

  /* Admin shell redesign: Aiklava-Portal-Redesign/screens/home-admin + admin-services + admin-panel */
  body.portal-admin-dashboard{
    --adm-accent:#ec7a1c;
    --adm-accent-2:#ffb24d;
    --adm-accent-soft:#fdeedd;
    --adm-accent-ink:#c4641a;
    --adm-ok:#5e8519;
    --adm-ok-soft:#eef5dd;
    --adm-warn:#b4692c;
    --adm-warn-soft:#fff0db;
    --adm-danger:#c0436b;
    --adm-danger-soft:#fbe7ef;
    --adm-bg:#f1ece3;
    --adm-surface:rgba(255,255,255,.72);
    --adm-surface-2:rgba(255,255,255,.55);
    --adm-field:rgba(255,255,255,.7);
    --adm-ink:#2a2620;
    --adm-ink-soft:#6c6457;
    --adm-ink-faint:#9c9484;
    --adm-line:rgba(120,100,70,.13);
    --adm-brd:rgba(255,255,255,.7);
    --adm-shadow:0 10px 30px rgba(120,95,50,.08);
    --adm-shadow-hi:0 22px 56px rgba(120,95,50,.14);
    --adm-blob-a:#ffcf8e;
    --adm-blob-b:#d6e7a6;
    --adm-blob-a-op:.5;
    --adm-blob-b-op:.45;
    --adm-backdrop:rgba(40,28,14,.34);
    color:var(--adm-ink);
    background:var(--adm-bg);
    min-height:100vh;
  }
  html[data-theme="dark"] body.portal-admin-dashboard{
    --adm-accent:#ff7a1a;
    --adm-accent-2:#ffae5c;
    --adm-accent-soft:rgba(255,140,40,.16);
    --adm-accent-ink:#ffae5c;
    --adm-ok:#a7d34e;
    --adm-ok-soft:rgba(167,211,78,.16);
    --adm-warn:#ffca72;
    --adm-warn-soft:rgba(255,202,114,.16);
    --adm-danger:#ff6f91;
    --adm-danger-soft:rgba(255,111,145,.16);
    --adm-bg:#16130f;
    --adm-surface:rgba(40,34,28,.55);
    --adm-surface-2:rgba(54,46,38,.5);
    --adm-field:rgba(255,255,255,.05);
    --adm-ink:#f4efe6;
    --adm-ink-soft:#b3a899;
    --adm-ink-faint:#80766a;
    --adm-line:rgba(255,255,255,.09);
    --adm-brd:rgba(255,255,255,.09);
    --adm-shadow:0 16px 40px rgba(0,0,0,.45);
    --adm-shadow-hi:0 26px 56px rgba(0,0,0,.55);
    --adm-blob-a:#ff8a2e;
    --adm-blob-b:#7a4a1f;
    --adm-blob-a-op:.22;
    --adm-blob-b-op:.30;
    --adm-backdrop:rgba(0,0,0,.55);
  }
  body.portal-admin-dashboard .shell{
    width:100%;
    max-width:none;
    min-height:100vh;
    padding:0;
  }
  body.portal-admin-dashboard .shell > .hero,
  body.portal-admin-dashboard .grid{
    display:none;
  }
  body.portal-admin-dashboard #dashboardPanel:not(.hidden){
    width:100%;
    min-height:100vh;
    margin:0;
    padding:0;
    border:0;
    border-radius:0;
    background:transparent;
    box-shadow:none;
    overflow:visible;
  }
  body.portal-admin-dashboard #dashboardPanel:not(.hidden)::before,
  body.portal-admin-dashboard #dashboardPanel:not(.hidden)::after{
    display:none;
  }
  body.portal-admin-dashboard #dashboardPanel:not(.hidden) .panel-body{
    min-height:100vh;
    display:block;
    padding:0;
  }
  body.portal-admin-dashboard #dashboardToolbar,
  body.portal-admin-dashboard #dashboardMessage,
  body.portal-admin-dashboard #servicesSection{
    display:none!important;
  }
  .admin-dashboard{
    position:relative;
    display:block;
    min-height:100vh;
    overflow:hidden;
    padding:18px;
    background:transparent;
    border:0;
    box-shadow:none;
  }
  .admin-dashboard.hidden{
    display:none!important;
  }
  .admin-dashboard .glass{
    background:var(--adm-surface);
    border:1px solid var(--adm-brd);
    box-shadow:var(--adm-shadow);
    backdrop-filter:blur(20px) saturate(1.25);
    -webkit-backdrop-filter:blur(20px) saturate(1.25);
  }
  .admin-blob{
    position:fixed;
    border-radius:50%;
    filter:blur(100px);
    z-index:0;
    pointer-events:none;
  }
  .admin-blob.a{
    width:520px;
    height:520px;
    right:-110px;
    top:-170px;
    background:var(--adm-blob-a);
    opacity:var(--adm-blob-a-op);
  }
  .admin-blob.b{
    width:420px;
    height:420px;
    left:-120px;
    bottom:-150px;
    background:var(--adm-blob-b);
    opacity:var(--adm-blob-b-op);
  }
  .admin-wrap{
    position:relative;
    z-index:1;
    width:min(1280px,100%);
    margin:0 auto;
  }
  .admin-appbar{
    position:sticky;
    top:14px;
    z-index:10;
    display:flex;
    align-items:center;
    gap:16px;
    min-height:68px;
    padding:10px 12px;
    border-radius:24px;
  }
  .admin-brand{
    display:flex;
    align-items:center;
    gap:10px;
    min-width:150px;
    color:var(--adm-ink);
    font-weight:900;
    letter-spacing:-.01em;
  }
  .admin-logo,
  .admin-avatar{
    width:42px;
    height:42px;
    border-radius:14px;
    display:grid;
    place-items:center;
    flex:0 0 auto;
    background:linear-gradient(135deg,var(--adm-accent),var(--adm-accent-2));
    color:#fff;
    font-weight:900;
    box-shadow:0 12px 24px rgba(120,75,24,.18);
  }
  .admin-seg{
    flex:1;
    min-width:0;
    display:flex;
    justify-content:center;
    gap:8px;
    overflow-x:auto;
    padding:2px;
    scrollbar-width:thin;
  }
  .admin-tab{
    border:1px solid transparent;
    border-radius:999px;
    min-height:42px;
    padding:8px 14px;
    display:inline-flex;
    align-items:center;
    gap:8px;
    white-space:nowrap;
    background:transparent;
    color:var(--adm-ink-soft);
    font:inherit;
    font-size:14px;
    font-weight:800;
    cursor:pointer;
  }
  .admin-tab.on{
    background:var(--adm-accent-soft);
    color:var(--adm-accent-ink);
    border-color:rgba(236,122,28,.22);
  }
  .admin-tab-ic,
  .admin-kpi-icon,
  .admin-service-icon,
  .admin-control-icon{
    display:grid;
    place-items:center;
    flex:0 0 auto;
  }
  .admin-tab-ic svg,
  .admin-kpi-icon svg,
  .admin-service-icon svg,
  .admin-control-icon svg,
  .admin-iconbtn svg{
    width:18px;
    height:18px;
  }
  .admin-actions-top{
    display:flex;
    align-items:center;
    gap:8px;
    margin-left:auto;
  }
  .admin-iconbtn,
  .admin-me{
    min-height:42px;
    border:1px solid var(--adm-line);
    background:var(--adm-surface-2);
    color:var(--adm-ink-soft);
    border-radius:999px;
    cursor:pointer;
    font:inherit;
  }
  .admin-iconbtn{
    width:42px;
    display:grid;
    place-items:center;
  }
  .admin-me{
    display:flex;
    align-items:center;
    gap:10px;
    padding:4px 4px 4px 12px;
  }
  .admin-me-text{
    display:block;
    text-align:right;
  }
  .admin-me-text b,
  .admin-me-text span{
    display:block;
    max-width:150px;
    overflow:hidden;
    text-overflow:ellipsis;
    white-space:nowrap;
  }
  .admin-me-text b{
    color:var(--adm-ink);
    font-size:13px;
  }
  .admin-me-text span{
    margin-top:1px;
    color:var(--adm-ink-faint);
    font-size:11px;
  }
  .admin-page{
    padding:26px 4px 8px;
  }
  .admin-pane{
    display:grid;
    gap:22px;
  }
  .admin-hero{
    display:flex;
    justify-content:space-between;
    align-items:center;
    gap:18px;
    border-radius:28px;
    padding:18px 2px 4px;
  }
  .admin-hero h1,
  .admin-page-head h1{
    margin:0;
    color:var(--adm-ink);
    font-size:34px;
    line-height:1.08;
    letter-spacing:-.02em;
  }
  .admin-hero p,
  .admin-page-head p{
    margin:8px 0 0;
    color:var(--adm-ink-soft);
    line-height:1.55;
  }
  .admin-hero-actions{
    display:flex;
    gap:10px;
    flex-wrap:wrap;
    justify-content:flex-end;
  }
  .admin-dot{
    display:inline-block;
    width:9px;
    height:9px;
    border-radius:50%;
    background:var(--adm-ok);
    margin-right:7px;
    box-shadow:0 0 0 4px var(--adm-ok-soft);
  }
  .admin-kpis{
    display:grid;
    grid-template-columns:repeat(4,minmax(0,1fr));
    gap:16px;
  }
  .admin-kpi{
    min-height:160px;
    border-radius:24px;
    padding:20px;
    display:flex;
    flex-direction:column;
    align-items:flex-start;
    gap:8px;
    color:var(--adm-ink);
    font:inherit;
    text-align:left;
    cursor:pointer;
  }
  .admin-kpi-icon{
    width:42px;
    height:42px;
    border-radius:14px;
    background:var(--adm-accent-soft);
    color:var(--adm-accent-ink);
  }
  .admin-kpi strong{
    margin-top:auto;
    color:var(--adm-ink);
    font-size:34px;
    line-height:1;
    letter-spacing:-.03em;
  }
  .admin-kpi span{
    color:var(--adm-ink-soft);
    font-weight:800;
  }
  .admin-kpi small{
    color:var(--adm-ok);
    font-size:12px;
    font-weight:800;
  }
  .admin-two{
    display:grid;
    grid-template-columns:1.05fr .95fr;
    gap:18px;
  }
  .admin-card-panel{
    border-radius:28px;
    padding:22px;
    min-height:310px;
  }
  .admin-panel-head,
  .admin-page-head{
    display:flex;
    justify-content:space-between;
    gap:14px;
    align-items:flex-start;
  }
  .admin-panel-head h2{
    margin:0;
    color:var(--adm-ink);
    font-size:18px;
    letter-spacing:-.01em;
  }
  .admin-status-list,
  .admin-events{
    display:grid;
    gap:10px;
    margin-top:16px;
  }
  .admin-health-group{
    margin-top:2px;
    color:var(--adm-ink-faint);
    font-size:11px;
    font-weight:900;
    letter-spacing:.12em;
    text-transform:uppercase;
  }
  .admin-status-row,
  .admin-event{
    display:flex;
    align-items:center;
    gap:10px;
    min-height:44px;
    padding:10px 12px;
    border:1px solid var(--adm-line);
    border-radius:16px;
    background:var(--adm-surface-2);
  }
  .admin-status,
  .admin-event small{
    display:inline-flex;
    align-items:center;
    gap:7px;
    color:var(--adm-ink-soft);
    font-size:12px;
    font-weight:800;
  }
  .admin-status span,
  .admin-status-row::before,
  .admin-event::before{
    content:"";
    width:8px;
    height:8px;
    border-radius:50%;
    background:currentColor;
    flex:0 0 auto;
  }
  .admin-status.ok,
  .admin-status-row.ok,
  .admin-event.ok{
    color:var(--adm-ok);
  }
  .admin-status.warn,
  .admin-status-row.warn,
  .admin-event.warn{
    color:var(--adm-warn);
  }
  .admin-status.danger,
  .admin-status-row.danger,
  .admin-event.danger{
    color:var(--adm-danger);
  }
  .admin-status.muted{
    color:var(--adm-ink-faint);
  }
  .admin-status-row strong,
  .admin-event strong{
    display:block;
    color:var(--adm-ink);
    font-size:14px;
  }
  .admin-status-row small,
  .admin-event small{
    display:block;
    margin-top:2px;
    color:var(--adm-ink-faint);
  }
  .admin-group-title{
    margin:4px 0 -6px;
    color:var(--adm-ink-faint);
    font-size:12px;
    font-weight:900;
    letter-spacing:.14em;
    text-transform:uppercase;
  }
  .admin-service-grid,
  .admin-control-grid{
    display:grid;
    grid-template-columns:repeat(4,minmax(0,1fr));
    gap:16px;
  }
  .admin-service-card,
  .admin-control-card{
    border-radius:24px;
    padding:20px;
    min-height:210px;
    color:var(--adm-ink);
    text-decoration:none;
    display:flex;
    flex-direction:column;
    gap:12px;
  }
  .admin-service-card h3,
  .admin-control-card h3{
    margin:0;
    color:var(--adm-ink);
    font-size:18px;
    letter-spacing:-.01em;
  }
  .admin-service-card p,
  .admin-control-card p{
    margin:0;
    color:var(--adm-ink-soft);
    line-height:1.5;
    font-size:13px;
  }
  .admin-service-icon,
  .admin-control-icon{
    width:44px;
    height:44px;
    border-radius:14px;
    background:var(--adm-accent-soft);
    color:var(--adm-accent-ink);
  }
  .admin-service-card .admin-status,
  .admin-control-card .btn,
  .admin-control-card .mini-actions{
    margin-top:auto;
  }
  .admin-control-card .mini-actions .btn{
    margin-top:0;
  }
  .admin-page-head{
    align-items:center;
    margin-bottom:4px;
  }
  .admin-page-head p{
    max-width:760px;
  }
  .btn.sm,
  .admin-card-panel .btn.sm{
    min-height:34px;
    padding:8px 12px;
    border-radius:12px;
    font-size:12px;
  }
  body.portal-admin-dashboard .btn.primary,
  body.portal-admin-dashboard .btn.dark{
    background:linear-gradient(135deg,var(--adm-accent),var(--adm-accent-2));
    color:#fff;
    border-color:transparent;
    box-shadow:0 14px 30px rgba(120,75,24,.18);
  }
  body.portal-admin-dashboard .btn.soft{
    background:var(--adm-surface-2);
    color:var(--adm-accent-ink);
    border-color:var(--adm-line);
    box-shadow:none;
  }
  @media(max-width:1120px){
    .admin-kpis,
    .admin-service-grid,
    .admin-control-grid{
      grid-template-columns:repeat(2,minmax(0,1fr));
    }
    .admin-two{
      grid-template-columns:1fr;
    }
    .admin-appbar{
      flex-wrap:wrap;
    }
    .admin-seg{
      order:3;
      width:100%;
      justify-content:flex-start;
    }
  }
  @media(max-width:720px){
    .admin-dashboard{
      padding:12px;
    }
    .admin-brand span:not(.admin-logo),
    .admin-me-text{
      display:none;
    }
    .admin-actions-top{
      gap:6px;
    }
    .admin-iconbtn,
    .admin-avatar,
    .admin-logo{
      width:40px;
      height:40px;
    }
    .admin-hero,
    .admin-page-head{
      flex-direction:column;
      align-items:flex-start;
    }
    .admin-hero h1,
    .admin-page-head h1{
      font-size:28px;
    }
    .admin-hero-actions,
    .admin-page-head .btn{
      width:100%;
    }
    .admin-hero-actions .btn,
    .admin-page-head .btn{
      width:100%;
    }
    .admin-kpis,
    .admin-service-grid,
    .admin-control-grid{
      grid-template-columns:1fr;
    }
    .admin-kpi,
    .admin-service-card,
    .admin-control-card{
      min-height:auto;
    }
  }

  /* Final admin visual override: prototype geometry wins over the legacy portal shell. */
  body.portal-admin-dashboard{
    --adm-r-lg:22px;
    --adm-sp-4:18px;
    --adm-sp-5:24px;
    --adm-sp-6:38px;
    --adm-shadow:0 10px 30px rgba(120,95,50,.08);
    --adm-shadow-hi:0 22px 56px rgba(120,95,50,.14);
    --adm-warn:#b07d12;
    --adm-warn-soft:#fbf0d6;
    --adm-surface:rgba(255,255,255,.72);
    --adm-surface-2:rgba(255,255,255,.55);
    --adm-line:rgba(120,100,70,.13);
    --adm-brd:rgba(255,255,255,.7);
    --adm-tab-on-bg:#fff;
    --adm-tab-on-ink:var(--adm-accent-ink);
    background:var(--adm-bg);
    color:var(--adm-ink);
    overflow-x:hidden;
  }
  html[data-theme="dark"] body.portal-admin-dashboard{
    --adm-shadow:0 16px 40px rgba(0,0,0,.45);
    --adm-shadow-hi:0 26px 56px rgba(0,0,0,.55);
    --adm-warn:#e9b04a;
    --adm-warn-soft:rgba(233,176,74,.16);
    --adm-surface:rgba(40,34,28,.55);
    --adm-surface-2:rgba(54,46,38,.5);
    --adm-line:rgba(255,255,255,.08);
    --adm-brd:rgba(255,255,255,.08);
    --adm-tab-on-bg:rgba(255,170,90,.16);
    --adm-tab-on-ink:var(--adm-accent-2);
  }
  body.portal-admin-dashboard .admin-dashboard{
    min-height:100vh;
    padding:0;
    overflow:visible;
  }
  body.portal-admin-dashboard .admin-dashboard .glass{
    background:var(--adm-surface);
    border:1px solid var(--adm-brd);
    box-shadow:var(--adm-shadow);
    backdrop-filter:blur(16px) saturate(1.3);
    -webkit-backdrop-filter:blur(16px) saturate(1.3);
  }
  body.portal-admin-dashboard .admin-wrap{
    position:relative;
    z-index:1;
    width:auto;
    max-width:none;
    margin:0;
  }
  body.portal-admin-dashboard .admin-appbar{
    position:sticky;
    top:0;
    z-index:5;
    display:flex;
    align-items:center;
    gap:14px;
    min-height:0;
    padding:8px 16px;
    border:0;
    border-bottom:1px solid var(--adm-line);
    border-radius:0;
    box-shadow:var(--adm-shadow);
  }
  body.portal-admin-dashboard .admin-brand{
    min-width:0;
    gap:10px;
    color:var(--adm-ink);
    font-size:18px;
    font-weight:800;
    letter-spacing:0;
  }
  body.portal-admin-dashboard .admin-logo{
    width:32px;
    height:32px;
    border-radius:10px;
    box-shadow:none;
    font-size:14px;
  }
  body.portal-admin-dashboard .admin-seg{
    position:absolute;
    left:0;
    right:0;
    top:50%;
    transform:translateY(-50%);
    width:fit-content;
    max-width:max(160px,calc(100% - 520px));
    margin-inline:auto;
    display:flex;
    justify-content:flex-start;
    gap:4px;
    padding:5px;
    overflow-x:auto;
    scrollbar-width:none;
    border:1px solid var(--adm-line);
    border-radius:999px;
    background:var(--adm-surface-2);
    box-shadow:inset 0 1px 3px rgba(120,100,70,.08);
  }
  body.portal-admin-dashboard .admin-seg::-webkit-scrollbar{
    display:none;
  }
  body.portal-admin-dashboard .admin-tab{
    min-height:0;
    padding:9px 16px;
    border:0;
    border-radius:999px;
    color:var(--adm-ink-soft);
    background:transparent;
    font-size:13px;
    font-weight:700;
    transition:.2s cubic-bezier(.4,0,.2,1);
  }
  body.portal-admin-dashboard .admin-tab.on{
    color:var(--adm-tab-on-ink);
    background:var(--adm-tab-on-bg);
    border:0;
    box-shadow:var(--adm-shadow);
  }
  body.portal-admin-dashboard .admin-tab-ic{
    width:24px;
    height:24px;
    border-radius:7px;
    background:var(--adm-accent-soft);
    color:var(--adm-accent-ink);
  }
  body.portal-admin-dashboard .admin-tab-ic svg{
    width:14px;
    height:14px;
  }
  body.portal-admin-dashboard .admin-iconbtn{
    width:38px;
    height:38px;
    min-height:0;
    border:1px solid var(--adm-line);
    border-radius:999px;
    background:var(--adm-surface-2);
    color:var(--adm-ink-soft);
  }
  body.portal-admin-dashboard #adminLogoutButton{
    display:grid;
  }
  body.portal-admin-dashboard .admin-me{
    min-height:0;
    padding:0 0 0 4px;
    border:0;
    background:transparent;
    color:var(--adm-ink);
  }
  body.portal-admin-dashboard .admin-avatar{
    width:38px;
    height:38px;
    border-radius:999px;
    box-shadow:none;
    font-size:13px;
  }
  body.portal-admin-dashboard .admin-page{
    max-width:1180px;
    margin:0 auto;
    padding:var(--adm-sp-5) var(--adm-sp-6) var(--adm-sp-6);
    display:grid;
    gap:var(--adm-sp-4);
  }
  body.portal-admin-dashboard .admin-pane{
    display:grid;
    gap:var(--adm-sp-4);
  }
  body.portal-admin-dashboard .admin-pane.hidden{
    display:none!important;
  }
  body.portal-admin-dashboard .admin-hero{
    align-items:flex-end;
    gap:18px;
    padding:0;
    border-radius:0;
  }
  body.portal-admin-dashboard .admin-hero h1,
  body.portal-admin-dashboard .admin-page-head h1{
    margin:0 0 5px;
    color:var(--adm-ink);
    font-size:26px;
    line-height:1.15;
    letter-spacing:-.01em;
  }
  body.portal-admin-dashboard .admin-hero p,
  body.portal-admin-dashboard .admin-page-head p{
    margin:0;
    color:var(--adm-ink-soft);
    font-size:14px;
    line-height:1.45;
  }
  body.portal-admin-dashboard .admin-hero p{
    display:flex;
    align-items:center;
    gap:8px;
  }
  body.portal-admin-dashboard .admin-dot{
    width:8px;
    height:8px;
    margin:0;
    box-shadow:0 0 0 4px var(--adm-ok-soft);
  }
  body.portal-admin-dashboard .admin-hero-actions{
    display:flex;
    gap:10px;
    flex-wrap:nowrap;
  }
  body.portal-admin-dashboard .admin-hero-actions .btn{
    border-radius:999px;
    padding:11px 18px;
    font-size:14px;
    font-weight:800;
  }
  body.portal-admin-dashboard .admin-hero-actions .btn.soft{
    background:var(--adm-surface);
    border:1px solid var(--adm-line);
    color:var(--adm-ink);
  }
  body.portal-admin-dashboard .btn.primary,
  body.portal-admin-dashboard .btn.dark{
    color:#fff;
    background:linear-gradient(135deg,color-mix(in srgb,var(--adm-accent) 90%,transparent),color-mix(in srgb,var(--adm-accent-2) 90%,transparent));
    border-color:transparent;
    box-shadow:var(--adm-shadow);
  }
  body.portal-admin-dashboard .btn.soft{
    background:var(--adm-surface);
    border:1px solid var(--adm-line);
    color:var(--adm-accent-ink);
  }
  body.portal-admin-dashboard .admin-kpis{
    grid-template-columns:repeat(4,1fr);
    gap:var(--adm-sp-4);
  }
  body.portal-admin-dashboard .admin-kpi{
    min-height:0;
    position:relative;
    display:block;
    padding:18px 20px;
    border-radius:var(--adm-r-lg);
    text-align:left;
    transition:.2s cubic-bezier(.4,0,.2,1);
  }
  body.portal-admin-dashboard .admin-kpi:hover{
    transform:translateY(-3px);
    box-shadow:var(--adm-shadow-hi);
  }
  body.portal-admin-dashboard .admin-kpi::after{
    content:"↗";
    position:absolute;
    top:15px;
    right:17px;
    color:var(--adm-ink-faint);
    font-size:13px;
    font-weight:800;
  }
  body.portal-admin-dashboard .admin-kpi-icon{
    width:36px;
    height:36px;
    margin-bottom:12px;
    border-radius:11px;
  }
  body.portal-admin-dashboard .admin-kpi-icon svg{
    width:18px;
    height:18px;
  }
  body.portal-admin-dashboard .admin-kpi strong{
    display:block;
    margin:0;
    font-size:26px;
    line-height:1;
    letter-spacing:-.02em;
  }
  body.portal-admin-dashboard .admin-kpi > span:not(.admin-kpi-icon){
    display:block;
    margin-top:2px;
    color:var(--adm-ink-soft);
    font-size:13px;
    font-weight:400;
  }
  body.portal-admin-dashboard .admin-kpi small{
    display:inline-block;
    margin-top:7px;
    padding:3px 9px;
    border-radius:999px;
    background:var(--adm-ok-soft);
    color:var(--adm-ok);
    font-size:12px;
    font-weight:800;
  }
  body.portal-admin-dashboard .admin-two{
    grid-template-columns:1fr 1fr;
    gap:var(--adm-sp-4);
  }
  body.portal-admin-dashboard .admin-card-panel{
    min-height:0;
    padding:var(--adm-sp-5);
    border-radius:var(--adm-r-lg);
  }
  body.portal-admin-dashboard .admin-panel-head{
    margin-bottom:14px;
  }
  body.portal-admin-dashboard .admin-panel-head h2{
    font-size:15px;
    letter-spacing:0;
  }
  body.portal-admin-dashboard .admin-status-list{
    display:block;
    margin-top:0;
  }
  body.portal-admin-dashboard .admin-health-group{
    margin:14px 0 9px;
    color:var(--adm-ink-faint);
    font-size:11px;
    font-weight:800;
    text-transform:uppercase;
    letter-spacing:.05em;
  }
  body.portal-admin-dashboard .admin-health-group:first-child{
    margin-top:0;
  }
  body.portal-admin-dashboard .admin-status-chips{
    display:flex;
    flex-wrap:wrap;
    gap:9px;
  }
  body.portal-admin-dashboard .admin-status-chip{
    display:flex;
    align-items:center;
    gap:8px;
    padding:7px 13px;
    border:1px solid var(--adm-line);
    border-radius:999px;
    background:var(--adm-surface-2);
    color:var(--adm-ink-soft);
    font-size:13px;
    font-weight:700;
  }
  body.portal-admin-dashboard .admin-status-chip .sd{
    width:8px;
    height:8px;
    border-radius:50%;
    background:currentColor;
  }
  body.portal-admin-dashboard .admin-status-chip.ok .sd{
    background:var(--adm-ok);
  }
  body.portal-admin-dashboard .admin-status-chip.warn{
    color:var(--adm-warn);
  }
  body.portal-admin-dashboard .admin-status-chip.warn .sd{
    background:var(--adm-warn);
  }
  body.portal-admin-dashboard .admin-status-chip.danger{
    color:var(--adm-danger);
  }
  body.portal-admin-dashboard .admin-status-chip.danger .sd{
    background:var(--adm-danger);
  }
  body.portal-admin-dashboard .admin-events{
    display:grid;
    gap:2px;
    margin-top:0;
  }
  body.portal-admin-dashboard .admin-event{
    display:flex;
    align-items:center;
    gap:13px;
    min-height:0;
    padding:11px 6px;
    border:0;
    border-radius:12px;
    background:transparent;
  }
  body.portal-admin-dashboard .admin-event + .admin-event{
    border-top:1px solid var(--adm-line);
  }
  body.portal-admin-dashboard .admin-event::before{
    content:none;
  }
  body.portal-admin-dashboard .admin-event-icon{
    width:34px;
    height:34px;
    flex:0 0 34px;
    display:grid;
    place-items:center;
    border-radius:10px;
    background:var(--adm-accent-soft);
    color:var(--adm-accent-ink);
  }
  body.portal-admin-dashboard .admin-event.ok .admin-event-icon{
    background:var(--adm-ok-soft);
    color:var(--adm-ok);
  }
  body.portal-admin-dashboard .admin-event.warn .admin-event-icon{
    background:var(--adm-warn-soft);
    color:var(--adm-warn);
  }
  body.portal-admin-dashboard .admin-event.danger .admin-event-icon{
    background:var(--adm-danger-soft);
    color:var(--adm-danger);
  }
  body.portal-admin-dashboard .admin-event-icon svg{
    width:16px;
    height:16px;
  }
  body.portal-admin-dashboard .admin-event-text strong{
    display:block;
    color:var(--adm-ink);
    font-size:13.5px;
    line-height:1.25;
  }
  body.portal-admin-dashboard .admin-event-text span{
    display:block;
    margin-top:2px;
    color:var(--adm-ink-faint);
    font-size:12px;
    line-height:1.25;
  }
  body.portal-admin-dashboard .admin-hintbar{
    position:fixed;
    left:50%;
    bottom:16px;
    z-index:6;
    transform:translateX(-50%);
    padding:9px 18px;
    border-radius:999px;
    color:var(--adm-ink-soft);
    font-size:12px;
    line-height:1;
    white-space:nowrap;
  }
  body.portal-admin-dashboard .admin-page-head{
    align-items:center;
    margin:0 0 4px;
  }
  body.portal-admin-dashboard .admin-service-grid,
  body.portal-admin-dashboard .admin-control-grid{
    grid-template-columns:repeat(4,minmax(0,1fr));
    gap:var(--adm-sp-4);
  }
  body.portal-admin-dashboard .admin-service-card,
  body.portal-admin-dashboard .admin-control-card{
    min-height:210px;
    border-radius:var(--adm-r-lg);
    padding:20px;
  }
  @media(max-width:1120px){
    body.portal-admin-dashboard .admin-appbar{
      flex-wrap:wrap;
    }
    body.portal-admin-dashboard .admin-seg{
      position:static;
      transform:none;
      order:3;
      width:100%;
      max-width:none;
      margin:6px 0 0;
    }
    body.portal-admin-dashboard .admin-kpis,
    body.portal-admin-dashboard .admin-service-grid,
    body.portal-admin-dashboard .admin-control-grid{
      grid-template-columns:repeat(2,minmax(0,1fr));
    }
    body.portal-admin-dashboard .admin-two{
      grid-template-columns:1fr;
    }
  }
  @media(max-width:720px){
    body.portal-admin-dashboard .admin-page{
      padding:18px;
    }
    body.portal-admin-dashboard .admin-brand span:not(.admin-logo),
    body.portal-admin-dashboard .admin-me-text{
      display:none;
    }
    body.portal-admin-dashboard .admin-hero,
    body.portal-admin-dashboard .admin-page-head{
      flex-direction:column;
      align-items:flex-start;
    }
    body.portal-admin-dashboard .admin-hero-actions,
    body.portal-admin-dashboard .admin-hero-actions .btn,
    body.portal-admin-dashboard .admin-page-head .btn{
      width:100%;
    }
    body.portal-admin-dashboard .admin-kpis,
    body.portal-admin-dashboard .admin-service-grid,
    body.portal-admin-dashboard .admin-control-grid{
      grid-template-columns:1fr;
    }
    body.portal-admin-dashboard .admin-hintbar{
      display:none;
    }
  }
