@import url('https://fonts.googleapis.com/css2?family=Plus+Jakarta+Sans:wght@400;500;600;700;800&family=Inter:wght@400;500;600&display=swap');

:root {
    --font-primary: 'Plus Jakarta Sans', system-ui, sans-serif;
    --font-body: 'Inter', system-ui, sans-serif;
    --primary: #2563eb;
    --primary-dark: #1d4ed8;
    --primary-light: #dbeafe;
    --primary-2: #7c3aed;
    --success: #16a34a;
    --success-light: #dcfce7;
    --warning: #d97706;
    --warning-light: #fef3c7;
    --danger: #dc2626;
    --danger-light: #fee2e2;
    --info: #0891b2;
    --info-light: #cffafe;
    --bg-page: #f1f5f9;
    --bg-card: #ffffff;
    --bg-sidebar: #0f172a;
    --bg-topbar: #0f172a;
    --bg-input: #ffffff;
    --bg-hover: #f8fafc;
    --bg-code: #f1f5f9;
    --text-primary: #0f172a;
    --text-secondary: #475569;
    --text-muted: #94a3b8;
    --text-inverse: #ffffff;
    --border: #e2e8f0;
    --border-light: rgba(148,163,184,.12);
    --shadow-sm: 0 1px 3px rgba(0,0,0,.06), 0 1px 2px rgba(0,0,0,.04);
    --shadow: 0 4px 16px rgba(0,0,0,.08), 0 2px 6px rgba(0,0,0,.04);
    --shadow-md: 0 10px 32px rgba(0,0,0,.1), 0 4px 12px rgba(0,0,0,.05);
    --shadow-lg: 0 20px 60px rgba(0,0,0,.12), 0 8px 24px rgba(0,0,0,.06);
    --shadow-primary: 0 8px 24px rgba(37,99,235,.28);
    --shadow-card-hover: 0 16px 40px rgba(0,0,0,.14);
    --kanban-novo: #3b82f6;
    --kanban-atendimento: #f59e0b;
    --kanban-aprovado: #8b5cf6;
    --kanban-ativado: #10b981;
    --kanban-sem_cobertura: #64748b;
    --kanban-recusado: #ef4444;
    --kanban-inadimplente: #f97316;
    --transition: .18s cubic-bezier(.4,0,.2,1);
    --transition-slow: .35s cubic-bezier(.4,0,.2,1);
    --radius-sm: .5rem;
    --radius: .875rem;
    --radius-lg: 1.25rem;
    --radius-xl: 1.75rem;
    --radius-full: 999px;
    --sidebar-w: 272px;
}

[data-theme="dark"] {
    --bg-page: #0c0f1a;
    --bg-card: #141929;
    --bg-sidebar: #080c17;
    --bg-topbar: #080c17;
    --bg-input: #1e2540;
    --bg-hover: #1a2035;
    --bg-code: #0f1624;
    --text-primary: #f1f5f9;
    --text-secondary: #94a3b8;
    --text-muted: #64748b;
    --border: rgba(148,163,184,.12);
    --shadow: 0 4px 16px rgba(0,0,0,.4);
    --shadow-md: 0 10px 32px rgba(0,0,0,.45);
    --shadow-lg: 0 20px 60px rgba(0,0,0,.5);
    --shadow-card-hover: 0 16px 40px rgba(0,0,0,.55);
    --primary-light: rgba(37,99,235,.18);
    --success-light: rgba(22,163,74,.18);
    --warning-light: rgba(217,119,6,.18);
    --danger-light: rgba(220,38,38,.18);
    --info-light: rgba(8,145,178,.18);
}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{font-size:16px;-webkit-tap-highlight-color:transparent;scroll-behavior:smooth}
body{font-family:var(--font-body);background:var(--bg-page);color:var(--text-primary);line-height:1.6;min-height:100vh;transition:background var(--transition-slow),color var(--transition-slow)}
a{color:var(--primary);text-decoration:none;transition:color var(--transition)}
a:hover{color:var(--primary-dark)}

/* LAYOUT */
.app-body{display:flex;min-height:100vh}
.app-sidebar{width:var(--sidebar-w);background:var(--bg-sidebar);color:#fff;display:flex;flex-direction:column;position:fixed;top:0;left:0;bottom:0;z-index:1040;overflow-y:auto;overflow-x:hidden;transition:transform var(--transition-slow),background var(--transition-slow);box-shadow:4px 0 20px rgba(0,0,0,.25)}
.app-sidebar::-webkit-scrollbar{width:4px}
.app-sidebar::-webkit-scrollbar-thumb{background:rgba(255,255,255,.08);border-radius:4px}
.sidebar-logo{padding:1.5rem 1.25rem 1rem;border-bottom:1px solid rgba(255,255,255,.06)}
.sidebar-logo-badge{display:inline-flex;align-items:center;gap:.5rem;background:linear-gradient(135deg,rgba(37,99,235,.35),rgba(124,58,237,.35));border:1px solid rgba(255,255,255,.1);border-radius:var(--radius-full);padding:.4rem .85rem;font-size:.78rem;font-weight:700;letter-spacing:.04em;font-family:var(--font-primary);color:#fff}
.sidebar-logo-badge i{font-size:1rem;color:#60a5fa}
.sidebar-logo-title{font-family:var(--font-primary);font-size:1.15rem;font-weight:800;color:#fff;margin-top:.75rem;margin-bottom:.15rem;letter-spacing:-.02em}
.sidebar-logo-sub{font-size:.78rem;color:rgba(255,255,255,.45)}
.sidebar-nav-section{padding:1.25rem 1rem .5rem}
.sidebar-nav-label{font-size:.68rem;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:rgba(255,255,255,.3);padding:0 .25rem;margin-bottom:.5rem;display:block}
.sidebar-nav{display:flex;flex-direction:column;gap:2px}
.sidebar-nav .nav-link{display:flex;align-items:center;gap:.8rem;padding:.7rem 1rem;border-radius:var(--radius);color:rgba(255,255,255,.65);font-weight:600;font-size:.875rem;font-family:var(--font-primary);border:1px solid transparent;transition:all var(--transition);position:relative;overflow:hidden}
.sidebar-nav .nav-link::before{content:'';position:absolute;left:0;top:50%;transform:translateY(-50%);width:3px;height:0;border-radius:0 2px 2px 0;background:#60a5fa;transition:height var(--transition)}
.sidebar-nav .nav-link i{font-size:1rem;width:1.15rem;text-align:center;flex-shrink:0;transition:transform var(--transition)}
.sidebar-nav .nav-link:hover{color:#fff;background:rgba(255,255,255,.07);border-color:rgba(255,255,255,.05);transform:translateX(3px)}
.sidebar-nav .nav-link:hover i{transform:scale(1.1)}
.sidebar-nav .nav-link.active{color:#fff;background:linear-gradient(135deg,rgba(37,99,235,.35),rgba(124,58,237,.25));border-color:rgba(96,165,250,.2);box-shadow:0 4px 12px rgba(37,99,235,.15)}
.sidebar-nav .nav-link.active::before{height:65%}
.sidebar-nav .nav-link.active i{color:#60a5fa}
.sidebar-user{margin:auto 1rem 1rem;padding:.875rem 1rem;border-radius:var(--radius);background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.07)}
.sidebar-user-name{font-size:.875rem;font-weight:700;color:#fff;font-family:var(--font-primary)}
.sidebar-user-email{font-size:.75rem;color:rgba(255,255,255,.4)}
.sidebar-user-role{font-size:.7rem;font-weight:700;padding:.2rem .6rem;border-radius:var(--radius-full);background:rgba(37,99,235,.25);color:#93c5fd;display:inline-block;margin-top:.3rem}
.dark-toggle-wrap{padding:.5rem 1rem}
.dark-toggle{display:flex;align-items:center;justify-content:space-between;padding:.6rem .875rem;border-radius:var(--radius);background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.06);cursor:pointer;transition:background var(--transition)}
.dark-toggle:hover{background:rgba(255,255,255,.08)}
.dark-toggle-label{font-size:.8rem;color:rgba(255,255,255,.55);display:flex;align-items:center;gap:.5rem}
.dark-toggle-switch{width:36px;height:20px;background:rgba(255,255,255,.12);border-radius:var(--radius-full);position:relative;transition:background var(--transition)}
.dark-toggle-switch::after{content:'';position:absolute;top:2px;left:2px;width:16px;height:16px;border-radius:50%;background:rgba(255,255,255,.5);transition:transform var(--transition),background var(--transition)}
[data-theme="dark"] .dark-toggle-switch{background:rgba(37,99,235,.5)}
[data-theme="dark"] .dark-toggle-switch::after{transform:translateX(16px);background:#60a5fa}
.app-main{margin-left:var(--sidebar-w);flex:1;display:flex;flex-direction:column;min-width:0;transition:margin-left var(--transition-slow)}
.app-topbar{background:var(--bg-topbar);padding:.75rem 1.5rem;display:flex;align-items:center;gap:1rem;position:sticky;top:0;z-index:100;border-bottom:1px solid rgba(255,255,255,.05);box-shadow:0 2px 16px rgba(0,0,0,.2);transition:background var(--transition-slow);min-height:60px}
.topbar-title{font-family:var(--font-primary);font-size:1rem;font-weight:700;color:#fff}
.topbar-sub{font-size:.75rem;color:rgba(255,255,255,.4)}
.topbar-actions{margin-left:auto;display:flex;align-items:center;gap:.75rem}
.topbar-user{font-size:.82rem;color:rgba(255,255,255,.55);font-weight:500}
.btn-topbar-menu{background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.1);color:#fff;padding:.45rem .7rem;border-radius:var(--radius);font-size:1.1rem;line-height:1;cursor:pointer;transition:background var(--transition);display:none}
.btn-topbar-menu:hover{background:rgba(255,255,255,.14)}
.page-shell{padding:1.75rem 2rem;max-width:1680px}
.page-shell--full{padding:0;max-width:none;width:100%;height:100%;display:flex;flex-direction:column;flex:1}
.page-shell--full > :last-child{flex:1;min-height:0}
.page-header{margin-bottom:1.75rem;animation:fadeInDown .35s ease}
.page-title{font-family:var(--font-primary);font-size:1.6rem;font-weight:800;color:var(--text-primary);letter-spacing:-.03em;line-height:1.2;transition:color var(--transition-slow)}
.page-subtitle{color:var(--text-muted);font-size:.9rem;margin-top:.3rem}

/* CARDS */
.card-modern{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow);overflow:hidden;transition:background var(--transition-slow),border-color var(--transition-slow),box-shadow var(--transition),transform var(--transition)}
.card-modern:hover{box-shadow:var(--shadow-card-hover)}
.card-modern-header{background:var(--bg-card);border-bottom:1px solid var(--border);padding:1.1rem 1.35rem;display:flex;align-items:center;transition:background var(--transition-slow),border-color var(--transition-slow)}
.card-modern-header strong{font-family:var(--font-primary);font-size:.95rem;font-weight:700;color:var(--text-primary);transition:color var(--transition-slow)}

/* STAT CARDS */
.stat-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow);padding:1.35rem;display:flex;align-items:center;gap:1rem;transition:all var(--transition);animation:fadeInUp .4s ease both;cursor:default}
.stat-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-md)}
.stat-card:nth-child(1){animation-delay:.05s}
.stat-card:nth-child(2){animation-delay:.1s}
.stat-card:nth-child(3){animation-delay:.15s}
.stat-card:nth-child(4){animation-delay:.2s}
.stat-icon{width:54px;height:54px;border-radius:var(--radius);display:grid;place-items:center;font-size:1.3rem;color:#fff;flex-shrink:0}
.metric-gradient-blue{background:linear-gradient(135deg,#2563eb,#0ea5e9)}
.metric-gradient-green{background:linear-gradient(135deg,#16a34a,#22c55e)}
.metric-gradient-amber{background:linear-gradient(135deg,#d97706,#f59e0b)}
.metric-gradient-rose{background:linear-gradient(135deg,#be185d,#fb7185)}
.metric-gradient-purple{background:linear-gradient(135deg,#7c3aed,#a78bfa)}
.metric-gradient-cyan{background:linear-gradient(135deg,#0891b2,#22d3ee)}
.stat-label{font-size:.75rem;font-weight:700;letter-spacing:.05em;text-transform:uppercase;color:var(--text-muted);font-family:var(--font-primary)}
.stat-value{font-family:var(--font-primary);font-size:1.85rem;font-weight:800;line-height:1.1;color:var(--text-primary);letter-spacing:-.03em;margin:.2rem 0}
.stat-foot{font-size:.8rem;color:var(--text-muted)}

/* BUTTONS */
.btn{font-family:var(--font-primary);font-weight:700;border-radius:var(--radius);transition:all var(--transition);font-size:.875rem}
.btn-primary{background:linear-gradient(135deg,#2563eb,#7c3aed);border:none;color:#fff;box-shadow:var(--shadow-primary)}
.btn-primary:hover{background:linear-gradient(135deg,#1d4ed8,#6d28d9);transform:translateY(-1px);box-shadow:0 12px 28px rgba(37,99,235,.4);color:#fff}
.btn-primary:active{transform:translateY(0)}
.btn-outline-primary{border-color:var(--border);color:var(--primary);background:transparent}
.btn-outline-primary:hover{background:var(--primary-light);color:var(--primary-dark);border-color:rgba(37,99,235,.4)}
.btn-sm{font-size:.8rem;padding:.35rem .8rem;border-radius:var(--radius-sm)}
.btn-lg{padding:.875rem 1.5rem;font-size:.975rem}
.btn-icon{width:36px;height:36px;padding:0;display:inline-grid;place-items:center;border-radius:var(--radius)}
.btn-success{background:#16a34a;border:none;box-shadow:0 6px 18px rgba(22,163,74,.3)}
.btn-success:hover{background:#15803d;transform:translateY(-1px);color:#fff}
.btn-danger{background:#dc2626;border:none}
.btn-danger:hover{background:#b91c1c;transform:translateY(-1px);color:#fff}

/* FORMS */
.form-control,.form-select{background:var(--bg-input);border:1px solid var(--border);color:var(--text-primary);border-radius:var(--radius);font-family:var(--font-body);font-size:.9rem;transition:all var(--transition);padding:.6rem 1rem}
.form-control:focus,.form-select:focus{background:var(--bg-input);border-color:var(--primary);color:var(--text-primary);box-shadow:0 0 0 3px rgba(37,99,235,.15)}
.form-control::placeholder{color:var(--text-muted)}
.form-label{font-size:.82rem;font-weight:700;letter-spacing:.02em;color:var(--text-secondary);margin-bottom:.45rem;font-family:var(--font-primary);display:flex;align-items:center;gap:.35rem;transition:color var(--transition-slow)}
.form-control-lg,.form-select-lg{padding:.8rem 1.1rem;font-size:.95rem;border-radius:var(--radius)}
.input-group .input-group-text{background:var(--bg-input);border-color:var(--border);color:var(--text-muted);border-radius:var(--radius) 0 0 var(--radius);transition:background var(--transition-slow),border-color var(--transition-slow)}
.input-group>.form-control{border-radius:0}
.input-group>.btn{border-radius:0 var(--radius) var(--radius) 0}
.form-text{font-size:.78rem;color:var(--text-muted)}

/* BADGES */
.badge{font-family:var(--font-primary);font-weight:700;font-size:.72rem;letter-spacing:.03em;padding:.3rem .7rem;border-radius:var(--radius-full)}
.badge-status-novo{background:rgba(59,130,246,.15);color:#3b82f6}
.badge-status-atendimento{background:rgba(245,158,11,.15);color:#d97706}
.badge-status-aprovado{background:rgba(139,92,246,.15);color:#8b5cf6}
.badge-status-ativado{background:rgba(16,185,129,.15);color:#10b981}
.badge-status-sem_cobertura{background:rgba(100,116,139,.15);color:#64748b}
.badge-status-recusado{background:rgba(239,68,68,.15);color:#ef4444}
.badge-status-inadimplente{background:rgba(249,115,22,.15);color:#f97316}

/* TABLES */
.table{color:var(--text-primary);border-color:var(--border);font-size:.875rem;transition:color var(--transition-slow)}
.table>:not(caption)>*>*{padding:.95rem 1rem;background-color:transparent;border-bottom-color:var(--border);transition:background-color var(--transition-slow),border-color var(--transition-slow)}
.table thead th{font-size:.72rem;font-weight:800;text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted);font-family:var(--font-primary);background:transparent;border-bottom:2px solid var(--border)!important;white-space:nowrap}
.table-hover tbody tr:hover{background-color:var(--bg-hover)}
.table-responsive{border-radius:var(--radius);overflow-x:auto;overflow-y:hidden;-webkit-overflow-scrolling:touch;display:block;width:100%;max-width:100%}

/* ALERTS */
.alert{border-radius:var(--radius);border:1px solid;font-size:.88rem;font-weight:500;animation:slideDown .3s ease}
.alert-success{background:var(--success-light);border-color:rgba(22,163,74,.2);color:#15803d}
.alert-danger{background:var(--danger-light);border-color:rgba(220,38,38,.2);color:#b91c1c}
.alert-warning{background:var(--warning-light);border-color:rgba(217,119,6,.2);color:#92400e}
.alert-info{background:var(--info-light);border-color:rgba(8,145,178,.2);color:#0e7490}
[data-theme="dark"] .alert-success{color:#86efac}
[data-theme="dark"] .alert-danger{color:#fca5a5}
[data-theme="dark"] .alert-warning{color:#fde68a}
[data-theme="dark"] .alert-info{color:#a5f3fc}

/* TOAST */
.toast{background:#0f172a;color:#fff;border-radius:var(--radius);box-shadow:var(--shadow-lg);border:1px solid rgba(255,255,255,.07);font-size:.875rem;font-weight:600;font-family:var(--font-primary)}
[data-theme="dark"] .toast{background:#1e293b}

/* AUTH PAGES */
.auth-shell{min-height:100vh;background:radial-gradient(ellipse at top,rgba(59,130,246,.22) 0%,transparent 35%),linear-gradient(180deg,#0a0f1e 0%,#0f172a 100%);display:flex;align-items:center;justify-content:center;padding:2rem 1rem}
.auth-panel{width:100%;max-width:1100px;display:flex;border-radius:var(--radius-xl);overflow:hidden;box-shadow:var(--shadow-lg)}
.auth-hero{flex:0 0 45%;background:linear-gradient(145deg,rgba(15,23,42,.97) 0%,rgba(37,99,235,.85) 100%);padding:3rem;position:relative;overflow:hidden;display:flex;flex-direction:column;justify-content:space-between;color:#fff}
.auth-hero::before{content:'';position:absolute;inset:0;background:radial-gradient(circle at top right,rgba(255,255,255,.12) 0%,transparent 30%),radial-gradient(circle at bottom left,rgba(34,197,94,.12) 0%,transparent 25%);pointer-events:none}
.auth-hero-badge{display:inline-flex;align-items:center;gap:.5rem;background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.15);border-radius:var(--radius-full);padding:.5rem 1rem;font-size:.8rem;font-weight:700;font-family:var(--font-primary)}
.auth-hero h1{font-family:var(--font-primary);font-size:2rem;font-weight:800;line-height:1.2;letter-spacing:-.03em;margin:1.25rem 0 .75rem}
.auth-hero p{color:rgba(255,255,255,.7);font-size:.95rem}
.auth-hero-list{list-style:none;display:flex;flex-direction:column;gap:.875rem;padding:0;margin:0}
.auth-hero-list li{display:flex;align-items:flex-start;gap:.75rem;color:rgba(255,255,255,.85);font-size:.88rem}
.auth-hero-list li i{color:#86efac;font-size:1.05rem;margin-top:.1rem;flex-shrink:0}
.auth-card{flex:1;background:#fff;padding:3rem;display:flex;flex-direction:column;justify-content:center;transition:background var(--transition-slow)}
[data-theme="dark"] .auth-card{background:#111827}
.auth-brand{font-size:.75rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--primary);margin-bottom:.75rem;font-family:var(--font-primary)}
.auth-title{font-family:var(--font-primary);font-size:1.75rem;font-weight:800;letter-spacing:-.03em;color:#0f172a;margin-bottom:.35rem}
[data-theme="dark"] .auth-title{color:#f9fafb}
.auth-subtitle{color:#6b7280;font-size:.9rem}
.auth-card .form-control{background:#f9fafb;border-color:#e5e7eb;color:#111827}
[data-theme="dark"] .auth-card .form-control{background:#1f2937;border-color:#374151;color:#f9fafb}
.auth-card .form-label{color:#374151}
[data-theme="dark"] .auth-card .form-label{color:#9ca3af}
.auth-card .input-group-text{background:#f9fafb;border-color:#e5e7eb}
[data-theme="dark"] .auth-card .input-group-text{background:#1f2937;border-color:#374151;color:#9ca3af}

/* CHECKOUT */
.checkout-wrapper{min-height:100vh;background:radial-gradient(ellipse at top,rgba(59,130,246,.2) 0%,transparent 35%),linear-gradient(180deg,#0a0f1e 0%,#0f172a 100%);display:flex;align-items:center;justify-content:center;padding:2rem 1rem}
.checkout-container{width:100%;max-width:1000px}
.checkout-panel{display:flex;border-radius:var(--radius-xl);overflow:hidden;box-shadow:var(--shadow-lg)}
.checkout-hero{flex:0 0 40%;background:linear-gradient(145deg,rgba(15,23,42,.97) 0%,rgba(37,99,235,.85) 100%);padding:3rem 2.5rem;color:#fff;display:flex;flex-direction:column;gap:2rem;position:relative;overflow:hidden}
.checkout-hero::after{content:'';position:absolute;bottom:-80px;right:-80px;width:220px;height:220px;border-radius:50%;background:radial-gradient(circle,rgba(124,58,237,.3),transparent);pointer-events:none}
.checkout-form-wrap{flex:1;background:#fff;padding:2.5rem;overflow:hidden;transition:background var(--transition-slow)}
[data-theme="dark"] .checkout-form-wrap{background:#111827}
.checkout-form-wrap .form-control,.checkout-form-wrap .form-select{background:#f9fafb;border-color:#e5e7eb;color:#111827}
[data-theme="dark"] .checkout-form-wrap .form-control,[data-theme="dark"] .checkout-form-wrap .form-select{background:#1f2937;border-color:#374151;color:#f9fafb}
.checkout-form-wrap .form-label{color:#374151}
[data-theme="dark"] .checkout-form-wrap .form-label{color:#9ca3af}

/* Progress steps */
.checkout-progress{display:flex;align-items:center;gap:0;margin-bottom:2rem}
.checkout-step-dot{display:flex;flex-direction:column;align-items:center;gap:.35rem}
.checkout-step-circle{width:36px;height:36px;border-radius:50%;border:2px solid #e5e7eb;background:#fff;display:grid;place-items:center;font-size:.8rem;font-weight:800;color:#9ca3af;font-family:var(--font-primary);transition:all var(--transition);position:relative;z-index:1}
[data-theme="dark"] .checkout-step-circle{background:#1f2937;border-color:#374151;color:#6b7280}
.checkout-step-label{font-size:.7rem;font-weight:700;color:#9ca3af;white-space:nowrap;font-family:var(--font-primary)}
.checkout-step-dot.is-active .checkout-step-circle{border-color:var(--primary);background:var(--primary);color:#fff;box-shadow:0 4px 14px rgba(37,99,235,.4);transform:scale(1.1)}
.checkout-step-dot.is-active .checkout-step-label{color:var(--primary)}
.checkout-step-dot.is-done .checkout-step-circle{border-color:#16a34a;background:#16a34a;color:#fff}
.checkout-step-dot.is-done .checkout-step-label{color:#16a34a}
.checkout-progress-line{flex:1;height:2px;background:#e5e7eb;border-radius:2px;margin-bottom:1.2rem}
[data-theme="dark"] .checkout-progress-line{background:#374151}

/* Plan cards */
.plan-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:.875rem}
.plan-card{background:#fff;border:2px solid #e5e7eb;border-radius:var(--radius-lg);padding:1.25rem;cursor:pointer;transition:all var(--transition);position:relative;overflow:hidden}
[data-theme="dark"] .plan-card{background:#1f2937;border-color:#374151}
.plan-card::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,#2563eb,#7c3aed);opacity:0;transition:opacity var(--transition)}
.plan-card:hover{border-color:rgba(37,99,235,.35);box-shadow:0 8px 24px rgba(37,99,235,.1);transform:translateY(-2px)}
.plan-card:hover::before{opacity:1}
.plan-card.is-selected{border-color:#2563eb;box-shadow:0 0 0 3px rgba(37,99,235,.15),0 8px 24px rgba(37,99,235,.12);background:#eff6ff}
[data-theme="dark"] .plan-card.is-selected{background:rgba(37,99,235,.15)}
.plan-card.is-selected::before{opacity:1}
.plan-card-check-icon{position:absolute;top:.75rem;right:.75rem;width:22px;height:22px;border-radius:50%;border:2px solid #e5e7eb;background:#fff;display:grid;place-items:center;transition:all var(--transition);font-size:.7rem;color:transparent}
[data-theme="dark"] .plan-card-check-icon{background:#1f2937;border-color:#374151}
.plan-card.is-selected .plan-card-check-icon{background:#2563eb;border-color:#2563eb;color:#fff}
.plan-card-speed{font-family:var(--font-primary);font-size:1.6rem;font-weight:800;color:#2563eb;line-height:1;letter-spacing:-.04em}
.plan-card-name{font-weight:700;font-family:var(--font-primary);color:#111827;margin-bottom:.2rem;font-size:.9rem}
[data-theme="dark"] .plan-card-name{color:#f9fafb}
.plan-card-price{font-family:var(--font-primary);font-size:1.05rem;font-weight:800;color:#0f172a;margin-top:.65rem}
[data-theme="dark"] .plan-card-price{color:#f1f5f9}
.plan-card-price small{font-size:.7rem;font-weight:600;color:#6b7280}
.plan-card-desc{font-size:.78rem;color:#6b7280;margin-top:.3rem;line-height:1.4;white-space:pre-line}
.plan-card-badge{display:inline-block;font-size:.65rem;font-weight:800;padding:.2rem .55rem;border-radius:var(--radius-full);background:#dbeafe;color:#2563eb;text-transform:uppercase;letter-spacing:.06em;margin-bottom:.5rem;font-family:var(--font-primary)}

.checkout-step-panel{display:none;animation:fadeInRight .3s ease}
.checkout-step-panel.is-active{display:block}

/* KANBAN */
.kanban-board{display:flex;gap:1rem;overflow-x:auto;padding-bottom:1.5rem;min-height:65vh}

.kanban-page{position:relative;padding-bottom:4.75rem}
.kanban-board{scrollbar-width:none;-ms-overflow-style:none}
.kanban-board::-webkit-scrollbar{height:0;width:0;display:none}
.kanban-scrollbar-fixed{position:fixed;left:var(--sidebar-w);right:0;bottom:0;z-index:1035;padding:.45rem .75rem .7rem;background:linear-gradient(180deg,rgba(255,255,255,0),var(--bg-main) 35%);backdrop-filter:blur(10px)}
[data-theme="dark"] .kanban-scrollbar-fixed{background:linear-gradient(180deg,rgba(15,23,42,0),var(--bg-main) 35%)}
.kanban-scrollbar-track{overflow-x:auto;overflow-y:hidden;height:18px;border-radius:999px;scrollbar-width:thin;scrollbar-color:var(--border) transparent}
.kanban-scrollbar-track::-webkit-scrollbar{height:12px}
.kanban-scrollbar-track::-webkit-scrollbar-thumb{background:var(--border);border-radius:999px}
.kanban-scrollbar-track::-webkit-scrollbar-track{background:transparent}
.kanban-scrollbar-spacer{height:1px;min-width:100%}
.kanban-scrollbar-track:focus-visible{outline:2px solid rgba(37,99,235,.35);outline-offset:2px}
@media (max-width: 991.98px){
    .kanban-scrollbar-fixed{left:0}
}
.kanban-column{flex:0 0 280px;background:var(--bg-code);border-radius:var(--radius-lg);border:1px solid var(--border);display:flex;flex-direction:column;overflow:hidden;transition:background var(--transition-slow),border-color var(--transition-slow)}
.kanban-column.is-drag-over{border-color:var(--primary);box-shadow:0 0 0 2px rgba(37,99,235,.2)}
.kanban-col-header{padding:.875rem 1rem;display:flex;align-items:center;gap:.6rem;border-bottom:2px solid}
.kanban-col-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}
.kanban-col-title{font-family:var(--font-primary);font-weight:800;font-size:.82rem;text-transform:uppercase;letter-spacing:.06em;color:var(--text-secondary);flex:1}
.kanban-col-count{font-size:.72rem;font-weight:800;width:22px;height:22px;border-radius:50%;display:grid;place-items:center;background:var(--border);color:var(--text-muted);font-family:var(--font-primary)}
.kanban-column[data-status="NOVO"] .kanban-col-header{border-color:#3b82f6}
.kanban-column[data-status="NOVO"] .kanban-col-dot{background:#3b82f6}
.kanban-column[data-status="ATENDIMENTO"] .kanban-col-header{border-color:#f59e0b}
.kanban-column[data-status="ATENDIMENTO"] .kanban-col-dot{background:#f59e0b}
.kanban-column[data-status="APROVADO"] .kanban-col-header{border-color:#8b5cf6}
.kanban-column[data-status="APROVADO"] .kanban-col-dot{background:#8b5cf6}
.kanban-column[data-status="ATIVADO"] .kanban-col-header{border-color:#10b981}
.kanban-column[data-status="ATIVADO"] .kanban-col-dot{background:#10b981}
.kanban-column[data-status="SEM_COBERTURA"] .kanban-col-header{border-color:#64748b}
.kanban-column[data-status="SEM_COBERTURA"] .kanban-col-dot{background:#64748b}
.kanban-column[data-status="RECUSADO"] .kanban-col-header{border-color:#ef4444}
.kanban-column[data-status="RECUSADO"] .kanban-col-dot{background:#ef4444}
.kanban-column[data-status="INADIMPLENTE"] .kanban-col-header{border-color:#f97316}
.kanban-column[data-status="INADIMPLENTE"] .kanban-col-dot{background:#f97316}
.kanban-cards{padding:.75rem;flex:1;display:flex;flex-direction:column;gap:.6rem;overflow-y:auto;min-height:80px}
.kanban-cards::-webkit-scrollbar{width:3px}
.kanban-cards::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}
.kanban-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:1rem;cursor:grab;transition:all var(--transition);box-shadow:var(--shadow-sm);user-select:none;animation:fadeInUp .25s ease both}
.kanban-card:hover{box-shadow:var(--shadow-md);border-color:rgba(37,99,235,.2);transform:translateY(-2px)}
.kanban-card.is-dragging{opacity:.5;cursor:grabbing;transform:scale(1.02);box-shadow:var(--shadow-lg)}
.kanban-card.drag-placeholder{background:rgba(37,99,246,.06);border-color:rgba(37,99,235,.2);border-style:dashed;min-height:80px}
.kanban-card-name{font-family:var(--font-primary);font-weight:800;font-size:.875rem;color:var(--text-primary);margin-bottom:.2rem}
.kanban-card-phone{font-size:.78rem;color:var(--text-muted)}
.kanban-card-plan{font-size:.75rem;font-weight:700;color:var(--text-secondary);background:var(--bg-hover);border-radius:var(--radius-sm);padding:.2rem .55rem;display:inline-block;margin-top:.45rem;border:1px solid var(--border)}
.kanban-card-loc{font-size:.73rem;color:var(--text-muted);margin-top:.3rem;display:flex;align-items:center;gap:.3rem}
.kanban-card-actions{display:flex;gap:.4rem;margin-top:.75rem;flex-wrap:wrap}
.kanban-card-actions .btn-sm{font-size:.72rem;padding:.28rem .65rem}
.kanban-card-note{font-size:.75rem;color:var(--text-secondary);background:var(--bg-hover);border-radius:var(--radius-sm);padding:.4rem .6rem;margin-top:.5rem;border-left:2px solid var(--border);font-style:italic}

/* COVERAGE TABS */
.coverage-tabs-nav{display:flex;gap:.5rem;flex-wrap:wrap;background:var(--bg-code);padding:.5rem;border-radius:var(--radius-lg);margin-bottom:1.5rem;border:1px solid var(--border)}
.coverage-tab-btn{flex:1;min-width:120px;padding:.6rem 1rem;border-radius:var(--radius);border:1px solid transparent;background:transparent;color:var(--text-muted);font-family:var(--font-primary);font-size:.82rem;font-weight:700;cursor:pointer;display:flex;align-items:center;gap:.5rem;transition:all var(--transition)}
.coverage-tab-btn:hover{background:var(--bg-card);color:var(--text-primary)}
.coverage-tab-btn.is-active{background:var(--primary);color:#fff;box-shadow:0 4px 12px rgba(37,99,235,.25)}
.coverage-tab-btn .tab-count{background:rgba(255,255,255,.25);color:#fff;font-size:.65rem;padding:.15rem .45rem;border-radius:var(--radius-full);font-weight:800}
.coverage-tab-btn:not(.is-active) .tab-count{background:var(--border);color:var(--text-muted)}
.coverage-panel{display:none;animation:fadeIn .25s ease}
.coverage-panel.is-active{display:block}
.coverage-tag{display:inline-flex;align-items:center;gap:.4rem;background:var(--bg-hover);border:1px solid var(--border);border-radius:var(--radius-full);padding:.3rem .75rem;font-size:.8rem;font-weight:600;color:var(--text-secondary);transition:all var(--transition)}
.coverage-tag:hover{border-color:rgba(220,38,38,.3)}
.coverage-tag-del{background:none;border:none;padding:0;cursor:pointer;color:var(--text-muted);font-size:.75rem;line-height:1;transition:color var(--transition)}
.coverage-tag-del:hover{color:var(--danger)}

/* PLAN ITEM */
.plan-item-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:1.25rem 1.35rem;display:flex;align-items:center;gap:1rem;transition:all var(--transition)}
.plan-item-card:hover{box-shadow:var(--shadow-md);border-color:rgba(37,99,235,.2)}
.plan-item-icon{width:44px;height:44px;border-radius:var(--radius);background:linear-gradient(135deg,rgba(37,99,235,.12),rgba(124,58,237,.12));display:grid;place-items:center;color:var(--primary);font-size:1.2rem;flex-shrink:0}
.plan-item-name{font-family:var(--font-primary);font-weight:800;font-size:.9rem;color:var(--text-primary)}
.plan-item-desc{font-size:.78rem;color:var(--text-muted);margin-top:.1rem;white-space:pre-line}
.plan-item-price{font-family:var(--font-primary);font-weight:800;color:var(--primary);font-size:1.05rem;white-space:nowrap}
.plan-item-comissao{font-size:.75rem;color:var(--success);font-weight:700}

/* MINI STEPS */
.mini-step{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:1.25rem;transition:all var(--transition);height:100%}
.mini-step:hover{box-shadow:var(--shadow-md);border-color:rgba(37,99,235,.2)}
.mini-step-icon{width:50px;height:50px;border-radius:var(--radius);background:linear-gradient(135deg,#2563eb,#7c3aed);display:grid;place-items:center;color:#fff;font-size:1.2rem;margin-bottom:.75rem}

/* LINK COPY */
.link-copy-box{background:var(--bg-code);border:1px dashed var(--border);border-radius:var(--radius);padding:.875rem 1rem;display:flex;align-items:center;gap:.75rem;transition:background var(--transition-slow),border-color var(--transition-slow)}
.link-copy-url{flex:1;font-size:.82rem;font-family:monospace;color:var(--text-secondary);word-break:break-all;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.link-copy-box:hover{border-color:var(--primary);background:var(--primary-light)}

/* EMPTY STATE */
.empty-state{text-align:center;padding:3rem 1rem;background:var(--bg-card);border:1px dashed var(--border);border-radius:var(--radius-lg);transition:background var(--transition-slow)}
.empty-state-icon{width:60px;height:60px;border-radius:var(--radius-lg);background:linear-gradient(135deg,#2563eb,#7c3aed);display:grid;place-items:center;color:#fff;font-size:1.4rem;margin:0 auto 1rem}
.empty-state h5{font-family:var(--font-primary);font-weight:800;color:var(--text-primary)}
.empty-state p{color:var(--text-muted);font-size:.875rem}

/* MODALS */
.modal-content{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-xl);box-shadow:var(--shadow-lg);color:var(--text-primary);transition:background var(--transition-slow)}
.modal-header{border-bottom:1px solid var(--border);padding:1.25rem 1.5rem}
.modal-title{font-family:var(--font-primary);font-weight:800;color:var(--text-primary)}
.modal-footer{border-top:1px solid var(--border)}
[data-theme="dark"] .btn-close{filter:invert(1)}

/* LOADING */
.loading-overlay{position:fixed;inset:0;z-index:9999;background:rgba(10,15,30,.65);backdrop-filter:blur(4px);display:none;align-items:center;justify-content:center;flex-direction:column;gap:.75rem}
.loading-overlay.is-visible{display:flex}
.loading-spinner{width:48px;height:48px;border-radius:50%;border:3px solid rgba(255,255,255,.12);border-top-color:#60a5fa;animation:spin .8s linear infinite}
.loading-text{color:rgba(255,255,255,.7);font-size:.875rem;font-weight:600;font-family:var(--font-primary)}

/* SIDEBAR OVERLAY */
.sidebar-overlay{display:none;position:fixed;inset:0;z-index:1039;background:rgba(0,0,0,.5);backdrop-filter:blur(2px)}
.sidebar-overlay.is-visible{display:block}

/* PLAN-CHECK (afiliado) */
.plan-check{display:flex;align-items:center;gap:.85rem;padding:.95rem 1rem;border-radius:var(--radius-lg);border:1px solid var(--border);background:var(--bg-card);cursor:pointer;transition:all var(--transition)}
.plan-check:hover,.plan-check.selected{border-color:rgba(37,99,235,.35);box-shadow:0 8px 20px rgba(37,99,235,.08)}
.plan-check.selected{background:var(--primary-light)}
.generated-link{padding:1rem;border-radius:var(--radius);background:var(--bg-code);border:1px dashed var(--border)}

/* ANIMATIONS */
@keyframes fadeIn{from{opacity:0}to{opacity:1}}
@keyframes fadeInUp{from{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}
@keyframes fadeInDown{from{opacity:0;transform:translateY(-12px)}to{opacity:1;transform:translateY(0)}}
@keyframes fadeInRight{from{opacity:0;transform:translateX(16px)}to{opacity:1;transform:translateX(0)}}
@keyframes slideDown{from{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}
@keyframes spin{to{transform:rotate(360deg)}}

/* RESPONSIVE */
@media(max-width:991.98px){
    .app-sidebar{transform:translateX(-100%);width:280px}
    .app-sidebar.is-open{transform:translateX(0)}
    .app-main{margin-left:0}
    .btn-topbar-menu{display:inline-flex}
    .checkout-hero{display:none}
    .checkout-panel{flex-direction:column}
    .auth-hero{display:none}
    .auth-panel{flex-direction:column}
    .auth-card{flex:none}
}
@media(max-width:767.98px){
    .page-shell{padding:1rem}
    .page-title{font-size:1.35rem}
    .stat-value{font-size:1.6rem}
    .kanban-column{flex:0 0 240px}
    .plan-grid{grid-template-columns:1fr 1fr}
    .checkout-form-wrap{padding:1.5rem}
    .auth-card{padding:2rem 1.5rem}
}
@media(max-width:479.98px){.plan-grid{grid-template-columns:1fr}}

/* SCROLLBAR */
@media(min-width:992px){
    ::-webkit-scrollbar{width:6px;height:6px}
    ::-webkit-scrollbar-track{background:transparent}
    ::-webkit-scrollbar-thumb{background:var(--border);border-radius:6px}
    ::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}
}

/* UTILITIES */
.text-muted{color:var(--text-muted)!important;transition:color var(--transition-slow)}
.fw-800{font-weight:800!important}
.badge-soft{box-shadow:0 4px 10px rgba(0,0,0,.08)}


/* RESPONSIVE TABLES */
.table-responsive-x{overflow-x:auto;-webkit-overflow-scrolling:touch;display:block;width:100%}
.table-responsive-x table{min-width:760px;width:100%}
.table-responsive table{min-width:760px;width:100%}

/* COVERAGE ALL TOGGLE */
.coverage-all-switch{display:flex;align-items:center;gap:.6rem;padding:.75rem .9rem;border:1px solid var(--border);border-radius:var(--radius);background:var(--bg-hover);margin-bottom:1rem}
.coverage-all-switch .form-check-input{margin-top:0}
