/* =========================================
   CallKeep Cloud — SaaS UI (Dark + Light)
   ========================================= */

:root{
  --accent:#11cdc6;
  --accent2:#0f93a0;
  --radius:14px;
  --shadow: 0 18px 55px rgba(0,0,0,.25);
  --shadow2: 0 10px 30px rgba(0,0,0,.18);
}

/* ===== THEME: DARK (default) ===== */
:root[data-theme="dark"]{
  --bg0:#070A12;
  --bg1:#0A1222;
  --bg2:#0E1A2F;
  --panel:#0B1324;
  --panel2:#0F1C33;
  --stroke: rgba(255,255,255,.10);
  --stroke2: rgba(255,255,255,.14);
  --text: rgba(255,255,255,.92);
  --muted: rgba(255,255,255,.66);
  --muted2: rgba(255,255,255,.48);
  --chip: rgba(255,255,255,.08);
  --inputBg: rgba(255,255,255,.06);
  --tableStripe: rgba(255,255,255,.03);
}

/* ===== THEME: LIGHT ===== */
:root[data-theme="light"]{
  --bg0:#F5F7FB;
  --bg1:#EEF3FF;
  --bg2:#E8F0FF;
  --panel:#FFFFFF;
  --panel2:#F3F6FF;
  --stroke: rgba(15,23,42,.12);
  --stroke2: rgba(15,23,42,.16);
  --text: rgba(15,23,42,.92);
  --muted: rgba(15,23,42,.64);
  --muted2: rgba(15,23,42,.48);
  --chip: rgba(15,23,42,.06);
  --inputBg: rgba(15,23,42,.05);
  --tableStripe: rgba(15,23,42,.03);
}

*{ box-sizing:border-box; }
html,body{ height:100%; }
body{
  font-family: Inter, system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  background:
    radial-gradient(1200px 700px at 20% 0%, rgba(17,205,198,.18), transparent 55%),
    radial-gradient(900px 600px at 90% 10%, rgba(79,70,229,.12), transparent 55%),
    linear-gradient(180deg, var(--bg1), var(--bg0));
  color: var(--text);
}

/* ===== TOPBAR ===== */
.ck-topbar{
  position: sticky;
  top: 0;
  z-index: 50;
  background: linear-gradient(180deg, rgba(0,0,0,.35), rgba(0,0,0,.15));
  backdrop-filter: blur(12px);
  border-bottom: 1px solid var(--stroke);
}
:root[data-theme="light"] .ck-topbar{
  background: rgba(255,255,255,.60);
}

.ck-topbar-inner{
  display:flex;
  align-items:center;
  gap: 12px;
  padding: 10px 14px;
}

.ck-brand{
  display:flex;
  align-items:center;
  gap: 12px;
  text-decoration:none;
  color: var(--text);
}
.ck-brand:hover{ color: var(--text); opacity:.95; }

.ck-logo{
  width: 38px; height: 38px;
  border-radius: 12px;
  display:flex; align-items:center; justify-content:center;
  background: linear-gradient(135deg, rgba(17,205,198,.18), rgba(17,205,198,.06));
  border: 1px solid rgba(17,205,198,.35);
  box-shadow: 0 10px 24px rgba(17,205,198,.14);
}
.ck-logo span{
  font-weight: 900;
  letter-spacing:.5px;
  color: var(--text);
  font-size: 14px;
}

.ck-brand-text{ line-height: 1.1; }
.ck-brand-title{ font-weight: 800; font-size: 14px; }
.ck-brand-sub{ font-size: 12px; color: var(--muted); }

.ck-pill{
  margin-left: 10px;
  font-size: 12px;
  padding: 5px 10px;
  border-radius: 999px;
  border: 1px solid var(--stroke);
  background: var(--chip);
  color: var(--muted);
}

/* top actions */
.ck-top-actions{
  display:flex;
  align-items:center;
  gap: 10px;
}

.ck-iconbtn{
  border: 1px solid var(--stroke);
  background: var(--chip);
  color: var(--text);
  border-radius: 12px;
  padding: 8px 12px;
}

.ck-ghostbtn{
  border: 1px solid var(--stroke);
  background: var(--chip);
  color: var(--text);
  border-radius: 12px;
  padding: 9px 12px;
}
.ck-ghostbtn:hover{
  border-color: var(--stroke2);
  background: rgba(17,205,198,.10);
}

.ck-theme-dot{
  width:10px; height:10px;
  border-radius:999px;
  background: var(--accent);
  display:inline-block;
  box-shadow: 0 0 0 3px rgba(17,205,198,.20);
  margin-right: 8px;
}
.ck-theme-label{ font-weight: 700; font-size: 13px; }

.ck-userbtn{
  border: 1px solid var(--stroke);
  background: var(--chip);
  color: var(--text);
  border-radius: 999px;
  padding: 8px 12px;
  display:flex;
  align-items:center;
  gap: 10px;
}
.ck-userbtn:hover{
  border-color: var(--stroke2);
  background: rgba(17,205,198,.10);
}
.ck-status-dot{
  width: 10px; height: 10px;
  border-radius: 999px;
  background: #22c55e;
  box-shadow: 0 0 0 3px rgba(34,197,94,.18);
}
.ck-rolepill{
  font-size: 12px;
  padding: 4px 8px;
  border-radius: 999px;
  border: 1px solid var(--stroke);
  background: rgba(0,0,0,.12);
  color: var(--muted);
}
:root[data-theme="light"] .ck-rolepill{ background: rgba(15,23,42,.06); }

.ck-dd{
  background: var(--panel);
  border: 1px solid var(--stroke);
  border-radius: 14px;
  overflow:hidden;
  min-width: 220px;
}
.ck-dd .dropdown-item{
  color: var(--text);
  padding: 10px 12px;
}
.ck-dd .dropdown-item:hover{
  background: rgba(17,205,198,.12);
}
.ck-dd .dropdown-divider{ border-color: var(--stroke); }

/* ===== LAYOUT SHELL ===== */
.ck-sidebar{
  position: fixed;
  top: 60px;
  left: 0;
  width: 260px;
  height: calc(100vh - 60px);
  border-right: 1px solid var(--stroke);
  background: linear-gradient(180deg, rgba(0,0,0,.12), rgba(0,0,0,.05));
  backdrop-filter: blur(10px);
}
:root[data-theme="light"] .ck-sidebar{
  background: rgba(255,255,255,.55);
}

.ck-side-inner{
  padding: 16px 14px;
  height: 100%;
  display:flex;
  flex-direction: column;
}

.ck-side-title{
  font-weight: 900;
  letter-spacing:.02em;
  font-size: 12px;
  color: var(--muted);
  margin: 6px 8px 10px;
  text-transform: uppercase;
}

.ck-nav{ display:flex; flex-direction: column; gap: 8px; }

.ck-navitem{
  display:flex;
  align-items:center;
  gap: 10px;
  padding: 10px 12px;
  border-radius: 12px;
  border: 1px solid transparent;
  text-decoration:none;
  color: var(--text);
  background: transparent;
}
.ck-navitem:hover{
  background: rgba(17,205,198,.10);
  border-color: rgba(17,205,198,.22);
}
.ck-navitem.active{
  background: rgba(17,205,198,.16);
  border-color: rgba(17,205,198,.35);
  box-shadow: 0 10px 28px rgba(17,205,198,.14);
}
.ck-navicon{ width: 22px; text-align:center; opacity:.95; }

.ck-side-foot{
  margin-top: auto;
  padding: 12px;
  border-top: 1px solid var(--stroke);
  color: var(--muted);
}
.ck-side-meta-title{ font-weight: 800; font-size: 12px; color: var(--text); }
.ck-side-meta-sub{ font-size: 12px; color: var(--muted); margin-top: 2px; }

/* Main */
.ck-main{
  padding-top: 18px;
  margin-left: 260px;
}
.ck-content{
  padding: 22px 22px 34px;
  max-width: 1200px;
}

/* Public/auth main */
.ck-main-public{ padding: 22px 0 34px; }
.ck-content-public{ padding: 22px; }

/* ===== COMPONENTS ===== */
.ck-card{
  background: var(--panel);
  border: 1px solid var(--stroke);
  border-radius: var(--radius);
  box-shadow: var(--shadow2);
}
.ck-card-soft{
  background: linear-gradient(180deg, var(--panel), rgba(0,0,0,.05));
}

.ck-h1{
  font-size: 34px;
  font-weight: 900;
  letter-spacing: -0.02em;
  margin: 0 0 10px;
}
.ck-sub{
  color: var(--muted);
  margin: 0 0 18px;
  font-size: 14px;
}

.btn-primary{
  background: var(--accent) !important;
  border-color: var(--accent) !important;
  color: #042a2a !important;
  font-weight: 800;
  border-radius: 12px;
}
.btn-primary:hover{
  filter: brightness(.95);
}
.btn-outline-light, .btn-outline-secondary{
  border-radius: 12px;
}

.form-control, .form-select{
  background: var(--inputBg) !important;
  border: 1px solid var(--stroke) !important;
  color: var(--text) !important;
  border-radius: 12px !important;
}
.form-control::placeholder{ color: var(--muted2); }
.form-control:focus, .form-select:focus{
  box-shadow: 0 0 0 4px rgba(17,205,198,.18) !important;
  border-color: rgba(17,205,198,.55) !important;
}

.alert{
  border-radius: 12px;
  border: 1px solid var(--stroke);
}

/* Tables lisibles */
.table{
  color: var(--text);
  margin-bottom: 0;
}
.table thead th{
  color: var(--muted);
  font-weight: 800;
  font-size: 12px;
  text-transform: uppercase;
  letter-spacing: .04em;
  border-bottom: 1px solid var(--stroke);
}
.table td, .table th{
  border-top: 1px solid var(--stroke);
}
.table-striped>tbody>tr:nth-of-type(odd)>*{
  background-color: var(--tableStripe);
  color: var(--text);
}
.table-hover>tbody>tr:hover>*{
  background: rgba(17,205,198,.10);
}

/* Login grid (existant) – rendu plus doux */
.ck-shell{ padding: 34px 0; }
.ck-auth-grid{
  display:grid;
  grid-template-columns: 1.1fr .9fr;
  gap: 22px;
  align-items: stretch;
  max-width: 1080px;
  margin: 0 auto;
}
@media (max-width: 992px){
  .ck-auth-grid{ grid-template-columns: 1fr; }
  .ck-main{ margin-left: 0; }
}

.ck-hero{
  border-radius: var(--radius);
  padding: 28px;
  background:
    radial-gradient(360px 220px at 85% 0%, rgba(17,205,198,.20), transparent 60%),
    linear-gradient(180deg, rgba(0,0,0,.18), rgba(0,0,0,.05));
  border: 1px solid var(--stroke);
  box-shadow: var(--shadow);
}
:root[data-theme="light"] .ck-hero{
  background:
    radial-gradient(360px 220px at 85% 0%, rgba(17,205,198,.22), transparent 60%),
    linear-gradient(180deg, rgba(255,255,255,.90), rgba(255,255,255,.65));
}

.ck-hero h1{
  font-size: 40px;
  line-height: 1.05;
  font-weight: 900;
  letter-spacing: -0.02em;
  margin: 0 0 12px;
}
.ck-hero p{ color: var(--muted); margin: 0 0 16px; }

.ck-features{
  display:grid;
  grid-template-columns: 1fr 1fr;
  gap: 12px;
  margin-top: 14px;
}
@media (max-width: 520px){
  .ck-features{ grid-template-columns: 1fr; }
}
.ck-feature{
  border-radius: 14px;
  padding: 12px 14px;
  border: 1px solid var(--stroke);
  background: rgba(255,255,255,.04);
}
:root[data-theme="light"] .ck-feature{ background: rgba(15,23,42,.03); }
.ck-feature strong{ display:block; font-weight: 900; margin-bottom: 4px; }
.ck-feature span{ color: var(--muted); font-size: 13px; }

.ck-card-body{ padding: 22px; }
.ck-title{ font-weight: 900; font-size: 18px; margin-bottom: 4px; }
.ck-subtitle{ color: var(--muted); margin-bottom: 16px; }

.ck-input-group{
  display:flex;
  gap: 10px;
  align-items:center;
}
.ck-eye{
  border-radius: 12px;
  border: 1px solid var(--stroke);
  background: var(--chip);
  color: var(--text);
  padding: 10px 12px;
  font-weight: 800;
}
.ck-eye:hover{ background: rgba(17,205,198,.10); }

/* Offcanvas */
.ck-offcanvas{
  background: var(--panel);
  color: var(--text);
  border-right: 1px solid var(--stroke);
}

/* ===== Login: proof blocks (ck-proof / ck-trust) ===== */
.ck-proof{
  display: grid;
  grid-template-columns: repeat(3, minmax(0,1fr));
  gap: 12px;
  margin-top: 16px;
}
@media (max-width: 992px){
  .ck-proof{ grid-template-columns: 1fr; }
}

.ck-proof-item{
  border-radius: 14px;
  padding: 12px 14px;
  border: 1px solid var(--stroke);
  background: rgba(255,255,255,.04);
}
:root[data-theme="light"] .ck-proof-item{
  background: rgba(15,23,42,.03);
}

.ck-proof-kpi{
  font-weight: 900;
  margin-bottom: 6px;
  letter-spacing: -0.01em;
}
.ck-proof-text{
  color: var(--muted);
  font-size: 13px;
  line-height: 1.35;
  margin: 0;
}

.ck-trust{
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  align-items: center;
  margin-top: 16px;
  color: var(--muted);
  font-size: 12px;
}
.ck-trust .dot{
  width: 9px;
  height: 9px;
  border-radius: 999px;
  background: var(--accent);
  box-shadow: 0 0 0 3px rgba(17,205,198,.18);
  display: inline-block;
}
.ck-trust .sep{
  opacity: .65;
}

/* petits détails de liens */
a{ color: var(--accent); text-decoration: none; }
a:hover{ text-decoration: underline; }
.ck-footer-note{ color: var(--muted); font-size: 12px; }


/* ===== Layout auth: mêmes hauteurs + responsive clean ===== */
.ck-auth-grid{
  display:grid;
  gap:24px;
  grid-template-areas:"hero card";
  grid-template-columns:minmax(0, 1.15fr) minmax(0, .95fr);
  align-items:stretch;
}

.ck-hero{ grid-area:hero; height:100%; display:flex; flex-direction:column; }
.ck-card{ grid-area:card; height:100%; }
.ck-card-body{ height:100%; display:flex; flex-direction:column; }

.ck-lead{ margin: 10px 0 0; opacity:.9; }
.ck-proof{
  margin-top:16px;
  display:grid;
  grid-template-columns:repeat(3, minmax(0, 1fr));
  gap:12px;
}
.ck-proof-item{
  border-radius:14px;
  padding:12px 12px;
}
.ck-proof-kpi{ font-weight:800; }
.ck-proof-text{ margin-top:4px; font-size:13px; opacity:.9; }

.ck-auth-form{ display:flex; flex-direction:column; flex:1 1 auto; }
.ck-card-footer{
  margin-top:auto;
  padding-top:14px;
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:12px;
}

/* breakpoints */
@media (max-width: 992px){
  .ck-auth-grid{
    grid-template-areas:
      "card"
      "hero";
    grid-template-columns:1fr;
  }
  .ck-proof{ grid-template-columns:1fr; }
}
@media (max-width: 1200px){
  .ck-proof{ grid-template-columns:repeat(2, minmax(0, 1fr)); }
}

.ck-empty{
  border:1px dashed rgba(0,0,0,.18);
  background: rgba(255,255,255,.55);
  border-radius: 16px;
  padding: 16px;
}
html[data-theme="dark"] .ck-empty{
  border-color: rgba(255,255,255,.18);
  background: rgba(255,255,255,.04);
}

.ck-table thead th{
  font-size: .72rem;
  text-transform: uppercase;
  letter-spacing: .08em;
  color: rgba(0,0,0,.55);
  background: rgba(0,0,0,.04);
  border-bottom: 1px solid rgba(0,0,0,.12);
}
html[data-theme="dark"] .ck-table thead th{
  color: rgba(255,255,255,.65);
  background: rgba(255,255,255,.05);
  border-bottom-color: rgba(255,255,255,.14);
}
.ck-table td, .ck-table th{
  padding: .75rem .75rem;
  border-bottom: 1px solid rgba(0,0,0,.08);
}
html[data-theme="dark"] .ck-table td,
html[data-theme="dark"] .ck-table th{
  border-bottom-color: rgba(255,255,255,.10);
}

.ck-table tbody tr:hover{
  background: rgba(17,205,198,.06);
}
