/* =========================================================
   KK PHONE — LIGHT / GREEN THEME
   FULL STYLE.CSS (iOS PERFECT + POLISHED AUTH + DASHBOARD)
========================================================= */

*{box-sizing:border-box}
html,body{height:100%}
body{margin:0}
a{color:inherit}

/* =========================================================
   iOS SAFARI — PREVENT AUTO ZOOM / SCALE + APP FEEL
========================================================= */

/* iOS zooms focused inputs if font-size < 16px */
input, select, textarea{
  font-size:16px !important;
}

/* Ensure our styled inputs never trigger iOS zoom */
.kkInput, .kkCode, .kkInputPhone{
  font-size:16px !important;
}

html, body{
  -webkit-text-size-adjust: 100%;
  touch-action: manipulation;
}

/* Remove iOS rubber-band/bounce: make body fixed, scroll inside .kkApp */
body.kkView,
body.kkDash{
  position: fixed;
  inset: 0;
  width: 100%;
  height: 100%;
  overflow: hidden;
}

/* The app scroll container (if content ever exceeds) */
.kkApp{
  height: 100%;
  overflow: auto;
  -webkit-overflow-scrolling: touch;
  padding-bottom: env(safe-area-inset-bottom);
}

button, a{
  -webkit-tap-highlight-color: transparent;
}

/* ---------- THEME VARIABLES ---------- */
:root{
  --kk-bg: #f4f7f5;
  --kk-panel: #ffffff;
  --kk-stroke: #e5e7eb;

  --kk-text: #0f172a;
  --kk-muted: #6b7280;

  --kk-accent: #22c55e;
  --kk-accent2:#16a34a;
  --kk-glow: rgba(34,197,94,.28);

  --kk-danger:#ef4444;
  --kk-ok:#22c55e;

  --kk-shadow1: 0 26px 60px rgba(15,23,42,.12);
  --kk-shadow2: 0 10px 22px rgba(15,23,42,.08);
}

/* =========================================================
   AUTH PAGES
========================================================= */

.kkView{
  color:var(--kk-text);
  font-family: system-ui, -apple-system, Segoe UI, Roboto, Arial;

  display:flex;
  justify-content:center;
  align-items:flex-start;

  background:
    radial-gradient(900px 480px at 50% 0%, rgba(34,197,94,.16), transparent 60%),
    radial-gradient(900px 540px at 50% 100%, rgba(15,23,42,.06), transparent 65%),
    linear-gradient(180deg, #ffffff, #eef4f1);
  overflow:hidden;
  position:relative;
  min-height:100%;
}

.kkView::before{
  content:"";
  position:absolute;
  inset:-200px;
  pointer-events:none;
  background:
    radial-gradient(600px 420px at 18% 16%, rgba(34,197,94,.12), transparent 60%),
    radial-gradient(700px 480px at 84% 18%, rgba(15,23,42,.06), transparent 62%),
    radial-gradient(900px 650px at 50% 92%, rgba(34,197,94,.10), transparent 65%);
  filter: blur(12px);
  opacity:.95;
}

/* optional background layer */
.kkBgGlow{ display:none; }

.kkWrap{
  width:100%;
  max-width:560px;
  padding:22px 16px 36px;
  margin-top: clamp(20px, 5vh, 56px);
  position:relative;
  z-index:1;
}

.kkShell{ width:100%; }

/* ---------- AUTH HEADER ---------- */
.kkHeader{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:14px;
  margin-bottom:14px;
}

.kkBrand{
  display:flex;
  align-items:center;
  gap:12px;
  min-width:0;
}
.kkBrandText{min-width:0}

.kkBrandTitle{
  font-weight:950;
  font-size:20px;
  letter-spacing:.2px;
  line-height:1.1;
}

.kkBrandSub{
  margin-top:4px;
  font-size:13px;
  color:var(--kk-muted);
  line-height:1.35;
}

.kkLogoCircle{
  width:64px;
  height:64px;
  border-radius:999px;
  background:#fff;
  border:1px solid var(--kk-stroke);
  box-shadow: 0 0 0 8px rgba(34,197,94,.10), 0 14px 30px rgba(15,23,42,.10);
  display:grid;
  place-items:center;
  overflow:hidden;
  flex:0 0 auto;
}

.kkLogoCircle img{
  width:62%;
  height:62%;
  object-fit:contain;
}

/* verify page center wrapper */
.kkLogoCenter{display:flex; justify-content:center; margin-bottom:10px}

.kkPill{
  display:inline-flex;
  align-items:center;
  gap:8px;
  padding:8px 11px;
  border-radius:999px;
  font-size:12px;
  font-weight:800;
  background: rgba(255,255,255,.75);
  border:1px solid rgba(15,23,42,.10);
  box-shadow: 0 6px 14px rgba(15,23,42,.06);
  white-space:nowrap;
}

.kkDot{
  width:8px;height:8px;border-radius:99px;
  background: rgba(34,197,94,.95);
  box-shadow: 0 0 0 4px rgba(34,197,94,.16);
}

.kkTitleBig{ text-align:center; font-weight:950; font-size:20px; margin:10px 0 2px; }
.kkSubCenter{ text-align:center; font-size:13px; color:var(--kk-muted); margin:0 0 14px; }

/* ---------- AUTH CARD ---------- */
.kkCard{
  background:var(--kk-panel);
  border:1px solid rgba(15,23,42,.10);
  border-radius:22px;
  padding:18px;
  box-shadow: var(--kk-shadow1), var(--kk-shadow2);
}
.kkCard::before{ display:none !important; }
.kkCardTight{ padding:18px; }

/* ---------- HINT / ALERT ---------- */
.kkHintRow{
  display:flex;
  gap:10px;
  align-items:flex-start;
  padding:12px 12px;
  border-radius:16px;
  background: rgba(34,197,94,.08);
  border:1px solid rgba(34,197,94,.18);
  margin-bottom:12px;
}

.kkHintIcon{
  width:24px;height:24px;
  border-radius:10px;
  display:grid;
  place-items:center;
  font-weight:950;
  background: rgba(34,197,94,.14);
  border:1px solid rgba(34,197,94,.22);
  color:#0f172a;
  flex:0 0 auto;
  margin-top:1px;
}

.kkHintText{
  font-size:13px;
  line-height:1.35;
  color:#0f172a;
}

.kkAlert{
  display:flex;
  gap:10px;
  align-items:flex-start;
  padding:12px;
  border-radius:16px;
  border:1px solid rgba(15,23,42,.12);
  background: rgba(255,255,255,.70);
  margin-bottom:12px;
}

.kkAlertDanger{
  border-color: rgba(239,68,68,.30);
  background: rgba(239,68,68,.10);
}

.kkAlertIcon{
  width:28px;height:28px;
  border-radius:10px;
  display:grid;
  place-items:center;
  font-weight:950;
  background: rgba(239,68,68,.18);
  border:1px solid rgba(239,68,68,.28);
  flex:0 0 auto;
  margin-top:1px;
}

.kkAlertTitle{ font-weight:950; font-size:13px; margin-bottom:2px; }
.kkAlertText{ font-size:13px; line-height:1.35; }

/* ---------- FORM ---------- */
.kkForm{ margin-top:6px; }

.kkLabel{
  display:block;
  margin-top:12px;
  font-size:11px;
  letter-spacing:.08em;
  text-transform:uppercase;
  color:var(--kk-muted);
}

.kkInput,.kkCode{
  width:100%;
  margin-top:6px;
  padding:14px;
  border-radius:14px;
  border:1px solid rgba(15,23,42,.12);
  background:#ffffff;
  color:#111827;
  font-weight:850;
}

.kkCode{
  text-align:center;
  letter-spacing:.35em;
}

.kkInput:focus,.kkCode:focus{
  outline:none;
  border-color: rgba(34,197,94,.55);
  box-shadow:0 0 0 4px rgba(34,197,94,.18);
}

.kkField{
  display:flex;
  align-items:center;
  border-radius:16px;
  overflow:hidden;
  border:1px solid rgba(15,23,42,.12);
  background:#fff;
  margin-top:6px;
  box-shadow: 0 8px 18px rgba(15,23,42,.06);
}

.kkFieldPrefix{
  padding:13px 12px;
  font-size:13px;
  font-weight:900;
  color:var(--kk-muted);
  border-right:1px solid rgba(15,23,42,.10);
  background: rgba(244,247,245,.9);
}

.kkInputPhone{
  border:0 !important;
  background: transparent !important;
  width:100%;
  padding:13px 12px;
  outline:none;
  font-weight:900;
  letter-spacing:.2px;
}

/* ---------- BUTTONS ---------- */
.kkBtn{
  width:100%;
  margin-top:14px;
  padding:14px;
  border-radius:16px;
  border:none;
  background:linear-gradient(180deg, var(--kk-accent), var(--kk-accent2));
  color:#ffffff;
  font-weight:950;
  cursor:pointer;
  box-shadow: 0 14px 30px rgba(34,197,94,.28), inset 0 -2px 0 rgba(0,0,0,.12);
  transition: transform .12s ease, filter .12s ease, box-shadow .12s ease;
}

.kkBtn:hover{
  filter:brightness(1.05);
  box-shadow: 0 18px 36px rgba(34,197,94,.28), inset 0 -2px 0 rgba(0,0,0,.12);
}

.kkBtn:active{ transform: scale(.985); }

.kkBtnPrimary{
  display:flex;
  align-items:center;
  justify-content:center;
  gap:10px;
}

.kkBtnMeta{
  font-size:12px;
  font-weight:950;
  padding:4px 9px;
  border-radius:999px;
  background: rgba(255,255,255,.20);
  border:1px solid rgba(255,255,255,.22);
}

.kkMicro{
  margin-top:10px;
  font-size:12px;
  color:var(--kk-muted);
  text-align:center;
  line-height:1.35;
}

.kkFooterNote{
  margin-top:12px;
  text-align:center;
  font-size:12px;
  color:var(--kk-muted);
}

.kkLock{ margin-right:6px; opacity:.85; }

/* notices */
.kkError,.kkNotice{
  margin-top:12px;
  padding:12px 14px;
  border-radius:14px;
  font-size:13px;
}

.kkError{
  background:#fee2e2;
  border:1px solid #fecaca;
  color:#991b1b;
}

.kkNotice{
  background:#f1f5f9;
  border:1px solid #e5e7eb;
  color:#334155;
}

/* verify links */
.kkLinks{
  margin-top:14px;
  display:flex;
  justify-content:space-between;
  gap:12px;
  font-size:12px;
  color:rgba(15,23,42,.80);
}
.kkLinks a{
  text-decoration:none;
  border-bottom: 1px dashed rgba(15,23,42,.20);
}
.kkLinks a:active{ opacity:.75; }

/* =========================================================
   DASHBOARD — PREMIUM LAYOUT + PERFECT CENTERING (iOS)
========================================================= */

.kkDash{
  color:var(--kk-text);
  font-family: system-ui, -apple-system, Segoe UI, Roboto, Arial;
  min-height:100%;

  background:
    radial-gradient(900px 520px at 50% 10%, rgba(34,197,94,.16), transparent 62%),
    radial-gradient(900px 600px at 50% 95%, rgba(15,23,42,.06), transparent 70%),
    linear-gradient(180deg, #ffffff, #eef4f1);
}

/* Sticky top bar */
.topBar{
  position: sticky;
  top: 0;
  z-index: 10;

  display:flex;
  justify-content:space-between;
  align-items:center;

  padding-top: calc(14px + env(safe-area-inset-top));
  padding-left: 18px;
  padding-right: 18px;
  padding-bottom: 14px;

  background: rgba(255,255,255,.78);
  border-bottom: 1px solid rgba(15,23,42,.08);
  backdrop-filter: blur(10px);
}

.topLeft{
  display:flex;
  align-items:center;
  gap:10px;
  min-width:0;
}

.topLogo{
  width:38px;height:38px;border-radius:999px;
  background:#ffffff;
  border:1px solid rgba(15,23,42,.10);
  box-shadow: 0 10px 18px rgba(15,23,42,.08);
  display:flex;
  align-items:center;
  justify-content:center;
  overflow:hidden;
  flex:0 0 auto;
}
.topLogo img{ width:62%; height:62%; object-fit:contain; }

.topTitle{
  font-weight:950;
  font-size:16px;
  letter-spacing:.2px;
  line-height:1.1;
}

.topSub{
  font-size:12px;
  color:var(--kk-muted);
  opacity:.88;
  line-height:1.2;
}

.logoutBtn{
  font-size:12px;
  padding:10px 12px;
  border-radius:12px;
  border:1px solid rgba(15,23,42,.12);
  background:#ffffff;
  font-weight:800;
  text-decoration:none;
}

/* Dialer device panel — FIXED CENTERING */
.dialer{
  width: min(520px, calc(100% - 32px));
  margin: 26px auto 0;
  padding: 22px 20px 22px;

  display:flex;
  flex-direction:column;
  gap:14px;

  border-radius:30px;
  background: rgba(255,255,255,.82);
  border: 1px solid rgba(15,23,42,.10);

  box-shadow:
    0 40px 90px rgba(15,23,42,.14),
    0 14px 26px rgba(15,23,42,.08);

  position:relative;
  overflow:hidden;
}

/* inner frame */
.dialer::before{
  content:"";
  position:absolute;
  inset:10px;
  border-radius:24px;
  border: 1px solid rgba(15,23,42,.06);
  pointer-events:none;
}

/* Dialer brand header */
.kkDialerBrand{
  display:flex;
  align-items:center;
  justify-content:center;
  gap:10px;
  margin-bottom: 2px;
  position:relative;
  z-index:1;
}

.kkDialerLogo{
  width:38px;height:38px;border-radius:999px;
  background:#fff;
  border:1px solid rgba(15,23,42,.10);
  box-shadow: 0 10px 18px rgba(15,23,42,.08);
  display:grid;
  place-items:center;
  overflow:hidden;
}

.kkDialerLogo img{
  width:62%;
  height:62%;
  object-fit:contain;
}

.kkDialerBrandText{ text-align:left; }
.kkDialerTitle{
  font-weight:950;
  font-size:13px;
  letter-spacing:.2px;
  line-height:1.1;
}
.kkDialerSub{
  font-size:11.5px;
  color:var(--kk-muted);
  margin-top:2px;
}

/* Screen */
.screen{
  border-radius:22px;
  padding:16px 14px;
  position:relative;
  z-index:1;

  background: linear-gradient(180deg, #ffffff, #f7faf9);
  border: 1px solid rgba(15,23,42,.10);

  box-shadow:
    inset 0 -1px 0 rgba(15,23,42,.06),
    0 10px 22px rgba(15,23,42,.06);
}

.dialDisplay{
  min-height:32px;
  font-size:26px;
  font-weight:900;
  letter-spacing:.14em;
  text-align:center;
}

.dialHint{
  margin-top:8px;
  font-size:11.5px;
  color:var(--kk-muted);
  text-align:center;
  opacity:.85;
}

/* Keypad */
.pad{
  display:grid;
  grid-template-columns: repeat(3, 1fr);
  gap:12px;
  margin-top:4px;
  position:relative;
  z-index:1;
}

/* Keypad button polish (preserved behavior, upgraded shape) */
.key{
  background: linear-gradient(180deg, #ffffff, #f8fafc);
  box-shadow:
    0 4px 10px rgba(15,23,42,.08),
    inset 0 -1px 0 rgba(15,23,42,.08);
  transition: transform .08s ease, box-shadow .08s ease;

  padding:16px 0;
  border-radius:20px;
  border:1px solid rgba(15,23,42,.10);
  color:#111827;
  font-size:22px;
  font-weight:900;
  cursor:pointer;
}

.key:hover{
  box-shadow:
    0 6px 14px rgba(15,23,42,.12),
    inset 0 -1px 0 rgba(15,23,42,.08);
}

.key:active{
  transform: scale(.96);
  box-shadow:
    0 2px 6px rgba(15,23,42,.10),
    inset 0 1px 2px rgba(15,23,42,.12);
  border-color: rgba(34,197,94,.55);
}

/* Actions bar */
.actions{
  display:flex;
  justify-content:space-between;
  gap:10px;
  margin-top:12px;
  padding-top:14px;
  border-top: 1px solid rgba(15,23,42,.10);
  position:relative;
  z-index:1;
}

.btnGhost{
  flex:1;
  padding:12px;
  border-radius:16px;
  border: 1px solid rgba(15,23,42,.12);
  background: linear-gradient(180deg, #ffffff, #f8fafc);
  font-weight:900;
  box-shadow: 0 10px 18px rgba(15,23,42,.06);
  cursor:pointer;
}

.btnCall{
  flex:1.2;
  padding:12px;
  border-radius:16px;
  border:none;
  background:linear-gradient(180deg, var(--kk-accent), var(--kk-accent2));
  color:#ffffff;
  font-weight:950;
  box-shadow:
    0 22px 44px rgba(34,197,94,.34),
    inset 0 -2px 0 rgba(0,0,0,.12);
  cursor:pointer;
}

.btnCall:hover{ filter: brightness(1.05); }

/* Toast */
.toast{
  opacity:0;
  transform:translateY(6px);
  transition:.18s ease;
  padding:10px 12px;
  border-radius:14px;
  border:1px solid rgba(15,23,42,.10);
  background:#ffffff;
  font-size:12px;
}
.toast.show{opacity:1; transform:translateY(0)}
.toast.ok{border-color:#bbf7d0}
.toast.bad{border-color:#fecaca}

/* =========================================================
   RESPONSIVE
========================================================= */

@media (max-width:520px){
  .kkHeader{
    flex-direction:column;
    align-items:flex-start;
    gap:10px;
  }
  .kkPill{ align-self:flex-start; }
}

@media (max-width:420px){
  .kkWrap{ padding:18px 14px 32px; }
  .kkLogoCircle{ width:58px; height:58px; }
  .kkBrandTitle{ font-size:19px; }

  .dialer{
    margin-top:20px;
    padding:18px 14px 18px;
    border-radius:26px;
  }

  .dialDisplay{ font-size:24px; }
}
/* =========================================================
   THE LAB ARTS DISTRICT AUTH OVERRIDES
========================================================= */

body.kkView{
  position:fixed;
  inset:0;
  margin:0;
  min-height:100dvh;
  background:#000;
  color:#fff;
  font-family: "Avenir Next", "Montserrat", "Helvetica Neue", Arial, sans-serif;
  overflow:hidden;
}

body.kkView::before,
body.kkView::after{
  content:"";
  position:fixed;
  top:0;
  bottom:0;
  width:clamp(24px, 7vw, 68px);
  z-index:0;
  background:
    repeating-linear-gradient(
      150deg,
      #f4f4f4 0,
      #f4f4f4 34px,
      #0f1217 34px,
      #0f1217 43px
    );
}

body.kkView::before{ left:0; }
body.kkView::after{ right:0; }

.kkApp{
  position:relative;
  z-index:1;
  height:100%;
  overflow:auto;
}

.kkWrap{
  width:min(760px, 100%);
  margin:0 auto;
  padding:clamp(120px, 21dvh, 260px) 16px 40px;
}

.kkShell{
  max-width:560px;
  margin:0 auto;
}

.kkHeader,
.kkBgGlow,
.kkHintRow,
.kkMicro,
.kkFooterNote{
  display:none !important;
}

.kkLogoCenterLab{
  margin:0 auto 24px;
}

.kkLabLogo{
  display:block;
  width:min(220px, 52vw);
  max-height:120px;
  margin:0 auto;
  object-fit:contain;
  filter:brightness(0) invert(1) contrast(1.06);
}

.kkCard.kkLabCard{
  border-radius:22px;
  border:1px solid #2e3440;
  background:rgba(7, 9, 12, .96);
  padding:0;
  box-shadow:none;
  overflow:hidden;
}

.kkLabIntro{
  padding:18px 22px 14px;
  border-bottom:1px solid #222933;
}

.kkLabTitle{
  color:#fff;
  font-size:42px;
  font-size:clamp(27px, 4.15vw, 42px);
  line-height:1.06;
  letter-spacing:.04em;
  font-weight:900;
  text-transform:uppercase;
}

.kkLabSub{
  margin-top:8px;
  color:#aeb4be;
  font-size:13px;
  line-height:1.35;
}

.kkLabForm{
  padding:16px 22px 18px;
}

.kkLabel{
  margin-top:0;
  margin-bottom:10px;
  color:#d2d6de;
  font-size:13px;
  letter-spacing:.02em;
  font-weight:700;
}

.kkField.kkLabField{
  border:0;
  background:transparent;
  box-shadow:none;
  overflow:visible;
  gap:10px;
}

.kkFieldPrefix{
  min-width:82px;
  border:1px solid #9ca3af;
  border-right:1px solid #9ca3af;
  border-radius:14px;
  text-align:center;
  background:#f5f5f5;
  color:#0f1115;
  font-size:39px;
  font-size:clamp(23px, 4.2vw, 39px);
  font-weight:800;
  line-height:1;
  padding:15px 8px;
}

.kkInputPhone{
  border:1px solid #9ca3af !important;
  border-radius:14px;
  background:#f5f5f5 !important;
  color:#181c22;
  font-size:38px;
  font-size:clamp(23px, 4.2vw, 38px);
  line-height:1;
  letter-spacing:.01em;
  font-weight:700;
  height:auto;
  padding:16px 18px;
}

.kkInputPhone::placeholder{ color:#a2a8b1; }

.kkBtn{
  margin-top:14px;
  border:1px solid #8d939d;
  border-radius:14px;
  background:#f5f5f5;
  color:#0f1115;
  box-shadow:none;
  font-size:44px;
  font-size:clamp(26px, 4.7vw, 44px);
  line-height:1;
  letter-spacing:.01em;
  text-align:center;
  padding:16px;
  font-weight:900;
}

.kkBtn:hover,
.kkBtn:active{
  filter:none;
  transform:none;
}

.kkBtnMeta{ display:none; }

.kkError,
.kkNotice{
  margin:14px 22px 0;
  border-radius:10px;
  font-size:13px;
}

.kkError{
  background:#3f1111;
  color:#ffd4d4;
  border:1px solid #8b2b2b;
}

.kkNotice{
  background:#1a2431;
  color:#d4dbea;
  border:1px solid #2e3a49;
}

.kkCode{
  border:1px solid #9ca3af;
  border-radius:14px;
  margin-top:0;
  background:#f5f5f5;
  color:#0f1115;
  font-size:40px;
  font-size:clamp(24px, 4.5vw, 40px);
  font-weight:800;
  letter-spacing:.17em;
}

.kkLinks.kkLabLinks{
  margin:0;
  padding:0 22px 18px;
  justify-content:space-between;
  font-size:12px;
  color:#d7dbe2;
}

.kkLinks.kkLabLinks a{
  border-bottom:1px solid rgba(215, 219, 226, .35);
}

.kkLabFooterLink{
  display:block;
  border-top:1px solid #222933;
  color:#d7dbe2;
  text-align:center;
  text-decoration:none;
  padding:13px 16px;
  font-size:13px;
  font-weight:500;
}

@media (max-width:520px){
  .kkWrap{
    padding-top:clamp(90px, 16dvh, 160px);
    padding-left:10px;
    padding-right:10px;
  }

  .kkLabSub{ font-size:12px; }
  .kkBtn{ padding:14px 12px; }
}

/* =========================================================
   THE LAB ARTS DISTRICT DASHBOARD OVERRIDES
========================================================= */

body.kkDash{
  position:fixed;
  inset:0;
  margin:0;
  min-height:100dvh;
  color:#f3f4f6;
  font-family: "Avenir Next", "Montserrat", "Helvetica Neue", Arial, sans-serif;
  background:#000;
  overflow:hidden;
}

body.kkDash::before,
body.kkDash::after{
  content:"";
  position:fixed;
  top:0;
  bottom:0;
  width:clamp(24px, 7vw, 68px);
  z-index:0;
  background:
    repeating-linear-gradient(
      150deg,
      #f4f4f4 0,
      #f4f4f4 34px,
      #0f1217 34px,
      #0f1217 43px
    );
}

body.kkDash::before{ left:0; }
body.kkDash::after{ right:0; }

body.kkDash .kkApp{
  position:relative;
  z-index:1;
  height:100%;
  overflow:auto;
  padding-bottom:30px;
}

body.kkDash .topBar{
  max-width:980px;
  margin:14px auto 0;
  border:1px solid #2b313d;
  border-radius:18px;
  background:rgba(8, 11, 16, .96);
  box-shadow:none;
  backdrop-filter:none;
}

body.kkDash .topLogo{
  background:#f5f5f5;
  border:1px solid #bfc4cd;
  box-shadow:none;
}

body.kkDash .topLogo img{
  filter:none;
}

body.kkDash .topTitle{
  color:#f8fafc;
  letter-spacing:.01em;
}

body.kkDash .topSub{
  color:#aab1bd;
  opacity:1;
}

body.kkDash .logoutBtn{
  background:#f5f5f5;
  border:1px solid #9ca3af;
  color:#111827;
  font-weight:900;
}

body.kkDash .dialer{
  width:min(560px, calc(100% - 26px));
  margin:20px auto 0;
  border-radius:24px;
  border:1px solid #293140;
  background:rgba(7, 9, 12, .96);
  box-shadow:none;
}

body.kkDash .dialer::before{
  border:1px solid #1e2430;
}

body.kkDash .kkDialerLogo{
  background:#f5f5f5;
  border:1px solid #bfc4cd;
  box-shadow:none;
}

body.kkDash .kkDialerTitle{ color:#f8fafc; }
body.kkDash .kkDialerSub{ color:#aab1bd; }

body.kkDash .screen{
  background:rgba(9, 13, 19, .96);
  border:1px solid #2a3341;
  box-shadow:none;
}

body.kkDash .dialDisplay{
  color:#f8fafc;
}

body.kkDash .dialHint{
  color:#acb3c0;
  opacity:1;
}

body.kkDash .key{
  background:#f5f5f5;
  border:1px solid #9ca3af;
  color:#0f1115;
  box-shadow:none;
}

body.kkDash .key:hover{
  box-shadow:none;
}

body.kkDash .key:active{
  transform:scale(.97);
  border-color:#6b7280;
  box-shadow:none;
}

body.kkDash .actions{
  border-top:1px solid #212a37;
}

body.kkDash .btnGhost,
body.kkDash .btnCall{
  border:1px solid #9ca3af;
  border-radius:14px;
  background:#f5f5f5;
  color:#0f1115;
  box-shadow:none;
  font-weight:900;
}

body.kkDash .btnCall:hover,
body.kkDash .btnGhost:hover{
  filter:none;
}

body.kkDash .toast{
  border:1px solid #3b4555;
  background:#0e1520;
  color:#f3f4f6;
}

body.kkDash .toast.ok{ border-color:#4b5563; }
body.kkDash .toast.bad{ border-color:#7f1d1d; }

@media (max-width:640px){
  body.kkDash .topBar{
    margin:10px 10px 0;
    border-radius:14px;
    padding-left:12px;
    padding-right:12px;
  }

  body.kkDash .dialer{
    width:calc(100% - 20px);
    margin-top:14px;
    border-radius:18px;
  }
}
