/* ============================================================
   Jolumi v3.03 UI
   JPayten-inspired editorial SaaS UI.
============================================================ */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  --bg:#07060f;
  --bg-deep:#05040b;
  --client-bg:#e2d7fc;
  --b:rgba(139,92,246,.22);
  --bhi:rgba(139,92,246,.56);
  --p:#8b5cf6;
  --plo:#6d28d9;
  --phi:#a78bfa;
  --v:#7c3aed;
  --pk:#c084fc;
  --t:#f5f3ff;
  --cream:#fffdd0;
  --m:rgba(245,243,255,.62);
  --d:rgba(245,243,255,.36);
  --panel:rgba(12,8,22,.88);
  --panel2:rgba(25,14,44,.72);
  --success:#77f0b0;
  --warning:#ffdf72;
  --danger:#ff7b93;
  --serif:'DM Serif Display',Georgia,serif;
  --sans:'Outfit',system-ui,-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;
  --shadow:0 28px 90px rgba(0,0,0,.34);
  --sidebar:230px;
}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
html[data-theme="light"]{
  --bg:#07060f;
  --bg-deep:#05040b;
  --t:#f5f3ff;
  --m:rgba(245,243,255,.62);
  --d:rgba(245,243,255,.36);
  --panel:rgba(12,8,22,.88);
  --panel2:rgba(25,14,44,.72);
}
body{
  background:var(--bg);
  color:var(--t);
  font-family:var(--sans);
  font-size:16px;
  line-height:1.65;
  overflow-x:hidden;
  min-height:100vh;
}
body::before{
  content:'';
  position:fixed;
  inset:0;
  z-index:-3;
  pointer-events:none;
  background:
    radial-gradient(circle at 9% 16%, rgba(124,58,237,.30), transparent 34%),
    radial-gradient(circle at 83% 0%, rgba(76,29,149,.22), transparent 30%),
    radial-gradient(circle at 28% 90%, rgba(124,58,237,.14), transparent 38%),
    linear-gradient(135deg,#07060f 0%,#0b0714 52%,#05040b 100%);
}
body::after{
  content:'';
  position:fixed;
  inset:0;
  z-index:-2;
  pointer-events:none;
  background-image:
    linear-gradient(rgba(139,92,246,.045) 1px,transparent 1px),
    linear-gradient(90deg,rgba(139,92,246,.045) 1px,transparent 1px);
  background-size:64px 64px,64px 64px;
  opacity:.38;
}
a{color:inherit;text-decoration:none}
button,input,select,textarea{font-family:var(--sans)}
.app-shell{display:grid;grid-template-columns:var(--sidebar) 1fr;min-height:100vh}
.sidebar{
  position:sticky;
  top:0;
  height:100vh;
  padding:32px 22px 24px;
  border-right:1px solid var(--b);
  background:rgba(5,4,11,.86);
  backdrop-filter:blur(20px);
  display:flex;
  flex-direction:column;
}
.brand-lockup{
  display:flex;
  flex-direction:column;
  align-items:center;
  width:100%;
  margin-bottom:34px;
  text-align:center;
}
.brand-logo{
  display:block;
  width:122px;
  height:auto;
  max-height:66px;
  object-fit:contain;
  object-position:center;
}
.brand-helper{
  color:var(--m);
  font-size:.82rem;
  margin-top:12px;
  font-weight:400;
  letter-spacing:.01em;
}
.brand-initial,.brand-name{display:none}
.nav{display:grid;gap:3px;margin-top:10px}
.nav a{
  position:relative;
  display:flex;
  align-items:center;
  gap:11px;
  min-height:42px;
  padding:9px 11px;
  color:var(--m);
  font-size:.9rem;
  font-weight:500;
  border:1px solid transparent;
  transition:all .18s ease;
}
.nav a::after{
  content:attr(data-icon);
  order:-1;
  display:inline-grid;
  place-items:center;
  width:18px;
  color:var(--phi);
  font-size:.88rem;
  opacity:.9;
}
.nav a:hover{color:var(--t);background:rgba(139,92,246,.07);border-color:var(--b)}
.nav a::before{content:'';width:0;height:1px;background:var(--phi);position:absolute;left:40px;bottom:7px;transition:width .18s ease}
.nav a:hover::before{width:22px}
.sidebar-version{
  margin-top:auto;
  color:var(--cream);
  opacity:.78;
  font-size:.72rem;
  letter-spacing:.06em;
  text-align:center;
}
.main{
  padding:42px 48px 68px;
  max-width:1480px;
  width:100%;
}
.topbar{
  display:flex;
  justify-content:space-between;
  align-items:flex-start;
  gap:24px;
  margin-bottom:38px;
  border-bottom:1px solid rgba(139,92,246,.10);
  padding-bottom:26px;
}
.eyebrow{
  display:flex;
  align-items:center;
  gap:10px;
  color:var(--phi);
  text-transform:uppercase;
  letter-spacing:.20em;
  font-size:.68rem;
  font-weight:700;
  margin-bottom:16px;
}
.eyebrow::before{content:'';width:24px;height:1px;background:var(--phi);opacity:.7}
h1{
  margin:0;
  font-family:var(--serif);
  font-weight:400;
  font-size:clamp(2.55rem,5.1vw,5.85rem);
  line-height:.9;
  letter-spacing:-.025em;
  color:var(--t);
}
h1 em{font-style:italic;color:var(--phi)}
h2{
  margin:0 0 9px;
  font-family:var(--serif);
  font-weight:400;
  font-size:clamp(2rem,3.8vw,4.2rem);
  line-height:.98;
  letter-spacing:-.02em;
  color:var(--t);
}
h2 em,h3 em{font-style:italic;color:var(--phi)}
h3{margin:0 0 9px;font-size:1rem;font-weight:650;color:var(--t)}
p{color:var(--m);line-height:1.75;font-weight:300}
.topbar p{margin:14px 0 0;max-width:760px;font-size:.94rem}
.helper{color:var(--m);margin:0 0 24px;max-width:760px}
.topbar-actions{display:flex;gap:10px;align-items:center;flex-wrap:wrap;justify-content:flex-end;min-width:240px}
.user-pill,.badge{display:inline-flex;align-items:center;border:1px solid var(--b);padding:10px 12px;color:var(--m);background:rgba(12,8,22,.55);font-size:.78rem;min-height:42px}
.button,button{
  border:1px solid rgba(167,139,250,.52);
  border-radius:0;
  padding:13px 24px;
  background:linear-gradient(135deg,var(--p),var(--plo));
  color:#fff;
  font-weight:700;
  cursor:pointer;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:8px;
  min-height:46px;
  letter-spacing:.01em;
  box-shadow:0 0 28px rgba(139,92,246,.22);
  transition:all .2s ease;
}
.button:hover,button:hover{background:linear-gradient(135deg,var(--phi),var(--v));transform:translateY(-1px);box-shadow:0 0 48px rgba(167,139,250,.34)}
.button.secondary,.ghost{background:linear-gradient(135deg,var(--p),var(--plo));color:#fff;border:1px solid rgba(167,139,250,.52);box-shadow:0 0 28px rgba(139,92,246,.22)}
.button.secondary:hover,.ghost:hover{background:linear-gradient(135deg,var(--phi),var(--v))}
.button.small{padding:9px 12px;min-height:34px;font-size:.78rem}
.compact-button{width:auto;justify-self:start;align-self:start}
.icon-button{width:48px;min-width:48px;height:48px;padding:0;font-size:1.35rem;line-height:1}
.grid{display:grid;gap:22px}
.grid.cards{grid-template-columns:repeat(4,minmax(0,1fr))}
.grid.two{grid-template-columns:repeat(2,minmax(0,1fr))}
.grid.client-layout{grid-template-columns:minmax(0,1fr)}
.card,.jp-panel{
  position:relative;
  background:linear-gradient(135deg,rgba(23,13,39,.82),rgba(7,6,15,.92));
  border:1px solid var(--b);
  border-radius:0;
  padding:32px;
  box-shadow:var(--shadow);
  backdrop-filter:blur(16px);
  overflow:visible;
}
.card::before,.jp-panel::before{content:'';position:absolute;left:0;top:0;right:0;height:1px;background:linear-gradient(90deg,var(--v),var(--pk),transparent);opacity:.9}
.card.equal{min-height:176px;display:flex;flex-direction:column;justify-content:space-between}
.metric{font-family:var(--serif);font-style:italic;color:var(--phi);font-size:3.2rem;letter-spacing:-.04em;margin-top:18px;line-height:1}
.section-head{display:flex;align-items:flex-start;justify-content:space-between;gap:18px;margin-bottom:22px}
.section-head .eyebrow{margin-bottom:12px}
.panel-title-row{display:flex;align-items:flex-start;justify-content:space-between;gap:20px;margin-bottom:28px}
.table-wrap{overflow-x:auto;border:1px solid var(--b);background:rgba(7,6,15,.42)}
table{width:100%;border-collapse:collapse}
th,td{text-align:left;padding:17px 20px;border-bottom:1px solid var(--b);vertical-align:middle;font-size:15px;font-weight:400}
th{color:var(--phi);font-size:.68rem;font-weight:700;text-transform:uppercase;letter-spacing:.16em}
tr:last-child td{border-bottom:0}
tr:hover td{background:rgba(139,92,246,.055)}
td strong{font-size:15px;font-weight:700}
.align-centre{text-align:center}
.status{display:inline-flex;padding:7px 10px;font-size:.7rem;font-weight:800;background:rgba(139,92,246,.10);border:1px solid var(--b);color:var(--t);text-transform:uppercase;letter-spacing:.06em}
.status.approved,.status.active{color:var(--success)}
.status.review,.status.needs-review{color:var(--warning)}
.status.archived,.status.paused{color:var(--m)}
form{display:grid;gap:22px}
label,.field-label{
  display:grid;
  gap:8px;
  color:rgba(245,243,255,.70);
  font-weight:500;
  font-size:14px;
  text-transform:none;
  letter-spacing:0;
}
input,select,textarea{
  width:100%;
  border:1px solid rgba(139,92,246,.42);
  background:rgba(24,14,42,.48);
  color:var(--t);
  padding:14px 16px;
  border-radius:0;
  outline:none;
  min-height:48px;
  box-shadow:inset 0 0 0 1px rgba(255,255,255,.01);
  font-size:15px;
  font-weight:400;
}
input::placeholder,textarea::placeholder{color:rgba(245,243,255,.30);font-size:15px;font-weight:400}
input:focus,select:focus,textarea:focus{border-color:var(--phi);box-shadow:0 0 0 3px rgba(139,92,246,.12),0 0 34px rgba(139,92,246,.08)}
textarea{min-height:126px;resize:vertical}
.final-notes textarea{min-height:154px}
select{appearance:auto}
.form-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:20px}
.form-grid.three{grid-template-columns:repeat(3,minmax(0,1fr))}
.field-row-spaced{margin-top:28px}
.people-section{margin-top:42px}
.form-actions{display:flex;gap:14px;flex-wrap:wrap;align-items:center;margin-top:10px}
.notice{padding:14px 16px;margin-bottom:20px;border:1px solid var(--b);background:rgba(12,8,22,.76);color:var(--m)}
.notice.success{color:var(--success)}
.notice.warning{color:var(--warning)}
.login-page{min-height:100vh;display:grid;place-items:center;padding:22px}
.login-card{width:min(560px,100%);padding:42px}
.login-logo{width:180px;height:auto;margin-bottom:24px}
.brand-mark{display:none}
.client-add-panel{display:none!important;margin-bottom:24px}
.client-add-panel.is-open{display:block!important}
.brand-block,.person-block,.social-row,.approval-step{border:1px solid var(--b);background:rgba(7,6,15,.34);padding:20px;margin-top:16px}
.brand-block-title{display:flex;align-items:center;justify-content:space-between;gap:14px;margin-bottom:16px}
.mini-title{color:var(--phi);font-weight:700;letter-spacing:.07em;text-transform:none;font-size:14px}
.inline-actions{display:flex;gap:10px;flex-wrap:wrap;align-items:center;margin-bottom:12px}
.social-row{display:grid;grid-template-columns:38px 1fr auto;align-items:center;gap:10px}
.social-row input{font-size:15px;font-weight:400}
.social-icon{display:inline-grid;place-items:center;width:34px;height:34px;border:1px solid var(--b);color:var(--phi);font-weight:900}
.tag-list{display:flex;flex-wrap:wrap;gap:8px}
.tag{border:1px solid var(--b);color:var(--m);padding:7px 10px;font-size:.72rem;font-weight:700;background:rgba(139,92,246,.055)}
.muted{color:var(--m)}
strong{color:var(--t)}
.jp-muted-box{border:1px solid var(--b);background:rgba(7,6,15,.34);padding:18px}
.file-note{font-size:.74rem;color:var(--d);font-weight:400;text-transform:none;letter-spacing:0}

/* Custom file upload */
.file-upload{
  position:relative;
  display:flex;
  align-items:center;
  gap:14px;
  min-height:88px;
  border:1px solid rgba(139,92,246,.42);
  background:rgba(24,14,42,.48);
  padding:18px;
  cursor:pointer;
}
.file-upload input{position:absolute;inset:0;opacity:0;cursor:pointer}
.upload-icon{
  width:42px;
  height:42px;
  display:inline-grid;
  place-items:center;
  border:1px solid var(--bhi);
  background:linear-gradient(135deg,var(--p),var(--plo));
  color:#fff;
  font-size:1.2rem;
  line-height:1;
}
.upload-copy{display:grid;gap:2px}
.upload-copy strong{font-size:15px;font-weight:600;color:var(--t)}
.upload-copy small{font-size:13px;font-weight:400;color:var(--m)}

/* Dialling code dropdown */
.dial-select{position:relative}
.dial-current{
  width:100%;
  min-height:48px;
  display:flex;
  align-items:center;
  justify-content:flex-start;
  gap:10px;
  padding:14px 16px;
  background:rgba(24,14,42,.48);
  border:1px solid rgba(139,92,246,.42);
  box-shadow:none;
  color:var(--t);
  font-size:14px;
  font-weight:400;
}
.dial-current img,.dial-option img{width:20px;height:auto;display:block}
.dial-current span{font-size:14px;font-weight:400}
.dial-menu{
  display:none;
  position:absolute;
  top:calc(100% + 6px);
  left:0;
  right:0;
  z-index:50;
  background:#191126;
  border:1px solid var(--bhi);
  box-shadow:0 22px 60px rgba(0,0,0,.44);
  padding:10px;
}
.dial-select.is-open .dial-menu{display:block}
.dial-search{
  min-height:40px;
  padding:10px 12px;
  font-size:14px;
  font-weight:400;
  margin-bottom:8px;
}
.dial-options{max-height:230px;overflow:auto;display:grid;gap:3px}
.dial-option{
  width:100%;
  display:grid;
  grid-template-columns:24px 1fr auto;
  align-items:center;
  gap:8px;
  background:transparent;
  border:0;
  box-shadow:none;
  min-height:34px;
  padding:7px 8px;
  color:var(--t);
  font-size:14px;
  font-weight:400;
  text-align:left;
}
.dial-option:hover{background:rgba(139,92,246,.28);transform:none;box-shadow:none}
.dial-option span,.dial-option strong{font-size:14px;font-weight:400}
.dial-option strong{color:var(--m)}

/* Clients page */
.page-clients .main{
  background:var(--client-bg);
  max-width:none;
  min-height:100vh;
}
.page-clients .topbar{
  border-bottom:0;
  padding-bottom:0;
  margin-bottom:20px;
}
.page-clients h1{
  font-size:clamp(2.15rem,3.8vw,4.4rem);
  color:#6d28d9;
}
.page-clients h1 em{color:#6d28d9}
.page-clients .topbar p{
  color:#24113f;
  font-size:.92rem;
  max-width:640px;
  margin-top:10px;
  font-weight:400;
}
.page-clients .client-layout{gap:22px}
.page-clients .jp-panel{
  background:linear-gradient(135deg,rgba(23,13,39,.98),rgba(7,6,15,.98));
}
.page-clients .client-list-panel h2{font-size:clamp(1.9rem,3.1vw,3.4rem)}

@media (max-width:1200px){
  .grid.cards{grid-template-columns:repeat(2,minmax(0,1fr))}
  .form-grid.three{grid-template-columns:1fr 1fr}
}
@media (max-width:980px){
  .app-shell{grid-template-columns:1fr}
  .sidebar{position:static;height:auto}
  .nav{grid-template-columns:repeat(2,1fr)}
  .grid.cards,.grid.two,.form-grid,.form-grid.three{grid-template-columns:1fr}
  .topbar{flex-direction:column}
  .topbar-actions{justify-content:flex-start}
  .main{padding:30px 24px 54px}
  .brand-logo{width:118px}
}
@media (max-width:560px){
  .main{padding:22px}
  .sidebar{padding:22px}
  .nav{grid-template-columns:1fr}
  .section-head,.panel-title-row{flex-direction:column}
  .social-row{grid-template-columns:38px 1fr}
  .social-row button{grid-column:2}
  .topbar{margin-bottom:26px}
  h1{font-size:3.4rem}
}

/* ============================================================
   Jolumi v3.03.02 Clients list alignment patch
   Scope: Clients list spacing, add button placement, table headings and centring only.
============================================================ */
.page-clients .topbar{
  margin-bottom:10px;
}
.page-clients .client-list-panel{
  position:relative;
  padding-top:38px;
}
.page-clients .client-list-panel .panel-title-row{
  display:block;
  margin-bottom:22px;
  padding-right:76px;
}
.page-clients .client-list-panel .icon-button{
  position:absolute;
  top:44px;
  right:48px;
  width:48px;
  min-width:48px;
  height:48px;
  padding:0;
}
.page-clients .client-table th{
  text-transform:none;
}
.page-clients .client-table th.align-centre,
.page-clients .client-table td.align-centre{
  text-align:center;
}
.page-clients .client-table td.align-centre .status{
  margin-left:auto;
  margin-right:auto;
}
@media (max-width:560px){
  .page-clients .client-list-panel .panel-title-row{
    display:block;
    padding-right:66px;
  }
  .page-clients .client-list-panel .icon-button{
    top:34px;
    right:32px;
  }
}

/* ============================================================
   Jolumi v3.03.02 Plus button fix
   Scope: make the Add Client + a real purple CTA button in the Client List panel.
============================================================ */
.page-clients .client-list-panel{
  position:relative;
}
.page-clients .client-list-panel .panel-title-row{
  position:static;
}
.page-clients .client-list-panel .add-client-button,
.page-clients .client-list-panel .icon-button,
.page-clients .client-list-panel .add-client-link{
  position:absolute!important;
  top:44px!important;
  right:48px!important;
  width:52px!important;
  min-width:52px!important;
  height:52px!important;
  min-height:52px!important;
  padding:0!important;
  display:grid!important;
  place-items:center!important;
  background:#7c3aed!important;
  color:#fffdd0!important;
  border:1px solid rgba(167,139,250,.58)!important;
  border-radius:0!important;
  text-decoration:none!important;
  font-family:var(--sans)!important;
  font-size:26px!important;
  font-weight:800!important;
  line-height:1!important;
  letter-spacing:0!important;
  box-shadow:0 18px 46px rgba(124,58,237,.32)!important;
  transform:none!important;
  cursor:pointer!important;
  z-index:4!important;
}
.page-clients .client-list-panel .add-client-button:hover,
.page-clients .client-list-panel .icon-button:hover,
.page-clients .client-list-panel .add-client-link:hover{
  background:#8b5cf6!important;
  transform:translateY(-1px)!important;
}
@media (max-width:560px){
  .page-clients .client-list-panel .add-client-button,
  .page-clients .client-list-panel .icon-button,
  .page-clients .client-list-panel .add-client-link{
    top:34px!important;
    right:32px!important;
  }
}

/* ============================================================
   Jolumi v3.03.04 Plus button inline alignment fix
   Scope: Client List + button only. Makes the CTA part of the heading row instead of absolute-positioned.
============================================================ */
.page-clients .client-list-panel .panel-title-row{
  display:flex!important;
  align-items:center!important;
  justify-content:space-between!important;
  gap:24px!important;
  margin-bottom:22px!important;
  padding-right:0!important;
}
.page-clients .client-list-panel .add-client-button,
.page-clients .client-list-panel .icon-button,
.page-clients .client-list-panel .add-client-link{
  position:static!important;
  flex:0 0 42px!important;
  width:42px!important;
  min-width:42px!important;
  max-width:42px!important;
  height:42px!important;
  min-height:42px!important;
  max-height:42px!important;
  padding:0!important;
  display:grid!important;
  place-items:center!important;
  background:#7c3aed!important;
  color:#fffdd0!important;
  border:1px solid rgba(167,139,250,.58)!important;
  border-radius:0!important;
  text-decoration:none!important;
  font-family:var(--sans)!important;
  font-size:24px!important;
  font-weight:700!important;
  line-height:1!important;
  letter-spacing:0!important;
  box-shadow:0 14px 34px rgba(124,58,237,.28)!important;
  transform:none!important;
  cursor:pointer!important;
  z-index:4!important;
}
@media (max-width:560px){
  .page-clients .client-list-panel .panel-title-row{
    display:flex!important;
    flex-direction:row!important;
    align-items:center!important;
  }
}
