/* =========================================================
   HTS Merchant Portal – Styles v2
   ========================================================= */
@import url('https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800&family=Dancing+Script:wght@700&family=JetBrains+Mono:wght@400;600&display=swap');

/* ── Variables ── */
:root {
  --bg: #07080f;
  --surface: rgba(255,255,255,0.04);
  --surface-hover: rgba(255,255,255,0.07);
  --border: rgba(255,255,255,0.09);
  --border-focus: rgba(108,99,255,0.65);

  --primary: #6C63FF;
  --primary-lt: #9B95FF;
  --primary-dk: #5147E0;
  --accent: #3B82F6;
  --success: #22C55E;
  --warn: #F59E0B;
  --error: #EF4444;
  --trial: #F97316;

  --text-1: #F0F0FF;
  --text-2: rgba(240,240,255,0.55);
  --text-3: rgba(240,240,255,0.3);

  --r-sm: 8px; --r-md: 14px; --r-lg: 20px; --r-xl: 26px;
  --shadow-card: 0 24px 80px rgba(0,0,0,0.6), 0 1px 0 rgba(255,255,255,0.06) inset;
  --shadow-btn: 0 8px 28px rgba(108,99,255,0.4);
  --font: 'Inter', system-ui, sans-serif;
  --mono: 'JetBrains Mono', monospace;
  --sign-font: 'Dancing Script', cursive;
  --t-fast: 180ms cubic-bezier(.4,0,.2,1);
  --t-med: 300ms cubic-bezier(.4,0,.2,1);
}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:var(--font);background:var(--bg);color:var(--text-1);min-height:100vh;display:flex;flex-direction:column;align-items:center;overflow-x:hidden}

/* ── Orbs ── */
.bg-orb{position:fixed;border-radius:50%;filter:blur(90px);pointer-events:none;z-index:0;animation:floatOrb 14s ease-in-out infinite}
.orb-1{width:520px;height:520px;background:radial-gradient(circle,rgba(108,99,255,.22) 0%,transparent 70%);top:-130px;left:-100px}
.orb-2{width:420px;height:420px;background:radial-gradient(circle,rgba(59,130,246,.18) 0%,transparent 70%);bottom:-80px;right:-80px;animation-delay:-5s}
.orb-3{width:320px;height:320px;background:radial-gradient(circle,rgba(249,115,22,.12) 0%,transparent 70%);top:50%;left:60%;animation-delay:-9s}
@keyframes floatOrb{0%,100%{transform:translate(0,0) scale(1)}33%{transform:translate(28px,-18px) scale(1.04)}66%{transform:translate(-18px,28px) scale(0.96)}}

/* ── Demo Strip ── */
.demo-strip{position:relative;z-index:20;display:flex;align-items:center;gap:10px;padding:8px 16px;background:rgba(249,115,22,.1);border:1px solid rgba(249,115,22,.25);border-radius:var(--r-xl);margin-top:16px;font-size:12px;font-weight:500;color:#fdba74}
.demo-label{opacity:.7}
.demo-desc{font-weight:600;min-width:140px}
.toggle-switch{position:relative;display:flex;width:36px;height:20px;flex-shrink:0}
.toggle-switch input{opacity:0;width:0;height:0}
.toggle-track{position:absolute;inset:0;background:rgba(255,255,255,.15);border-radius:20px;cursor:pointer;transition:var(--t-fast)}
.toggle-track::before{content:'';position:absolute;left:2px;top:2px;width:16px;height:16px;border-radius:50%;background:white;transition:var(--t-fast)}
.toggle-switch input:checked+.toggle-track{background:var(--trial)}
.toggle-switch input:checked+.toggle-track::before{transform:translateX(16px)}

/* ── Step Bar ── */
.step-bar{position:relative;z-index:10;display:flex;align-items:center;gap:0;padding:20px 20px 0;margin-top:16px;width:100%;max-width:860px}
.step-item{display:flex;flex-direction:column;align-items:center;gap:5px;flex-shrink:0}
.step-circle{width:40px;height:40px;border-radius:50%;background:var(--surface);border:2px solid var(--border);display:flex;align-items:center;justify-content:center;font-size:16px;transition:var(--t-med)}
.step-item.active .step-circle{background:linear-gradient(135deg,var(--primary),var(--accent));border-color:var(--primary);box-shadow:0 0 20px rgba(108,99,255,.5)}
.step-item.completed .step-circle{background:var(--success);border-color:var(--success)}
.step-item.completed .step-icon{display:none}
.step-item.completed .step-circle::after{content:'✓';font-size:16px;color:#fff;font-weight:700}
.step-label{font-size:10px;font-weight:500;color:var(--text-3);white-space:nowrap;transition:var(--t-med)}
.step-item.active .step-label,.step-item.completed .step-label{color:var(--text-2)}
.step-connector{flex:1;height:2px;background:var(--border);margin-bottom:20px;transition:background var(--t-med);min-width:12px}
.step-connector.filled{background:var(--primary)}

/* ── Screens ── */
.screens-wrapper{position:relative;z-index:5;width:100%;padding:20px 16px 48px;display:flex;justify-content:center}
.screen{display:none;width:100%;justify-content:center;animation:screenIn .4s both}
.screen.active{display:flex}
@keyframes screenIn{from{opacity:0;transform:translateY(16px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}

/* ── Cards ── */
.card{width:100%;max-width:480px}
.wide-card{max-width:960px}
.sign-card{max-width:600px}
.pay-card{max-width:540px}
.glass-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-xl);padding:36px 40px;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);box-shadow:var(--shadow-card)}
.glass-inner{background:rgba(255,255,255,.03);border:1px solid var(--border);border-radius:var(--r-md);padding:16px 20px}

/* ── Brand ── */
.card-brand{display:flex;align-items:center;gap:12px;margin-bottom:28px}
.brand-logo{flex-shrink:0}
.brand-name{font-size:19px;font-weight:700;background:linear-gradient(90deg,var(--primary-lt),var(--accent));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.brand-sub{font-size:11px;color:var(--text-3);margin-top:2px}

/* ── Typography helpers ── */
.card-title{font-size:24px;font-weight:700;line-height:1.25;margin-bottom:8px}
.card-desc{font-size:14px;color:var(--text-2);line-height:1.65;margin-bottom:24px}
.text-center{text-align:center}
.mt-2{margin-top:8px}.mt-3{margin-top:12px}.mt-4{margin-top:16px}.mt-5{margin-top:20px}.mt-6{margin-top:24px}.mb-4{margin-bottom:16px}.mb-6{margin-bottom:24px}

/* ── Badges ── */
.badge-pill{display:inline-flex;align-items:center;padding:4px 12px;border-radius:20px;font-size:11px;font-weight:600}
.badge-trial{background:linear-gradient(90deg,rgba(249,115,22,.2),rgba(245,158,11,.15));border:1px solid rgba(249,115,22,.3);color:#fdba74}
.badge-sign{background:linear-gradient(90deg,rgba(34,197,94,.15),rgba(59,130,246,.15));border:1px solid rgba(34,197,94,.3);color:#4ade80}

/* ── Fields ── */
.field-group{margin-bottom:18px}
.field-label{display:block;font-size:13px;font-weight:500;color:var(--text-2);margin-bottom:7px}
.input-wrap{position:relative;display:flex;align-items:center}
.input-icon{position:absolute;left:13px;color:var(--text-3);display:flex;pointer-events:none}
.input-field{width:100%;padding:11px 14px 11px 40px;background:rgba(255,255,255,.06);border:1px solid var(--border);border-radius:var(--r-sm);color:var(--text-1);font-family:var(--font);font-size:14px;outline:none;transition:var(--t-fast)}
.input-field.no-icon{padding-left:14px}
.input-field::placeholder{color:var(--text-3)}
.input-field:focus{border-color:var(--border-focus);background:rgba(108,99,255,.07);box-shadow:0 0 0 3px rgba(108,99,255,.12)}
.input-field.error{border-color:var(--error)}
select.input-field{cursor:pointer;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='rgba(240,240,255,0.4)' stroke-width='2'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center}
.field-error{font-size:12px;color:var(--error);margin-top:5px;min-height:15px}
.toggle-pwd{position:absolute;right:10px;background:none;border:none;cursor:pointer;color:var(--text-3);display:flex;padding:4px;transition:color var(--t-fast)}
.toggle-pwd:hover{color:var(--text-1)}

/* ── Checkbox ── */
.checkbox-label{display:flex;align-items:center;gap:10px;font-size:13px;color:var(--text-2);cursor:pointer;user-select:none}
.checkbox-input{display:none}
.checkbox-custom{width:18px;height:18px;border:2px solid var(--border);border-radius:5px;flex-shrink:0;display:flex;align-items:center;justify-content:center;transition:var(--t-fast)}
.checkbox-input:checked+.checkbox-custom{background:var(--primary);border-color:var(--primary)}
.checkbox-input:checked+.checkbox-custom::after{content:'✓';font-size:11px;color:#fff;font-weight:700}
.terms-check{margin:16px 0 20px}
.flex-between{display:flex;align-items:center;justify-content:space-between}

/* ── Buttons ── */
.btn-primary{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:12px 24px;background:linear-gradient(135deg,var(--primary) 0%,var(--accent) 100%);color:#fff;border:none;border-radius:var(--r-sm);font-family:var(--font);font-size:14px;font-weight:600;cursor:pointer;transition:var(--t-fast);box-shadow:var(--shadow-btn);position:relative;overflow:hidden}
.btn-primary::before{content:'';position:absolute;inset:0;background:linear-gradient(135deg,rgba(255,255,255,.15),transparent 60%);opacity:0;transition:opacity var(--t-fast)}
.btn-primary:hover:not(:disabled)::before{opacity:1}
.btn-primary:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 12px 36px rgba(108,99,255,.5)}
.btn-primary:active:not(:disabled){transform:translateY(0)}
.btn-primary:disabled{opacity:.38;cursor:not-allowed;box-shadow:none}
.btn-full{width:100%;margin-top:6px}
.btn-ghost{background:none;border:1px solid var(--border);border-radius:var(--r-sm);color:var(--text-2);font-family:var(--font);font-size:13px;font-weight:500;padding:10px 18px;cursor:pointer;transition:var(--t-fast)}
.btn-ghost:hover{background:var(--surface-hover);color:var(--text-1);border-color:rgba(255,255,255,.2)}
.btn-sm{padding:7px 14px;font-size:12px}
.link-text{color:var(--primary-lt);text-decoration:none;font-size:13px;font-weight:500}
.link-text:hover{text-decoration:underline}
.link-btn{background:none;border:none;color:var(--primary-lt);font-size:13px;font-weight:500;cursor:pointer}
.link-btn:hover{text-decoration:underline}
.btn-row{display:flex;gap:10px;margin-top:20px;align-items:center;justify-content:flex-end}
.btn-loader{display:flex}.btn-loader.hidden,.hidden{display:none!important}
@keyframes spin{to{transform:rotate(360deg)}}
.spin{animation:spin .8s linear infinite}
.btn-pay{font-size:15px;padding:13px 28px}

/* ── Alert boxes ── */
.alert-box{display:flex;align-items:center;gap:10px;padding:11px 15px;border-radius:var(--r-sm);font-size:13px;margin:14px 0}
.alert-error{background:rgba(239,68,68,.1);border:1px solid rgba(239,68,68,.28);color:#FCA5A5}
.alert-warn{background:rgba(245,158,11,.1);border:1px solid rgba(245,158,11,.28);color:#FCD34D}

/* ── Misc ── */
.card-footer-text{text-align:center;font-size:13px;color:var(--text-3)}
.text-success{color:var(--success)}.text-warn{color:var(--warn)}.text-error{color:var(--error)}

/* ═══════════════════════════════════════
   OTP
═══════════════════════════════════════ */
.otp-illus{margin-bottom:18px}
.otp-phone-icon{width:76px;height:76px;border-radius:50%;background:linear-gradient(135deg,rgba(108,99,255,.2),rgba(59,130,246,.2));border:1px solid rgba(108,99,255,.3);display:flex;align-items:center;justify-content:center;margin:0 auto;color:var(--primary-lt);animation:pulse 2s ease-in-out infinite}
@keyframes pulse{0%,100%{box-shadow:0 0 0 0 rgba(108,99,255,.3)}50%{box-shadow:0 0 0 14px rgba(108,99,255,0)}}
.otp-inputs{display:flex;align-items:center;justify-content:center;gap:9px;margin:20px 0}
.otp-box{width:50px;height:58px;border-radius:var(--r-sm);background:rgba(255,255,255,.06);border:2px solid var(--border);color:var(--text-1);font-size:22px;font-weight:700;text-align:center;outline:none;transition:var(--t-fast)}
.otp-box:focus{border-color:var(--primary);background:rgba(108,99,255,.1);box-shadow:0 0 0 3px rgba(108,99,255,.15);transform:scale(1.04)}
.otp-box.filled{border-color:var(--primary-lt)}
.otp-dash{font-size:22px;color:var(--text-3)}
.otp-timer{display:flex;align-items:center;justify-content:center;gap:6px;font-size:13px;color:var(--text-3);margin-bottom:18px}
#otpTimer{color:var(--warn);font-weight:600}
.resend-text{font-size:13px;color:var(--text-3)}

/* ═══════════════════════════════════════
   TRIAL CONTRACT
═══════════════════════════════════════ */
.first-login-banner{display:flex;align-items:center;gap:16px;padding:16px 20px;background:linear-gradient(90deg,rgba(249,115,22,.12),rgba(245,158,11,.08));border:1px solid rgba(249,115,22,.25);border-radius:var(--r-md)}
.flb-icon{font-size:28px;flex-shrink:0}
.first-login-banner h4{font-size:15px;font-weight:700;color:#fdba74;margin-bottom:4px}
.first-login-banner p{font-size:13px;color:var(--text-2);line-height:1.5}
.trial-terms-box{border:1px solid var(--border);border-radius:var(--r-md);overflow:hidden;margin-top:16px}
.trial-terms-header{padding:10px 18px;background:rgba(249,115,22,.08);border-bottom:1px solid var(--border)}
.trial-terms-content{padding:18px;height:200px;overflow-y:auto;font-size:13px;color:var(--text-2);line-height:1.7;scrollbar-width:thin;scrollbar-color:rgba(108,99,255,.4) transparent}
.trial-terms-content::-webkit-scrollbar{width:4px}
.trial-terms-content::-webkit-scrollbar-thumb{background:rgba(108,99,255,.4);border-radius:4px}
.trial-terms-content h4{font-size:14px;font-weight:700;color:var(--text-1);margin-bottom:10px}
.trial-terms-content p{margin-bottom:8px}
.trial-terms-content strong{color:var(--text-1)}

.trial-services{margin-top:18px}
.trial-services-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;margin-top:12px}
.trial-service-card{width:100%;text-align:left;padding:16px;border:1px solid var(--border);border-radius:var(--r-md);background:rgba(255,255,255,.03);color:var(--text-1);font-family:var(--font);cursor:pointer;transition:var(--t-fast);display:flex;flex-direction:column;gap:8px;min-height:132px}
.trial-service-card:hover{transform:translateY(-1px);border-color:rgba(108,99,255,.35);background:rgba(108,99,255,.06)}
.trial-service-card.selected{border-color:var(--primary);background:linear-gradient(180deg,rgba(108,99,255,.16),rgba(108,99,255,.06));box-shadow:0 10px 28px rgba(108,99,255,.15)}
.trial-service-icon{font-size:22px;line-height:1}
.trial-service-name{font-size:15px;font-weight:700;color:var(--text-1)}
.trial-service-desc{font-size:13px;line-height:1.55;color:var(--text-2)}

@media (max-width: 640px){
   .trial-services-grid{grid-template-columns:1fr}
}

/* ═══════════════════════════════════════
   SIGNATURE
═══════════════════════════════════════ */
.sign-area-wrap{margin-bottom:16px}
.sign-tabs{display:flex;gap:8px;margin-bottom:10px}
.sign-tab{padding:7px 16px;border-radius:var(--r-sm);border:1px solid var(--border);background:none;color:var(--text-3);font-family:var(--font);font-size:13px;font-weight:500;cursor:pointer;transition:var(--t-fast)}
.sign-tab.active{background:var(--primary);border-color:var(--primary);color:#fff}
.sign-pane{border:2px dashed var(--border);border-radius:var(--r-md);overflow:hidden;transition:border-color var(--t-fast)}
.sign-pane:hover{border-color:rgba(108,99,255,.4)}
canvas{width:100%;height:130px;display:block;background:rgba(255,255,255,.02);cursor:crosshair}
.clear-sign-btn{display:block;width:100%;padding:7px;background:rgba(239,68,68,.08);border:none;border-top:1px solid var(--border);color:#fca5a5;font-family:var(--font);font-size:12px;cursor:pointer;transition:var(--t-fast)}
.clear-sign-btn:hover{background:rgba(239,68,68,.16)}
.sign-text-input{padding:14px!important;font-family:var(--sign-font)!important;font-size:26px!important;text-align:center;height:72px;padding-left:14px!important}
.sign-preview{padding:14px;min-height:56px;font-family:var(--sign-font);font-size:34px;color:var(--primary-lt);text-align:center;border-top:1px solid var(--border)}

/* ═══════════════════════════════════════
   TRIAL DASHBOARD
═══════════════════════════════════════ */
.trial-dash-header{display:flex;align-items:flex-start;justify-content:space-between;gap:20px;margin-bottom:20px;flex-wrap:wrap}
.trial-dash-brand{display:flex;align-items:center;gap:12px}
.td-logo{flex-shrink:0}
.td-title{font-size:16px;font-weight:700}
.td-sub{font-size:12px;color:var(--text-3);margin-top:2px}

.trial-countdown{background:linear-gradient(135deg,rgba(249,115,22,.12),rgba(245,158,11,.08));border:1px solid rgba(249,115,22,.25);border-radius:var(--r-lg);padding:16px 20px;text-align:center;flex-shrink:0}
.tc-label{font-size:11px;font-weight:600;color:#fdba74;text-transform:uppercase;letter-spacing:.5px;margin-bottom:10px}
.tc-timer{display:flex;align-items:center;gap:6px;margin-bottom:12px}
.tc-block{display:flex;flex-direction:column;align-items:center;min-width:42px}
.tc-block span{font-size:24px;font-weight:800;font-variant-numeric:tabular-nums;color:var(--text-1);line-height:1}
.tc-block small{font-size:9px;color:var(--text-3);text-transform:uppercase;letter-spacing:.3px;margin-top:2px}
.tc-sep{font-size:20px;font-weight:700;color:rgba(249,115,22,.5);margin-bottom:12px}
.btn-upgrade{display:block;width:100%;padding:8px;background:linear-gradient(135deg,#f97316,#f59e0b);border:none;border-radius:var(--r-sm);font-family:var(--font);font-size:12px;font-weight:700;color:#fff;cursor:pointer;transition:var(--t-fast)}
.btn-upgrade:hover{opacity:.9;transform:translateY(-1px)}

.stats-bar{display:grid;grid-template-columns:1fr auto 1fr auto 1fr auto 1fr;align-items:center;background:rgba(255,255,255,.03);border:1px solid var(--border);border-radius:var(--r-md);padding:14px 0;margin-bottom:20px}
.stat-item{text-align:center;padding:0 16px}
.stat-val{display:block;font-size:18px;font-weight:700;color:var(--text-1);margin-bottom:2px}
.stat-label{font-size:11px;color:var(--text-3)}
.stat-divider{width:1px;height:32px;background:var(--border)}

/* ── Dash tabs ── */
.dash-tabs{display:flex;gap:4px;border-bottom:1px solid var(--border);margin-bottom:20px;overflow-x:auto;scrollbar-width:none}
.dash-tabs::-webkit-scrollbar{display:none}
.dash-tab{padding:9px 16px;border:none;border-bottom:2px solid transparent;background:none;color:var(--text-3);font-family:var(--font);font-size:13px;font-weight:500;cursor:pointer;transition:var(--t-fast);white-space:nowrap;margin-bottom:-1px}
.dash-tab:hover{color:var(--text-2)}
.dash-tab.active{color:var(--primary-lt);border-bottom-color:var(--primary)}
.dash-pane{animation:screenIn .3s both}
.dash-pane.hidden{display:none}

/* ── API Keys ── */
.apikey-warn{display:flex;align-items:center;gap:8px;padding:10px 14px;background:rgba(245,158,11,.1);border:1px solid rgba(245,158,11,.25);border-radius:var(--r-sm);font-size:13px;color:#FCD34D;margin-bottom:16px}
.key-card{background:rgba(0,0,0,.2);border:1px solid var(--border);border-radius:var(--r-md);overflow:hidden;margin-bottom:14px}
.key-row{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:14px 18px;border-bottom:1px solid var(--border)}
.key-row:last-child{border-bottom:none}
.key-info{display:flex;align-items:center;gap:10px;flex-shrink:0}
.key-type-label{font-size:13px;font-weight:600;color:var(--text-2)}
.key-env{font-size:10px;font-weight:700;padding:2px 8px;border-radius:20px;text-transform:uppercase}
.sandbox-env{background:rgba(249,115,22,.2);color:#fdba74;border:1px solid rgba(249,115,22,.3)}
.prod-env{background:rgba(34,197,94,.2);color:#4ade80;border:1px solid rgba(34,197,94,.3)}
.key-val-wrap{display:flex;align-items:center;gap:6px;flex:1;justify-content:flex-end;min-width:0}
.key-val{font-family:var(--mono);font-size:12px;color:var(--primary-lt);background:rgba(108,99,255,.08);padding:5px 10px;border-radius:6px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:340px;display:block}
.key-val.masked{color:var(--text-3);letter-spacing:2px}
.copy-btn,.reveal-btn{background:rgba(255,255,255,.06);border:1px solid var(--border);border-radius:6px;color:var(--text-2);cursor:pointer;padding:6px;display:flex;align-items:center;transition:var(--t-fast);flex-shrink:0}
.copy-btn:hover,.reveal-btn:hover{background:rgba(108,99,255,.15);border-color:rgba(108,99,255,.4);color:var(--primary-lt)}
.key-regen{display:flex;align-items:center;gap:12px}
.regen-note{font-size:12px;color:var(--text-3)}

/* ── API Docs ── */
.apidoc-layout{display:grid;grid-template-columns:200px 1fr;gap:0;border:1px solid var(--border);border-radius:var(--r-md);overflow:hidden;min-height:360px}
.apidoc-sidebar{background:rgba(0,0,0,.2);border-right:1px solid var(--border);padding:16px}
.sidebar-title{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:var(--text-3);margin-bottom:10px;padding:0 8px}
.sidebar-menu{list-style:none;display:flex;flex-direction:column;gap:2px}
.sidebar-menu li{padding:8px 10px;border-radius:var(--r-sm);font-size:13px;color:var(--text-2);cursor:pointer;transition:var(--t-fast)}
.sidebar-menu li:hover{background:var(--surface-hover);color:var(--text-1)}
.sidebar-menu li.active{background:rgba(108,99,255,.15);color:var(--primary-lt);font-weight:600}
.apidoc-content{padding:20px;overflow-y:auto;max-height:400px;scrollbar-width:thin;scrollbar-color:rgba(108,99,255,.3) transparent}
.apidoc-content::-webkit-scrollbar{width:4px}
.apidoc-content::-webkit-scrollbar-thumb{background:rgba(108,99,255,.3);border-radius:4px}
.doc-section-title{font-size:16px;font-weight:700;margin-bottom:6px}
.doc-section-desc{font-size:13px;color:var(--text-2);line-height:1.6;margin-bottom:16px}
.endpoint-block{background:rgba(0,0,0,.25);border:1px solid var(--border);border-radius:var(--r-md);margin-bottom:14px;overflow:hidden}
.endpoint-header{display:flex;align-items:center;gap:10px;padding:10px 14px;border-bottom:1px solid var(--border)}
.method-badge{font-family:var(--mono);font-size:11px;font-weight:700;padding:3px 8px;border-radius:5px}
.badge-get{background:rgba(34,197,94,.15);color:#4ade80}
.badge-post{background:rgba(59,130,246,.15);color:#93c5fd}
.badge-delete{background:rgba(239,68,68,.15);color:#fca5a5}
.endpoint-path{font-family:var(--mono);font-size:13px;color:var(--text-1)}
.endpoint-desc{font-size:12px;color:var(--text-3);margin-left:auto}
.endpoint-body{padding:14px}
.code-block{background:rgba(0,0,0,.4);border-radius:var(--r-sm);padding:14px;font-family:var(--mono);font-size:12px;color:#a5b4fc;white-space:pre;overflow-x:auto;line-height:1.6}

/* ── Trial Info ── */
.trial-info-grid{display:grid;grid-template-columns:1fr 1fr 1fr;gap:16px}
.ti-card{background:rgba(0,0,0,.15);border:1px solid var(--border);border-radius:var(--r-md);padding:20px}
.ti-icon{font-size:28px;margin-bottom:10px}
.ti-card h4{font-size:15px;font-weight:700;margin-bottom:14px}
.ti-rows{display:flex;flex-direction:column;gap:0}
.ti-row{display:flex;justify-content:space-between;align-items:center;padding:8px 0;border-bottom:1px solid rgba(255,255,255,.05);font-size:13px;color:var(--text-2)}
.ti-row:last-child{border-bottom:none}
.upgrade-cta{border-color:rgba(108,99,255,.3);background:rgba(108,99,255,.05)}
.upgrade-cta h4{color:var(--primary-lt)}
.ti-cta-desc{font-size:13px;color:var(--text-2);line-height:1.5;margin-bottom:12px}
.ti-benefits{list-style:none;display:flex;flex-direction:column;gap:6px;font-size:13px;color:var(--text-2)}

/* ═══════════════════════════════════════
   PACKAGES
═══════════════════════════════════════ */
.expired-banner{display:flex;align-items:center;gap:10px;padding:12px 16px;background:rgba(239,68,68,.1);border:1px solid rgba(239,68,68,.28);border-radius:var(--r-sm);font-size:13px;color:#fca5a5;margin-bottom:20px}
.packages-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin-bottom:20px}
.package-card{background:var(--surface);border:2px solid var(--border);border-radius:var(--r-lg);padding:22px 18px;cursor:pointer;transition:var(--t-med);position:relative;display:flex;flex-direction:column;gap:8px}
.package-card:hover{transform:translateY(-4px);border-color:rgba(108,99,255,.4);box-shadow:0 20px 60px rgba(0,0,0,.4)}
.package-card.selected{border-color:var(--primary);background:rgba(108,99,255,.08);box-shadow:0 0 0 1px var(--primary),0 20px 60px rgba(108,99,255,.2)}
.package-card.featured{border-color:rgba(108,99,255,.4)}
.pkg-badge{display:inline-flex;padding:3px 10px;border-radius:20px;font-size:10px;font-weight:700;background:rgba(108,99,255,.18);color:var(--primary-lt);width:fit-content}
.featured-badge{background:linear-gradient(90deg,rgba(108,99,255,.28),rgba(59,130,246,.28));color:#a5b4fc}
.enterprise-badge{background:rgba(245,158,11,.18);color:#FCD34D}
.pkg-icon{font-size:26px}
.pkg-name{font-size:17px;font-weight:700}
.pkg-desc{font-size:12px;color:var(--text-3);line-height:1.5}
.pkg-price{margin:4px 0}
.price-amount{font-size:21px;font-weight:800}
.price-unit{font-size:12px;color:var(--text-3)}
.pkg-features{list-style:none;display:flex;flex-direction:column;gap:5px;flex:1}
.pkg-features li{font-size:12px;color:var(--text-2)}
.pkg-features li.disabled{color:var(--text-3)}
.pkg-select-btn{width:100%;padding:9px;border-radius:var(--r-sm);border:1px solid var(--border);background:none;color:var(--text-2);font-family:var(--font);font-size:12px;font-weight:600;cursor:pointer;transition:var(--t-fast);margin-top:6px}
.pkg-select-btn:hover{background:var(--surface-hover);border-color:rgba(108,99,255,.4);color:var(--text-1)}
.package-card.selected .pkg-select-btn{background:var(--primary);border-color:var(--primary);color:#fff}
.featured-btn{background:linear-gradient(135deg,var(--primary),var(--accent));border-color:transparent;color:#fff}
.selected-pkg-info{display:flex;align-items:center;gap:8px;padding:11px 14px;background:rgba(34,197,94,.08);border:1px solid rgba(34,197,94,.2);border-radius:var(--r-sm);font-size:13px;color:#86efac;margin-bottom:6px}

/* ═══════════════════════════════════════
   CONTRACT SUMMARY
═══════════════════════════════════════ */
.contract-summary{background:rgba(0,0,0,.2);border:1px solid var(--border);border-radius:var(--r-md);overflow:hidden}
.summary-row{display:flex;align-items:center;justify-content:space-between;padding:11px 18px;border-bottom:1px solid var(--border);font-size:14px}
.summary-row:last-child{border-bottom:none}
.summary-label{color:var(--text-3)}
.summary-value{font-weight:600}

/* ═══════════════════════════════════════
   PAYMENT
═══════════════════════════════════════ */
.pay-summary{margin-bottom:20px}
.pay-row{display:flex;align-items:center;justify-content:space-between;font-size:14px;padding:6px 0;color:var(--text-2)}
.pay-divider{height:1px;background:var(--border);margin:10px 0}
.pay-total{color:var(--text-1);font-weight:700;font-size:15px}
.total-amount{font-size:19px;font-weight:800;color:var(--primary-lt)}
.payment-methods{margin-bottom:4px}
.method-tabs{display:flex;gap:8px;margin-bottom:14px;flex-wrap:wrap}
.method-tab{display:flex;align-items:center;gap:7px;padding:9px 14px;border-radius:var(--r-sm);border:1px solid var(--border);background:none;color:var(--text-3);font-size:13px;font-weight:500;cursor:pointer;transition:var(--t-fast)}
.method-tab input{display:none}
.method-tab.active{background:rgba(108,99,255,.1);border-color:var(--primary);color:var(--text-1)}
.method-content{animation:screenIn .3s both}
.two-col{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.bank-info{margin-top:4px}
.bank-title{font-size:13px;font-weight:700;color:var(--text-2);margin-bottom:12px}
.bank-row{display:flex;justify-content:space-between;align-items:center;font-size:13px;padding:7px 0;border-bottom:1px solid rgba(255,255,255,.05);color:var(--text-2)}
.bank-row:last-child{border-bottom:none}
.bank-row.highlight strong{color:var(--primary-lt);font-size:16px}
.wallet-grid{display:flex;gap:10px}
.wallet-item{flex:1;display:flex;flex-direction:column;align-items:center;gap:7px;padding:14px;border:1px solid var(--border);border-radius:var(--r-md);cursor:pointer;transition:var(--t-fast);font-size:13px;color:var(--text-2)}
.wallet-item:hover{border-color:rgba(108,99,255,.4);background:var(--surface-hover)}
.wallet-item.selected{border-color:var(--primary);background:rgba(108,99,255,.1);color:var(--text-1)}
.wl{font-size:24px}
.secure-note{display:flex;align-items:center;justify-content:center;gap:5px;font-size:11px;color:var(--text-3);margin-top:10px}

/* ═══════════════════════════════════════
   FULL DASHBOARD
═══════════════════════════════════════ */
.full-dash-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px;flex-wrap:wrap;gap:12px}
.full-dash-status{display:flex;align-items:center;gap:10px}
.status-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}
.active-dot{background:var(--success);box-shadow:0 0 8px rgba(34,197,94,.6);animation:blink 2s ease-in-out infinite}
@keyframes blink{0%,100%{opacity:1}50%{opacity:.4}}
.status-label{font-size:13px;color:var(--text-2)}
.merchant-id-tag{font-family:var(--mono);font-size:12px;padding:4px 10px;background:rgba(108,99,255,.12);border:1px solid rgba(108,99,255,.25);border-radius:20px;color:var(--primary-lt)}

.success-activation{display:flex;align-items:center;gap:16px;padding:16px 20px;background:linear-gradient(90deg,rgba(34,197,94,.1),rgba(59,130,246,.07));border:1px solid rgba(34,197,94,.2);border-radius:var(--r-md);margin-bottom:20px}
.sa-icon{font-size:32px;flex-shrink:0}
.success-activation h3{font-size:15px;font-weight:700;color:#4ade80;margin-bottom:4px}
.success-activation p{font-size:13px;color:var(--text-2);line-height:1.5}

.kpi-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin-bottom:20px}
.kpi-card{display:flex;align-items:center;gap:14px;padding:16px;background:rgba(0,0,0,.15);border:1px solid var(--border);border-radius:var(--r-md)}
.kpi-icon{font-size:26px;flex-shrink:0}
.kpi-val{font-size:18px;font-weight:800;color:var(--text-1)}
.kpi-label{font-size:11px;color:var(--text-3);margin-top:2px}

.quick-access{margin-top:4px}
.qa-title{font-size:14px;font-weight:700;color:var(--text-2);margin-bottom:12px}
.qa-grid{display:grid;grid-template-columns:repeat(8,1fr);gap:8px}
.qa-item{display:flex;flex-direction:column;align-items:center;gap:7px;padding:14px 8px;background:var(--surface);border:1px solid var(--border);border-radius:var(--r-md);text-decoration:none;color:var(--text-2);font-size:11px;font-weight:500;transition:var(--t-fast)}
.qa-item:hover{border-color:rgba(108,99,255,.4);background:var(--surface-hover);color:var(--text-1);transform:translateY(-2px)}
.qa-item span:first-child{font-size:22px}

/* ═══════════════════════════════════════
   MODAL
═══════════════════════════════════════ */
.modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,.72);backdrop-filter:blur(8px);z-index:100;display:flex;align-items:center;justify-content:center;padding:20px;animation:fadeIn .2s both}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}
.modal{max-width:420px;width:100%;position:relative;animation:slideUp .3s both}
@keyframes slideUp{from{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}
.modal-close{position:absolute;top:14px;right:14px;background:none;border:none;color:var(--text-3);font-size:15px;cursor:pointer;padding:4px}
.modal-title{font-size:18px;font-weight:700;margin-bottom:10px}
.modal-body{font-size:14px;color:var(--text-2);line-height:1.65;margin-bottom:18px}
.expired-modal-content{text-align:center}
.exp-icon{font-size:52px;margin-bottom:14px}

/* ═══════════════════════════════════════
   TOAST
═══════════════════════════════════════ */
.toast-container{position:fixed;bottom:24px;right:24px;z-index:200;display:flex;flex-direction:column;gap:8px}
.toast{display:flex;align-items:center;gap:9px;padding:11px 16px;background:rgba(18,18,28,.95);border-radius:var(--r-md);border:1px solid var(--border);backdrop-filter:blur(16px);font-size:13px;font-weight:500;color:var(--text-1);box-shadow:0 8px 32px rgba(0,0,0,.5);animation:slideInR .3s both;min-width:240px}
.toast.success{border-color:rgba(34,197,94,.35)}
.toast.error{border-color:rgba(239,68,68,.35)}
.toast.info{border-color:rgba(59,130,246,.35)}
.toast.warn{border-color:rgba(245,158,11,.35)}
@keyframes slideInR{from{transform:translateX(100%);opacity:0}to{transform:translateX(0);opacity:1}}
.toast-out{animation:slideOutR .3s both}
@keyframes slideOutR{from{transform:translateX(0);opacity:1}to{transform:translateX(100%);opacity:0}}

/* ═══════════════════════════════════════
   RESPONSIVE
═══════════════════════════════════════ */
@media(max-width:900px){
  .packages-grid{grid-template-columns:1fr}
  .trial-info-grid{grid-template-columns:1fr}
  .kpi-grid{grid-template-columns:1fr 1fr}
  .qa-grid{grid-template-columns:repeat(4,1fr)}
  .apidoc-layout{grid-template-columns:1fr}
   .apidoc-sidebar{border-right:none;border-bottom:1px solid var(--border)}
  .trial-dash-header{flex-direction:column}
}
@media(max-width:600px){
  .step-label{font-size:9px}.step-circle{width:34px;height:34px;font-size:13px}
  .glass-card{padding:24px 18px;border-radius:var(--r-lg)}
  .otp-box{width:42px;height:52px;font-size:20px}
  .stats-bar{grid-template-columns:1fr 1fr;grid-template-rows:auto auto}
  .stat-divider{display:none}
  .kpi-grid{grid-template-columns:1fr 1fr}
  .qa-grid{grid-template-columns:repeat(4,1fr)}
  .two-col{grid-template-columns:1fr}
  .wallet-grid{flex-direction:column}
}
