/* ============================================================
   Chatbotistic — Member Portal & Membership Templates
   Reuses the core design tokens from styles.css
   ============================================================ */

/* use-case detail: example workflow strip */
.uc-flow{display:flex;align-items:stretch;gap:0;flex-wrap:wrap;margin-top:40px;justify-content:center}
.uc-flow-step{flex:1;min-width:150px;max-width:230px;display:flex;flex-direction:column;gap:12px;padding:22px;border-radius:16px;background:linear-gradient(180deg,rgba(255,255,255,0.04),rgba(255,255,255,0.012));border:1px solid var(--line);text-align:left}
.uc-flow-step .n{width:36px;height:36px;border-radius:10px;display:grid;place-items:center;background:linear-gradient(135deg,#0e1430,#161d3c);border:1px solid var(--line-strong);font-family:var(--font-display);font-weight:600;color:#a8c1ff}
.uc-flow-step span{font-size:13.5px;color:var(--text-soft);line-height:1.45}
.uc-flow-arrow{display:flex;align-items:center;justify-content:center;color:var(--text-dim);padding:0 6px;flex-shrink:0}
@media (max-width:760px){
  .uc-flow{flex-direction:column;align-items:stretch}
  .uc-flow-step{max-width:none}
  .uc-flow-arrow{transform:rotate(90deg);padding:8px 0}
}

/* ============================================================
   Competitor "vs" comparison table (Chatbotistic vs others)
   ============================================================ */
.vs-table{border:1px solid var(--line);border-radius:18px;overflow:hidden;background:rgba(255,255,255,0.02);margin-top:40px}
.vs-scroll{overflow-x:auto}
.vs-grid{display:grid;grid-template-columns:1.5fr repeat(4,1fr);min-width:760px}
.vs-cell{padding:16px 20px;border-bottom:1px solid var(--line-soft);display:flex;align-items:center;font-size:14px;color:var(--text-soft)}
.vs-grid > .vs-cell:nth-last-child(-n+5){border-bottom:0}
.vs-cell.feat{color:var(--text-soft)}
.vs-cell.center{justify-content:center;text-align:center}
/* highlighted Chatbotistic column = 2nd data col = grid col 2 */
.vs-cell.us{background:linear-gradient(180deg,rgba(79,139,255,0.07),rgba(160,112,255,0.05));border-left:1px solid rgba(79,139,255,0.18);border-right:1px solid rgba(79,139,255,0.18)}
.vs-head{padding:22px 20px 18px;flex-direction:column;align-items:center;gap:3px;border-bottom:1px solid var(--line)}
.vs-head.feat{align-items:flex-start;justify-content:flex-end}
.vs-head .brand{font-family:var(--font-display);font-weight:600;font-size:16px;color:var(--text)}
.vs-head.us .brand{background:var(--grad-primary);-webkit-background-clip:text;background-clip:text;color:transparent}
.vs-head .tag{font-size:11px;color:var(--text-dim);font-family:var(--font-mono);letter-spacing:0.06em}
.vs-cell .vs-yes{color:var(--green)}
.vs-cell .vs-no{color:var(--text-dim)}
.vs-cell.us b,.vs-cell.us .vs-price{color:#fff}
.vs-price{font-family:var(--font-display);font-weight:600}
.vs-cell.us .vs-yes{filter:drop-shadow(0 0 6px rgba(52,211,153,0.4))}

/* plan recommendation block */
.rec-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-top:40px}
.rec-card{padding:26px;border-radius:18px;background:linear-gradient(180deg,rgba(255,255,255,0.035),rgba(255,255,255,0.01));border:1px solid var(--line);display:flex;flex-direction:column}
.rec-card .ico{width:44px;height:44px;border-radius:13px;display:grid;place-items:center;background:linear-gradient(135deg,rgba(79,139,255,0.16),rgba(160,112,255,0.16));border:1px solid rgba(79,139,255,0.22);color:#cfdcff;margin-bottom:16px}
.rec-card h3{font-size:17px;letter-spacing:-0.01em}
.rec-card p{font-size:13.5px;color:var(--text-soft);line-height:1.55;margin:8px 0 16px;flex:1}
.rec-card .pick{font-family:var(--font-mono);font-size:11px;letter-spacing:0.08em;text-transform:uppercase;color:var(--text-dim);margin-bottom:6px}
.rec-card .pick b{color:#c9b3ff}
@media (max-width:880px){.rec-grid{grid-template-columns:1fr}}

/* ---------- Generic form primitives (outside .contact-form) ---------- */
.cb-form{display:flex;flex-direction:column;gap:16px}
.cb-form .field label,.fld label{
  font-size:12px;color:var(--text-dim);font-family:var(--font-mono);
  letter-spacing:0.08em;text-transform:uppercase;display:block;margin-bottom:7px;
}
.cb-form input,.cb-form textarea,.cb-form select,
.fld input,.fld textarea,.fld select,.inp{
  width:100%;background:rgba(255,255,255,0.04);border:1px solid var(--line);
  border-radius:12px;padding:13px 15px;color:var(--text);
  font-family:var(--font-body);font-size:14px;outline:none;
  transition:border-color .2s,box-shadow .2s,background .2s;
}
.cb-form input::placeholder,.cb-form textarea::placeholder,.fld input::placeholder{color:var(--text-dim)}
.cb-form input:focus,.cb-form textarea:focus,.cb-form select:focus,
.fld input:focus,.fld textarea:focus,.fld select:focus,.inp:focus{
  border-color:var(--blue);box-shadow:0 0 0 3px rgba(79,139,255,0.16);
}
.cb-form textarea{resize:vertical;min-height:110px}
.cb-form select,.fld select{appearance:none;background-image:linear-gradient(45deg,transparent 50%,var(--text-dim) 50%),linear-gradient(135deg,var(--text-dim) 50%,transparent 50%);background-position:calc(100% - 18px) 19px,calc(100% - 13px) 19px;background-size:5px 5px,5px 5px;background-repeat:no-repeat;cursor:pointer}
.cb-form .field.invalid input,.cb-form .field.invalid select{border-color:#ff6f86;box-shadow:0 0 0 3px rgba(255,111,134,0.14)}
/* Native dropdown popup renders on a light OS surface — force dark bg + light text so options stay readable */
.cb-form select option,.fld select option,.inp option,select option{
  background-color:#0b1020;color:#e8edf7;
}
.cb-form select option:checked,.fld select option:checked,select option:checked{
  background-color:#10162a;color:#fff;
}
.field-err{font-size:12px;color:#ff8aa0;margin-top:5px;display:flex;align-items:center;gap:6px}
.field-hint{font-size:12px;color:var(--text-dim);margin-top:5px}
.fld{display:flex;flex-direction:column}
.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.req{color:var(--pink)}
.check-line{display:flex;gap:11px;align-items:flex-start;font-size:13.5px;color:var(--text-soft);line-height:1.5;cursor:pointer}
.check-line input{width:18px;height:18px;flex-shrink:0;margin-top:1px;accent-color:var(--blue)}

/* ---------- Auth / membership shell ---------- */
.auth-wrap{min-height:calc(100vh - 72px);display:grid;grid-template-columns:1.05fr 0.95fr}
.auth-aside{
  position:relative;overflow:hidden;padding:64px 56px;
  display:flex;flex-direction:column;justify-content:space-between;
  border-right:1px solid var(--line-soft);
  background:
    radial-gradient(700px 380px at 20% 0%, rgba(160,112,255,0.22), transparent 60%),
    radial-gradient(600px 360px at 90% 100%, rgba(63,220,255,0.14), transparent 60%),
    linear-gradient(180deg,#070b18,#05080f);
}
.auth-aside .scan{position:absolute;top:0;left:0;width:42%;height:100%;background:linear-gradient(90deg,transparent,rgba(160,112,255,0.06),transparent);animation:op-scan 9s ease-in-out infinite;pointer-events:none}
.auth-aside h2{font-size:clamp(26px,2.4vw,34px);letter-spacing:-0.02em;line-height:1.2;max-width:440px}
.auth-aside p{color:var(--text-soft);font-size:15px;line-height:1.65;max-width:420px;margin-top:14px}
.auth-points{display:flex;flex-direction:column;gap:14px;margin-top:34px}
.auth-point{display:flex;gap:13px;align-items:flex-start;font-size:14px;color:var(--text-soft)}
.auth-point .ico{width:34px;height:34px;border-radius:10px;flex-shrink:0;display:grid;place-items:center;background:linear-gradient(135deg,rgba(79,139,255,0.18),rgba(160,112,255,0.18));border:1px solid rgba(79,139,255,0.25);color:#a8c1ff}
.auth-point b{color:var(--text);display:block;font-size:14px;margin-bottom:1px}
.auth-main{display:flex;align-items:center;justify-content:center;padding:56px 40px}
.auth-card{width:100%;max-width:440px}
.auth-card.wide{max-width:560px}
.auth-card h1{font-size:30px;letter-spacing:-0.02em}
.auth-sub{color:var(--text-soft);font-size:15px;margin:10px 0 30px}
.auth-foot{margin-top:24px;font-size:14px;color:var(--text-soft);text-align:center}
.auth-foot a{color:var(--blue-bright);text-decoration:none;font-weight:600;cursor:pointer}
.auth-divider{display:flex;align-items:center;gap:14px;color:var(--text-dim);font-size:12px;margin:22px 0;font-family:var(--font-mono);letter-spacing:0.1em;text-transform:uppercase}
.auth-divider::before,.auth-divider::after{content:"";flex:1;height:1px;background:var(--line-soft)}
.sso-row{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.sso-btn{display:flex;align-items:center;justify-content:center;gap:9px;padding:12px;border-radius:12px;background:rgba(255,255,255,0.04);border:1px solid var(--line);color:var(--text);font-weight:600;font-size:13.5px;cursor:pointer;transition:border-color .2s,background .2s}
.sso-btn:hover{border-color:var(--line-strong);background:rgba(255,255,255,0.07)}
.pw-row{display:flex;justify-content:space-between;align-items:center}
.pw-row a{font-size:12.5px;color:var(--blue-bright);text-decoration:none;cursor:pointer}

/* status / result panels (payment success / failed / verify) */
.result-wrap{min-height:calc(100vh - 72px);display:grid;place-items:center;padding:64px 24px}
.result-card{max-width:520px;width:100%;text-align:center;padding:48px 40px}
.result-ico{width:74px;height:74px;border-radius:20px;display:grid;place-items:center;margin:0 auto 24px}
.result-ico.ok{background:linear-gradient(135deg,rgba(52,211,153,0.2),rgba(63,220,255,0.16));border:1px solid rgba(52,211,153,0.35);color:var(--green)}
.result-ico.err{background:linear-gradient(135deg,rgba(255,111,134,0.18),rgba(255,154,60,0.12));border:1px solid rgba(255,111,134,0.32);color:#ff8aa0}
.result-ico.wait{background:linear-gradient(135deg,rgba(79,139,255,0.18),rgba(160,112,255,0.14));border:1px solid rgba(79,139,255,0.3);color:#a8c1ff}
.result-card h1{font-size:28px;letter-spacing:-0.02em}
.result-card p{color:var(--text-soft);font-size:15.5px;line-height:1.6;margin:12px auto 26px;max-width:400px}
.result-actions{display:flex;gap:12px;justify-content:center;flex-wrap:wrap}
.receipt{text-align:left;border:1px solid var(--line);border-radius:14px;padding:18px;margin:26px 0;background:rgba(255,255,255,0.025)}
.receipt-row{display:flex;justify-content:space-between;padding:7px 0;font-size:13.5px;border-bottom:1px dashed var(--line-soft)}
.receipt-row:last-child{border-bottom:0}
.receipt-row .k{color:var(--text-dim)}
.receipt-row .v{color:var(--text);font-family:var(--font-mono);font-size:13px}

/* ---------- Demo / long form layout ---------- */
.form-page{max-width:920px;margin:0 auto;padding:0 32px}
.form-section-label{font-family:var(--font-mono);font-size:11px;letter-spacing:0.14em;text-transform:uppercase;color:var(--text-dim);margin:34px 0 16px;display:flex;align-items:center;gap:10px}
.form-section-label::after{content:"";flex:1;height:1px;background:var(--line-soft)}
.demo-aside-card{position:sticky;top:96px;padding:24px;border-radius:18px;align-self:flex-start}
.demo-layout{display:grid;grid-template-columns:1fr 320px;gap:36px;align-items:start;padding:56px 0}
.demo-step{display:flex;gap:12px;padding:10px 0;font-size:13.5px;color:var(--text-soft)}
.demo-step .n{width:24px;height:24px;border-radius:7px;flex-shrink:0;display:grid;place-items:center;background:rgba(79,139,255,0.12);border:1px solid rgba(79,139,255,0.25);color:#a8c1ff;font-family:var(--font-mono);font-size:11px}

/* ============================================================
   PORTAL
   ============================================================ */
.portal{display:grid;grid-template-columns:264px 1fr;min-height:100vh;background:var(--bg-0)}
.portal-side{
  position:sticky;top:0;height:100vh;overflow-y:auto;
  border-right:1px solid var(--line-soft);
  background:linear-gradient(180deg,#070b16,#05080f);
  padding:20px 14px;display:flex;flex-direction:column;gap:6px;z-index:20;
}
.portal-side .logo{padding:6px 10px 18px;font-size:17px}
.ps-group{font-family:var(--font-mono);font-size:10px;letter-spacing:0.14em;text-transform:uppercase;color:var(--text-dim);margin:18px 10px 6px;font-weight:500}
.ps-link{display:flex;align-items:center;gap:11px;padding:9px 11px;border-radius:10px;color:var(--text-soft);font-size:13.5px;font-weight:500;cursor:pointer;text-decoration:none;border:1px solid transparent;transition:background .18s,color .18s,border-color .18s}
.ps-link:hover{background:rgba(255,255,255,0.04);color:var(--text)}
.ps-link.active{background:linear-gradient(90deg,rgba(79,139,255,0.18),rgba(160,112,255,0.06));color:#fff;border-color:rgba(79,139,255,0.2)}
.ps-link .ico{display:grid;place-items:center;width:18px}
.ps-link .pill{margin-left:auto;font-family:var(--font-mono);font-size:9.5px;padding:2px 7px;border-radius:999px;background:rgba(160,112,255,0.18);color:#c9b3ff;letter-spacing:0.04em}
.ps-link .pill.lock{background:rgba(255,196,107,0.14);color:var(--amber)}
.ps-plan{margin-top:auto;padding:16px;border-radius:14px;background:linear-gradient(180deg,rgba(160,112,255,0.12),rgba(79,139,255,0.05));border:1px solid rgba(160,112,255,0.22)}
.ps-plan .pl-name{font-family:var(--font-display);font-weight:600;font-size:15px}
.ps-plan .pl-meta{font-size:12px;color:var(--text-soft);margin:3px 0 12px}
.ps-meter{height:6px;border-radius:999px;background:rgba(255,255,255,0.08);overflow:hidden;margin-bottom:6px}
.ps-meter span{display:block;height:100%;border-radius:999px;background:var(--grad-button)}
.ps-user{display:flex;align-items:center;gap:10px;padding:10px;border-radius:12px;border:1px solid var(--line-soft);margin-top:10px}
.ps-user .av{width:34px;height:34px;border-radius:50%;background:var(--grad-primary);display:grid;place-items:center;color:#0a0d18;font-weight:700;font-size:13px;flex-shrink:0}
.ps-user b{font-size:13px;display:block}
.ps-user span{font-size:11.5px;color:var(--text-dim)}

.portal-content{min-width:0;display:flex;flex-direction:column}
.portal-top{
  position:sticky;top:0;z-index:15;display:flex;align-items:center;gap:16px;
  padding:14px 28px;border-bottom:1px solid var(--line-soft);
  background:rgba(5,8,15,0.82);backdrop-filter:blur(16px);
}
.portal-top .crumb{font-size:13px;color:var(--text-dim);font-family:var(--font-mono);letter-spacing:0.04em}
.portal-top .crumb b{color:var(--text)}
.portal-search{flex:1;max-width:380px;display:flex;align-items:center;gap:9px;padding:9px 13px;border-radius:11px;background:rgba(255,255,255,0.04);border:1px solid var(--line);color:var(--text-dim);font-size:13px}
.portal-search input{flex:1;background:transparent;border:0;outline:none;color:var(--text);font-size:13px;font-family:var(--font-body)}
.portal-top .spacer{flex:1}
.portal-top .top-status{display:inline-flex;align-items:center;gap:7px;font-family:var(--font-mono);font-size:11px;letter-spacing:0.06em;color:var(--text-soft);padding:6px 11px;border-radius:999px;border:1px solid rgba(52,211,153,0.3);background:rgba(52,211,153,0.06)}
.portal-top .top-status .d{width:7px;height:7px;border-radius:50%;background:var(--green);box-shadow:0 0 9px var(--green)}
.portal-burger{display:none}
.portal-body{padding:30px 28px 64px;max-width:1180px;width:100%;margin:0 auto}
.view-head{margin-bottom:26px}
.view-head h1{font-size:26px;letter-spacing:-0.02em}
.view-head p{color:var(--text-soft);font-size:14.5px;margin-top:6px;max-width:560px}
.view-head .row{display:flex;align-items:flex-start;justify-content:space-between;gap:20px;flex-wrap:wrap}

/* stat tiles */
.pf-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}
.pf-stat{padding:18px;border-radius:16px;background:linear-gradient(180deg,rgba(255,255,255,0.04),rgba(255,255,255,0.012));border:1px solid var(--line)}
.pf-stat .lbl{font-size:10.5px;color:var(--text-dim);font-family:var(--font-mono);letter-spacing:0.1em;text-transform:uppercase;display:flex;align-items:center;gap:7px}
.pf-stat .val{font-family:var(--font-display);font-size:30px;font-weight:600;letter-spacing:-0.02em;margin-top:10px;line-height:1}
.pf-stat .sub{font-size:12px;color:var(--text-soft);margin-top:6px}
.pf-stat .sub.up{color:var(--green)}

.panel{padding:22px;border-radius:18px;background:linear-gradient(180deg,rgba(255,255,255,0.035),rgba(255,255,255,0.01));border:1px solid var(--line)}
.panel-head{display:flex;align-items:center;justify-content:space-between;gap:14px;margin-bottom:18px}
.panel-head h3{font-size:16px;letter-spacing:-0.01em}
.panel-head .sub{font-size:12.5px;color:var(--text-dim);margin-top:2px}
.cols-2{display:grid;grid-template-columns:1.5fr 1fr;gap:20px;align-items:start}
.cols-2.even{grid-template-columns:1fr 1fr}
.stack{display:flex;flex-direction:column;gap:20px}

/* setup checklist */
.setup-item{display:flex;align-items:center;gap:14px;padding:13px 0;border-bottom:1px solid var(--line-soft)}
.setup-item:last-child{border-bottom:0}
.setup-tick{width:26px;height:26px;border-radius:8px;flex-shrink:0;display:grid;place-items:center;border:1px solid var(--line-strong);color:var(--text-dim);font-size:12px}
.setup-item.done .setup-tick{background:linear-gradient(135deg,rgba(52,211,153,0.2),rgba(63,220,255,0.14));border-color:rgba(52,211,153,0.4);color:var(--green)}
.setup-item.active .setup-tick{border-color:var(--blue);color:var(--blue-bright);box-shadow:0 0 0 3px rgba(79,139,255,0.12)}
.setup-item .txt{flex:1;min-width:0}
.setup-item .txt b{font-size:13.5px;display:block}
.setup-item.done .txt b{color:var(--text-soft);text-decoration:line-through;text-decoration-color:var(--text-dim)}
.setup-item .txt span{font-size:12px;color:var(--text-dim)}
.setup-progress{display:flex;align-items:center;gap:12px;margin-bottom:6px}
.setup-progress .bar{flex:1;height:7px;border-radius:999px;background:rgba(255,255,255,0.08);overflow:hidden}
.setup-progress .bar span{display:block;height:100%;background:var(--grad-success);border-radius:999px}
.setup-progress .pct{font-family:var(--font-mono);font-size:12px;color:var(--green)}

/* quick actions */
.qa-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.qa{display:flex;align-items:center;gap:12px;padding:14px;border-radius:13px;background:rgba(255,255,255,0.03);border:1px solid var(--line);cursor:pointer;text-align:left;transition:transform .2s,border-color .2s,background .2s;color:var(--text);font-family:var(--font-body)}
.qa:hover{transform:translateY(-2px);border-color:var(--line-strong);background:rgba(255,255,255,0.06)}
.qa .ico{width:38px;height:38px;border-radius:11px;flex-shrink:0;display:grid;place-items:center;background:linear-gradient(135deg,rgba(79,139,255,0.16),rgba(160,112,255,0.16));border:1px solid rgba(79,139,255,0.22);color:#cfdcff}
.qa b{font-size:13.5px;display:block}
.qa span{font-size:11.5px;color:var(--text-dim)}

/* data tables */
.pf-table{width:100%;border-collapse:collapse}
.pf-table th{font-family:var(--font-mono);font-size:10px;letter-spacing:0.1em;text-transform:uppercase;color:var(--text-dim);text-align:left;padding:11px 14px;font-weight:500;border-bottom:1px solid var(--line)}
.pf-table td{padding:14px;font-size:13.5px;border-bottom:1px solid var(--line-soft);color:var(--text-soft);vertical-align:middle}
.pf-table tr:last-child td{border-bottom:0}
.pf-table tbody tr{transition:background .15s}
.pf-table tbody tr:hover{background:rgba(255,255,255,0.025)}
.pf-table td b,.pf-table td .nm{color:var(--text);font-weight:600}
.table-wrap{border:1px solid var(--line);border-radius:16px;overflow:hidden;background:rgba(255,255,255,0.02)}
.table-scroll{overflow-x:auto}
.row-av{width:30px;height:30px;border-radius:50%;background:var(--grad-primary);display:inline-grid;place-items:center;color:#0a0d18;font-weight:700;font-size:11px;flex-shrink:0}
.cell-name{display:flex;align-items:center;gap:11px}

/* status dots / badges */
.st{display:inline-flex;align-items:center;gap:7px;font-size:12.5px;font-weight:600}
.st .d{width:8px;height:8px;border-radius:50%}
.st.live{color:var(--green)}.st.live .d{background:var(--green);box-shadow:0 0 8px var(--green)}
.st.paused{color:var(--amber)}.st.paused .d{background:var(--amber)}
.st.draft{color:var(--text-dim)}.st.draft .d{background:var(--text-dim)}
.st.off{color:#ff8aa0}.st.off .d{background:#ff8aa0}
.badge{display:inline-flex;align-items:center;gap:6px;padding:3px 10px;border-radius:999px;font-size:11px;font-family:var(--font-mono);letter-spacing:0.05em;font-weight:500}
.badge.b-new{background:rgba(63,220,255,0.12);color:var(--cyan);border:1px solid rgba(63,220,255,0.24)}
.badge.b-won{background:rgba(52,211,153,0.12);color:var(--green);border:1px solid rgba(52,211,153,0.24)}
.badge.b-warm{background:rgba(255,196,107,0.12);color:var(--amber);border:1px solid rgba(255,196,107,0.24)}
.badge.b-cold{background:rgba(255,255,255,0.05);color:var(--text-dim);border:1px solid var(--line)}
.badge.b-plan{background:rgba(160,112,255,0.14);color:#c9b3ff;border:1px solid rgba(160,112,255,0.24)}
.icon-act{width:30px;height:30px;border-radius:8px;display:inline-grid;place-items:center;background:rgba(255,255,255,0.04);border:1px solid var(--line);color:var(--text-soft);cursor:pointer;transition:color .15s,border-color .15s}
.icon-act:hover{color:var(--text);border-color:var(--line-strong)}
.act-row{display:flex;gap:7px}

/* toolbar (filters above tables) */
.toolbar{display:flex;align-items:center;gap:10px;flex-wrap:wrap;margin-bottom:16px}
.toolbar .grow{flex:1}
.chip-select{display:inline-flex;align-items:center;gap:8px;padding:8px 13px;border-radius:10px;background:rgba(255,255,255,0.04);border:1px solid var(--line);color:var(--text-soft);font-size:13px;cursor:pointer}
.chip-select:hover{border-color:var(--line-strong);color:var(--text)}
.tab-row{display:flex;gap:4px;background:rgba(255,255,255,0.04);border:1px solid var(--line);border-radius:11px;padding:4px;flex-wrap:wrap}
.tab-row button{padding:7px 14px;border-radius:8px;border:0;background:transparent;color:var(--text-soft);font-family:var(--font-body);font-size:13px;font-weight:600;cursor:pointer}
.tab-row button.active{background:var(--grad-button);color:#fff}

/* license card */
.lic-key{display:flex;align-items:center;gap:12px;padding:16px 18px;border-radius:14px;background:#070b18;border:1px solid var(--line);font-family:var(--font-mono);font-size:15px;letter-spacing:0.04em;color:#cfdcff;flex-wrap:wrap}
.lic-key .key{flex:1;min-width:200px;word-break:break-all}
.kv-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:1px;background:var(--line-soft);border:1px solid var(--line);border-radius:14px;overflow:hidden;margin-top:18px}
.kv{background:var(--bg-1);padding:15px 16px}
.kv .k{font-size:10.5px;font-family:var(--font-mono);letter-spacing:0.1em;text-transform:uppercase;color:var(--text-dim)}
.kv .v{font-size:15px;margin-top:6px;font-weight:600}
.domain-row{display:flex;align-items:center;gap:12px;padding:12px 0;border-bottom:1px solid var(--line-soft);font-size:13.5px}
.domain-row:last-child{border-bottom:0}
.domain-row .globe{width:30px;height:30px;border-radius:9px;display:grid;place-items:center;background:rgba(79,139,255,0.1);border:1px solid rgba(79,139,255,0.22);color:#a8c1ff;flex-shrink:0}

/* steps (wp addon) */
.wpsteps{counter-reset:s;display:flex;flex-direction:column;gap:0}
.wpstep{display:flex;gap:16px;padding:16px 0;border-bottom:1px solid var(--line-soft);align-items:flex-start}
.wpstep:last-child{border-bottom:0}
.wpstep .num{counter-increment:s;width:34px;height:34px;border-radius:10px;flex-shrink:0;display:grid;place-items:center;background:linear-gradient(135deg,#0e1430,#161d3c);border:1px solid var(--line-strong);font-family:var(--font-display);font-weight:600}
.wpstep .num::before{content:counter(s)}
.wpstep b{font-size:14.5px;display:block;margin-bottom:3px}
.wpstep p{font-size:13px;color:var(--text-soft);margin:0;line-height:1.5}

/* empty / locked states */
.empty{text-align:center;padding:56px 24px}
.empty .ico{width:60px;height:60px;border-radius:16px;display:grid;place-items:center;margin:0 auto 18px;background:rgba(255,255,255,0.04);border:1px solid var(--line);color:var(--text-dim)}
.empty h3{font-size:17px}
.empty p{color:var(--text-soft);font-size:14px;margin:8px auto 20px;max-width:380px}
.locked-banner{display:flex;align-items:center;gap:16px;padding:18px 22px;border-radius:16px;background:linear-gradient(135deg,rgba(255,196,107,0.1),rgba(160,112,255,0.06));border:1px solid rgba(255,196,107,0.25);flex-wrap:wrap}
.locked-banner .ico{width:42px;height:42px;border-radius:12px;display:grid;place-items:center;background:rgba(255,196,107,0.14);border:1px solid rgba(255,196,107,0.3);color:var(--amber);flex-shrink:0}
.locked-banner b{font-size:14.5px;display:block}
.locked-banner span{font-size:13px;color:var(--text-soft)}
.locked-banner .btn{margin-left:auto}

/* analytics bars */
.bars{display:flex;align-items:flex-end;gap:8px;height:160px;padding-top:10px}
.bars .b{flex:1;display:flex;flex-direction:column;justify-content:flex-end;gap:8px;align-items:center}
.bars .b .fill{width:100%;border-radius:6px 6px 0 0;background:linear-gradient(180deg,var(--blue),rgba(79,139,255,0.12));min-height:6px;transition:height .6s cubic-bezier(.2,.8,.2,1)}
.bars .b .fill.alt{background:linear-gradient(180deg,var(--violet),rgba(160,112,255,0.12))}
.bars .b .lbl{font-size:10.5px;color:var(--text-dim);font-family:var(--font-mono)}
.list-rank{display:flex;flex-direction:column;gap:10px}
.rank-row{display:flex;align-items:center;gap:12px;font-size:13px}
.rank-row .nm{flex:1;color:var(--text);min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.rank-row .track{width:90px;height:6px;border-radius:999px;background:rgba(255,255,255,0.07);overflow:hidden}
.rank-row .track span{display:block;height:100%;background:var(--grad-button);border-radius:999px}
.rank-row .v{font-family:var(--font-mono);font-size:12px;color:var(--text-soft);width:42px;text-align:right}

/* toast */
.toast{position:fixed;bottom:26px;left:50%;transform:translateX(-50%) translateY(20px);background:rgba(14,20,40,0.96);border:1px solid rgba(52,211,153,0.35);border-radius:13px;padding:13px 18px;display:flex;align-items:center;gap:11px;font-size:13.5px;box-shadow:0 20px 60px -10px rgba(0,0,0,0.7);opacity:0;pointer-events:none;transition:opacity .3s,transform .3s;z-index:200}
.toast.show{opacity:1;transform:translateX(-50%) translateY(0)}
.toast .ico{width:26px;height:26px;border-radius:8px;display:grid;place-items:center;background:rgba(52,211,153,0.16);color:var(--green);flex-shrink:0}

/* preview widget mini (create widget) */
.cw-mini{border-radius:18px;border:1px solid var(--line-strong);overflow:hidden;background:linear-gradient(180deg,#0e1428,#0a0f1f);box-shadow:0 30px 70px -25px rgba(0,0,0,0.7)}
.cw-mini .h{padding:13px 15px;display:flex;align-items:center;gap:10px;border-bottom:1px solid var(--line)}
.cw-mini .av{width:32px;height:32px;border-radius:50%;display:grid;place-items:center;color:#fff;font-weight:700;font-size:12px}
.cw-mini .h b{font-size:13px;display:block}
.cw-mini .h span{font-size:10.5px;color:var(--text-soft)}
.cw-mini .body{padding:16px;display:flex;flex-direction:column;gap:10px;min-height:150px}
.cw-mini .bub{padding:9px 13px;border-radius:14px;font-size:12.5px;max-width:85%;background:rgba(255,255,255,0.06);border:1px solid var(--line);align-self:flex-start;border-bottom-left-radius:5px}
.cw-mini .fab{position:absolute;bottom:14px;right:14px;width:50px;height:50px;border-radius:50%;display:grid;place-items:center;color:#fff;box-shadow:0 14px 36px -8px rgba(0,0,0,0.6)}

/* responsive portal */
@media (max-width:1000px){
  .pf-stats{grid-template-columns:repeat(2,1fr)}
  .cols-2,.cols-2.even{grid-template-columns:1fr}
  .auth-wrap{grid-template-columns:1fr}
  .auth-aside{display:none}
  .demo-layout{grid-template-columns:1fr}
  .demo-aside-card{position:static;order:-1}
}
@media (max-width:860px){
  .portal{grid-template-columns:1fr}
  .portal-side{position:fixed;left:0;top:0;width:280px;transform:translateX(-100%);transition:transform .3s ease;box-shadow:0 0 80px rgba(0,0,0,0.6)}
  .portal.nav-open .portal-side{transform:translateX(0)}
  .portal-burger{display:grid}
  .portal-scrim{position:fixed;inset:0;background:rgba(0,0,0,0.6);z-index:18;opacity:0;pointer-events:none;transition:opacity .3s}
  .portal.nav-open .portal-scrim{opacity:1;pointer-events:auto}
  .portal-search{display:none}
}
@media (max-width:560px){
  .pf-stats,.qa-grid,.grid-2,.grid-3{grid-template-columns:1fr}
  .portal-body{padding:22px 16px 56px}
  .portal-top{padding:12px 16px}
  .auth-main{padding:36px 20px}
  .sso-row{grid-template-columns:1fr}
  .result-card{padding:36px 22px}
}
@media (prefers-reduced-motion: reduce){
  .auth-aside .scan,.bars .b .fill{animation:none !important;transition:none !important}
}
