:root{
  --ink:#1f1933;
  --muted:#716a80;
  --line:#e8e4ef;
  --paper:#fff;
  --soft:#f7f5fb;
  --purple:#654edb;
  --purple-dark:#352576;
  --navy:#15102e;
  --green:#17885c;
  --amber:#b56e12;
  --red:#b23b55;
  --shadow:0 24px 70px rgba(25,17,58,.12);
  font-family:Inter,Segoe UI,Arial,sans-serif
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;color:var(--ink);background:#f4f2f8}
button,input,textarea,select{font:inherit}
button,a{transition:.2s ease}
button{cursor:pointer}
[hidden]{display:none!important}
.portal-login{
  min-height:100vh;display:grid;grid-template-columns:minmax(300px,1.05fr) minmax(360px,.95fr);
  background:#fff
}
.portal-story{
  position:relative;overflow:hidden;padding:48px;color:#fff;
  background:
    radial-gradient(circle at 78% 16%,rgba(130,103,255,.7),transparent 30%),
    linear-gradient(145deg,#130d31,#251766 62%,#4632a6)
}
.portal-brand{display:inline-flex;align-items:center;gap:11px;color:#fff;text-decoration:none}
.portal-brand>span,.portal-logo{
  width:44px;height:44px;display:grid;place-items:center;border-radius:12px;
  background:#745ee5;color:#fff;font-weight:900
}
.portal-brand div{display:grid}.portal-brand small{opacity:.72}
.portal-story-copy{max-width:570px;margin:17vh auto 0}
.portal-story-copy>span{font-size:12px;letter-spacing:.15em;font-weight:800;color:#cfc5ff}
.portal-story-copy h1{font-size:clamp(42px,6vw,76px);line-height:.98;margin:16px 0}
.portal-story-copy p{font-size:17px;line-height:1.7;color:#d9d3ef}
.portal-proof{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin-top:28px}
.portal-proof article{padding:15px;border:1px solid rgba(255,255,255,.16);border-radius:12px;background:rgba(255,255,255,.06)}
.portal-proof b,.portal-proof span{display:block}.portal-proof span{margin-top:5px;font-size:12px;color:#cfc8e5}
.portal-orbit{position:absolute;right:-80px;bottom:-110px;width:360px;height:360px;border:1px solid rgba(255,255,255,.16);border-radius:50%;animation:spin 22s linear infinite}
.portal-orbit:before,.portal-orbit:after{content:"";position:absolute;border:1px solid rgba(255,255,255,.13);border-radius:50%}
.portal-orbit:before{inset:55px}.portal-orbit:after{inset:115px}
.portal-orbit i{position:absolute;left:48%;top:-7px;width:14px;height:14px;border-radius:50%;background:#fff;box-shadow:0 0 28px #fff}
.portal-auth-wrap{display:grid;place-items:center;padding:34px}
.portal-auth-card{width:min(470px,100%);padding:32px;border:1px solid var(--line);border-radius:18px;box-shadow:var(--shadow);background:#fff}
.portal-auth-card h2{font-size:32px;margin:8px 0}
.portal-auth-card>p{color:var(--muted);line-height:1.6}
.eyebrow{font-size:11px;letter-spacing:.14em;font-weight:900;color:var(--purple)}
.portal-tabs{display:grid;grid-template-columns:1fr 1fr;padding:4px;margin:22px 0;background:var(--soft);border-radius:10px}
.portal-tabs button{border:0;border-radius:8px;padding:10px;background:transparent;color:var(--muted);font-weight:800}
.portal-tabs button.active{background:#fff;color:var(--ink);box-shadow:0 5px 14px rgba(40,30,80,.08)}
.portal-form{display:grid;gap:14px}
.portal-form label{display:grid;gap:7px;font-size:12px;font-weight:800;color:#5e566c}
.portal-form input,.portal-form textarea,.portal-form select{
  width:100%;padding:12px 13px;border:1px solid #dcd7e8;border-radius:9px;background:#fff;outline:none
}
.portal-form textarea{min-height:112px;resize:vertical}
.portal-form input:focus,.portal-form textarea:focus,.portal-form select:focus{border-color:#765fe5;box-shadow:0 0 0 3px rgba(118,95,229,.12)}
.primary-btn,.secondary-btn,.google-btn,.danger-btn{
  border:0;border-radius:9px;padding:12px 15px;font-weight:850
}
.primary-btn{background:var(--purple);color:#fff}
.primary-btn:hover{background:#5740cf}
.secondary-btn{background:#fff;border:1px solid var(--line);color:var(--ink)}
.google-btn{width:100%;margin-top:10px;background:#fff;border:1px solid var(--line);color:var(--ink)}
.danger-btn{background:#fff0f3;color:var(--red)}
.auth-message{min-height:22px;margin-top:12px;font-size:13px;line-height:1.5;color:var(--muted)}
.auth-message[data-kind="error"]{color:var(--red)}
.auth-message[data-kind="success"]{color:var(--green)}
.invite-box{padding:15px;margin:16px 0;border:1px solid #d9d0ff;border-radius:11px;background:#f4f1ff}
.invite-box b,.invite-box span{display:block}.invite-box span{margin-top:4px;color:#695f7e;font-size:13px}
.portal-app{min-height:100vh;display:grid;grid-template-columns:250px minmax(0,1fr)}
.portal-sidebar{position:sticky;top:0;height:100vh;padding:22px 16px;background:var(--navy);color:#fff}
.portal-side-brand{display:flex;align-items:center;gap:10px;padding:0 8px 24px}
.portal-side-brand div{display:grid}.portal-side-brand small{color:#a9a1c1}
.portal-nav{display:grid;gap:5px}
.portal-nav button{
  display:flex;align-items:center;gap:11px;width:100%;padding:11px 12px;border:0;border-radius:9px;background:transparent;color:#bcb5d0;text-align:left;font-weight:750
}
.portal-nav button:hover,.portal-nav button.active{background:#2b2250;color:#fff}
.portal-nav button span{width:23px;text-align:center}
.portal-side-footer{position:absolute;left:16px;right:16px;bottom:18px}
.portal-side-footer button{width:100%;border:1px solid rgba(255,255,255,.12);background:transparent;color:#d6d0e5;padding:10px;border-radius:8px}
.portal-main{min-width:0}
.portal-topbar{
  position:sticky;top:0;z-index:5;display:flex;align-items:center;justify-content:space-between;
  padding:15px 24px;border-bottom:1px solid var(--line);background:rgba(255,255,255,.94);backdrop-filter:blur(14px)
}
.portal-topbar h1{margin:0;font-size:18px}
.portal-user{display:flex;align-items:center;gap:10px}
.portal-avatar{width:38px;height:38px;display:grid;place-items:center;border-radius:50%;background:#ece8ff;color:#5841c9;font-weight:900}
.portal-user div{display:grid}.portal-user small{color:var(--muted)}
.portal-content{padding:24px;max-width:1500px;margin:auto}
.portal-panel{display:none}.portal-panel.active{display:block}
.portal-hero{
  display:flex;justify-content:space-between;gap:20px;padding:28px;border-radius:18px;color:#fff;
  background:
    radial-gradient(circle at 80% 20%,rgba(153,129,255,.8),transparent 30%),
    linear-gradient(135deg,#221657,#4b37aa)
}
.portal-hero h2{font-size:clamp(28px,4vw,48px);margin:8px 0}.portal-hero p{max-width:650px;color:#ddd7ef;line-height:1.6}
.portal-progress{min-width:250px;align-self:center}
.portal-progress small{display:flex;justify-content:space-between;margin-bottom:8px}
.portal-progress div{height:10px;border-radius:20px;background:rgba(255,255,255,.18);overflow:hidden}
.portal-progress i{display:block;height:100%;width:0;background:#fff;border-radius:inherit;transition:.5s}
.metric-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin:18px 0}
.metric-card,.content-card{
  border:1px solid var(--line);border-radius:14px;background:#fff;box-shadow:0 12px 35px rgba(29,20,65,.05)
}
.metric-card{padding:18px}.metric-card small{color:var(--muted)}.metric-card b{display:block;margin-top:10px;font-size:28px}
.content-grid{display:grid;grid-template-columns:1.3fr .7fr;gap:18px}
.content-card{padding:20px}.content-card h3{margin:0 0 14px}
.section-head{display:flex;align-items:center;justify-content:space-between;gap:14px;margin-bottom:18px}
.section-head h2{margin:0;font-size:28px}.section-head p{margin:6px 0 0;color:var(--muted)}
.item-list{display:grid;gap:11px}
.item{
  display:grid;grid-template-columns:minmax(0,1fr) auto;gap:16px;align-items:center;
  padding:15px;border:1px solid var(--line);border-radius:11px;background:#fff
}
.item h4{margin:0}.item p{margin:6px 0 0;color:var(--muted);font-size:13px;line-height:1.45}
.item-actions{display:flex;align-items:center;gap:8px;flex-wrap:wrap;justify-content:flex-end}
.badge{display:inline-flex;padding:5px 8px;border-radius:20px;background:#eeeafc;color:#5e46c8;font-size:11px;font-weight:900;text-transform:capitalize}
.badge.signed,.badge.approved,.badge.paid,.badge.complete{background:#e5f6ee;color:var(--green)}
.badge.sent,.badge.in-progress,.badge.open{background:#fff3df;color:var(--amber)}
.badge.declined,.badge.overdue{background:#ffe8ed;color:var(--red)}
.empty{padding:30px;border:1px dashed #d9d4e4;border-radius:12px;text-align:center;color:var(--muted);background:#faf9fc}
.timeline{display:grid;gap:0}
.timeline article{position:relative;padding:0 0 20px 26px}
.timeline article:before{content:"";position:absolute;left:5px;top:5px;width:10px;height:10px;border-radius:50%;background:var(--purple)}
.timeline article:after{content:"";position:absolute;left:9px;top:18px;bottom:0;width:2px;background:#e4dff0}
.timeline article:last-child:after{display:none}
.timeline b,.timeline small{display:block}.timeline small{margin-top:5px;color:var(--muted)}
.table-wrap{overflow:auto;border:1px solid var(--line);border-radius:12px;background:#fff}
table{width:100%;border-collapse:collapse;min-width:680px}
th,td{padding:13px 14px;border-bottom:1px solid var(--line);text-align:left;font-size:13px}
th{background:#faf9fc;color:#71697e;font-size:11px;text-transform:uppercase;letter-spacing:.06em}
.modal{position:fixed;inset:0;z-index:20;display:grid;place-items:center;padding:20px;background:rgba(16,10,36,.72)}
.modal-card{width:min(720px,100%);max-height:90vh;overflow:auto;padding:24px;border-radius:16px;background:#fff;box-shadow:var(--shadow)}
.modal-card h2{margin:0}.agreement-text{white-space:pre-wrap;margin:18px 0;padding:18px;border:1px solid var(--line);border-radius:10px;background:#faf9fc;line-height:1.7}
.consent{display:flex!important;grid-template-columns:auto 1fr!important;align-items:flex-start;gap:10px!important;font-weight:600!important}
.consent input{width:auto!important;margin-top:3px}
.modal-actions{display:flex;justify-content:flex-end;gap:10px;margin-top:16px}
.toast{position:fixed;right:20px;bottom:20px;z-index:30;max-width:390px;padding:13px 16px;border-radius:9px;background:#21183f;color:#fff;box-shadow:var(--shadow);opacity:0;transform:translateY(15px);pointer-events:none}
.toast.show{opacity:1;transform:none}
.gate{position:fixed;inset:0;z-index:50;display:grid;place-items:center;padding:20px;background:#f4f2f8}
.gate div{max-width:500px;padding:24px;border-radius:14px;background:#fff;box-shadow:var(--shadow);text-align:center}
.gate.error div{border:1px solid #efbdc8;color:var(--red)}
.admin-shell{min-height:100vh;padding:30px;background:linear-gradient(145deg,#171031,#2e2171)}
.admin-card{width:min(940px,100%);margin:auto;padding:28px;border-radius:18px;background:#fff;box-shadow:var(--shadow)}
.admin-head{display:flex;justify-content:space-between;gap:20px;align-items:center;margin-bottom:22px}
.admin-head h1{margin:5px 0}.admin-head p{margin:0;color:var(--muted)}
.admin-form{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.admin-form .full{grid-column:1/-1}
.invite-result{margin-top:20px;padding:18px;border:1px solid #cfc3ff;border-radius:12px;background:#f5f2ff}
.invite-link{display:flex;gap:8px;margin-top:10px}.invite-link input{flex:1}
.admin-note{margin-top:16px;padding:14px;border-radius:10px;background:#fff7e8;color:#7a5315;font-size:13px;line-height:1.55}
@keyframes spin{to{transform:rotate(360deg)}}
@media(max-width:980px){
  .portal-login{grid-template-columns:1fr}.portal-story{display:none}
  .portal-app{grid-template-columns:84px minmax(0,1fr)}
  .portal-side-brand div,.portal-nav button b{display:none}
  .portal-nav button{justify-content:center}.portal-side-footer{left:10px;right:10px}
  .metric-grid{grid-template-columns:1fr 1fr}.content-grid{grid-template-columns:1fr}
}
@media(max-width:650px){
  .portal-app{display:block}.portal-sidebar{position:fixed;left:0;right:0;top:auto;bottom:0;z-index:10;width:auto;height:auto;padding:8px}
  .portal-side-brand,.portal-side-footer{display:none}.portal-nav{grid-template-columns:repeat(6,1fr);overflow:auto}
  .portal-nav button{padding:9px 6px}.portal-main{padding-bottom:72px}.portal-content{padding:15px}.portal-topbar{padding:12px 15px}
  .portal-user div{display:none}.portal-hero{display:block}.portal-progress{min-width:0;margin-top:20px}
  .metric-grid{grid-template-columns:1fr 1fr}.metric-card b{font-size:22px}.item{grid-template-columns:1fr}.item-actions{justify-content:flex-start}
  .admin-shell{padding:14px}.admin-card{padding:20px}.admin-head{align-items:flex-start;flex-direction:column}.admin-form{grid-template-columns:1fr}.admin-form .full{grid-column:auto}
}


/* Sirmint Customer Operations — Phase 2 */
.ops-shell{min-height:100vh;background:#f4f2f8}
.ops-topbar{
  position:sticky;top:0;z-index:10;display:flex;align-items:center;justify-content:space-between;
  gap:16px;padding:14px 22px;border-bottom:1px solid var(--line);
  background:rgba(255,255,255,.95);backdrop-filter:blur(14px)
}
.ops-brand{display:flex;align-items:center;gap:10px;color:var(--ink);text-decoration:none}
.ops-brand div{display:grid}.ops-brand small{color:var(--muted)}
.ops-actions{display:flex;gap:9px;flex-wrap:wrap}
.ops-layout{display:grid;grid-template-columns:300px minmax(0,1fr);min-height:calc(100vh - 73px)}
.ops-client-panel{padding:20px;border-right:1px solid var(--line);background:#fff}
.ops-client-panel h2{margin:4px 0 6px}.ops-client-panel>p{margin:0 0 16px;color:var(--muted);line-height:1.5}
.ops-search{width:100%;padding:11px 12px;border:1px solid var(--line);border-radius:9px;outline:none}
.ops-search:focus{border-color:var(--purple);box-shadow:0 0 0 3px rgba(101,78,219,.12)}
.ops-client-list{display:grid;gap:8px;margin-top:14px}
.ops-client-button{
  width:100%;display:grid;grid-template-columns:42px minmax(0,1fr);gap:10px;align-items:center;
  padding:11px;border:1px solid var(--line);border-radius:11px;background:#fff;text-align:left;color:var(--ink)
}
.ops-client-button:hover,.ops-client-button.active{border-color:#c8bcfa;background:#f6f3ff}
.ops-client-button>span{
  width:42px;height:42px;display:grid;place-items:center;border-radius:10px;
  background:#eeeaff;color:#5941c8;font-weight:900
}
.ops-client-button div{min-width:0;display:grid;gap:3px}
.ops-client-button b,.ops-client-button small{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.ops-client-button small{color:var(--muted)}
.ops-main{min-width:0;padding:24px}
.ops-empty{min-height:65vh;display:grid;place-items:center;text-align:center}
.ops-empty div{max-width:520px}
.ops-empty h1{font-size:38px;margin:8px 0}.ops-empty p{color:var(--muted);line-height:1.6}
.ops-workspace[hidden]{display:none!important}
.ops-client-head{
  display:flex;align-items:flex-start;justify-content:space-between;gap:18px;
  padding:24px;border-radius:16px;color:#fff;
  background:radial-gradient(circle at 80% 20%,rgba(158,135,255,.75),transparent 32%),linear-gradient(135deg,#201450,#4e3bb1)
}
.ops-client-head h1{margin:6px 0}.ops-client-head p{margin:0;color:#ded8ef}
.ops-head-buttons{display:flex;gap:9px;flex-wrap:wrap}
.ops-head-buttons a{background:#fff;color:#33246f;text-decoration:none}
.ops-stats{display:grid;grid-template-columns:repeat(5,1fr);gap:12px;margin:16px 0}
.ops-stat{padding:16px;border:1px solid var(--line);border-radius:12px;background:#fff}
.ops-stat small{color:var(--muted)}.ops-stat b{display:block;margin-top:8px;font-size:24px}
.ops-tabs{display:flex;gap:7px;overflow:auto;padding:5px;margin-bottom:16px;border:1px solid var(--line);border-radius:11px;background:#fff}
.ops-tabs button{flex:0 0 auto;padding:10px 13px;border:0;border-radius:8px;background:transparent;color:var(--muted);font-weight:850}
.ops-tabs button.active{background:#eeeaff;color:#523bc2}
.ops-panel{display:none}.ops-panel.active{display:block}
.ops-grid{display:grid;grid-template-columns:minmax(320px,.85fr) minmax(0,1.15fr);gap:18px}
.ops-form-card,.ops-record-card{padding:20px;border:1px solid var(--line);border-radius:14px;background:#fff;box-shadow:0 12px 35px rgba(29,20,65,.05)}
.ops-form-card h2,.ops-record-card h2{margin:0 0 5px}.ops-form-card>p,.ops-record-card>p{margin:0 0 16px;color:var(--muted)}
.ops-form-grid{display:grid;grid-template-columns:1fr 1fr;gap:13px}
.ops-form-grid .full{grid-column:1/-1}
.ops-record-list{display:grid;gap:9px}
.ops-record{
  display:grid;grid-template-columns:minmax(0,1fr) auto;gap:12px;align-items:center;
  padding:13px;border:1px solid var(--line);border-radius:10px
}
.ops-record h3{margin:0;font-size:15px}.ops-record p{margin:5px 0 0;color:var(--muted);font-size:12px;line-height:1.45}
.ops-record-actions{display:flex;gap:7px;align-items:center;flex-wrap:wrap;justify-content:flex-end}
.ops-record-actions button,.ops-record-actions a{padding:8px 10px;font-size:12px;text-decoration:none}
.ops-progress-control{display:flex;align-items:center;gap:8px}
.ops-progress-control input{width:88px;padding:8px;border:1px solid var(--line);border-radius:7px}
.ops-message{min-height:23px;margin-top:12px;color:var(--muted);font-size:13px}
.ops-message[data-kind="error"]{color:var(--red)}
.ops-message[data-kind="success"]{color:var(--green)}
@media(max-width:1100px){
  .ops-layout{grid-template-columns:240px minmax(0,1fr)}
  .ops-grid{grid-template-columns:1fr}
  .ops-stats{grid-template-columns:repeat(3,1fr)}
}
@media(max-width:760px){
  .ops-topbar{align-items:flex-start;flex-direction:column}
  .ops-layout{display:block}.ops-client-panel{border-right:0;border-bottom:1px solid var(--line)}
  .ops-client-list{grid-template-columns:repeat(2,minmax(0,1fr));max-height:300px;overflow:auto}
  .ops-main{padding:14px}.ops-stats{grid-template-columns:repeat(2,1fr)}
  .ops-client-head{display:block}.ops-head-buttons{margin-top:16px}
  .ops-form-grid{grid-template-columns:1fr}.ops-form-grid .full{grid-column:auto}
}
@media(max-width:480px){
  .ops-client-list{grid-template-columns:1fr}.ops-stats{grid-template-columns:1fr 1fr}
}
