/* ===== RESET & BASE ===== */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  --bg:#fafafa;--fg:#1a2e1f;--card:#fff;--card-fg:#1a2e1f;
  --primary:hsl(73,80%,42%);--primary-fg:#fff;
  --muted:#edeeec;--muted-fg:#6b726a;
  --border:#e0e2dd;--destructive:#e53e3e;--destructive-fg:#fff;
  --status-available:#22c55e;--status-oncall:#3b82f6;--status-break:#eab308;
  --status-lunch:#f97316;--status-offline:#7b8794;
  --priority-hot:#e53e3e;--priority-warm:#f97316;--priority-medium:#ca8a04;--priority-low:#7b8794;
  --radius:2px;
}
body{font-family:'Inter',sans-serif;background:var(--bg);color:var(--fg);font-size:13px;overflow:hidden;height:100vh}
button{cursor:pointer;font-family:inherit;border:none;background:none;font-size:inherit}
input,textarea{font-family:inherit;font-size:inherit}
::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:var(--bg)}::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}

/* ===== LAYOUT ===== */
.app{display:flex;flex-direction:column;height:100vh;overflow:hidden}
.workspace{display:flex;flex:1;overflow:hidden}

/* ===== PANELS ===== */
.panel{background:var(--card);border:1px solid var(--border)}

/* ===== TOP BAR ===== */
.topbar{height:60px;background:var(--bg);border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;padding:0 16px;flex-shrink:0}
.topbar-left,.topbar-right{display:flex;align-items:center;gap:16px}
.topbar-center{display:flex;flex-direction:column;align-items:center}
.logo-box{width:28px;height:28px;background:var(--primary);border-radius:var(--radius);display:flex;align-items:center;justify-content:center}
.logo-box span{color:var(--primary-fg);font-weight:700;font-size:11px}
.brand-name{font-weight:600;font-size:14px;color:var(--fg)}
.divider{width:1px;height:32px;background:var(--border)}
.avatar{width:36px;height:36px;border-radius:50%;background:var(--muted);display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:600;color:var(--fg)}
.agent-info span{font-size:14px;font-weight:500;color:var(--fg);display:block}
.agent-meta{font-size:11px;color:var(--muted-fg)}
.status-btn{display:flex;align-items:center;gap:8px;padding:6px 12px;border:1px solid var(--border);border-radius:var(--radius);font-size:12px}
.status-btn:hover{border-color:var(--primary)}
.status-dot{width:8px;height:8px;border-radius:50%}
.dropdown{position:absolute;top:100%;left:0;margin-top:4px;background:var(--card);border:1px solid var(--border);border-radius:var(--radius);z-index:50;min-width:140px;box-shadow:0 4px 12px rgba(0,0,0,0.1)}
.dropdown button{width:100%;text-align:left;padding:8px 12px;font-size:12px;display:flex;align-items:center;gap:8px}
.dropdown button:hover{background:var(--muted)}
.campaign-badge{padding:6px 16px;background:var(--card);border:1px solid var(--primary);border-radius:var(--radius);font-weight:600;font-size:14px}
.dialer-line{font-size:11px;color:var(--muted-fg);margin-top:2px;display:flex;align-items:center;gap:4px}
.dialer-line strong{color:var(--fg);font-weight:500}
.stat-box{text-align:center}
.stat-box .val{font-size:15px;font-weight:600;display:block}
.stat-box .lbl{font-size:11px;color:var(--muted-fg);display:block}
.stat-box.conv .val{color:var(--primary);font-weight:700}
.icon-btn{width:36px;height:36px;display:flex;align-items:center;justify-content:center;border:1px solid var(--border);border-radius:var(--radius);color:var(--muted-fg)}
.icon-btn:hover{color:var(--primary);border-color:var(--primary)}
.logout-btn{font-size:12px;color:var(--muted-fg);display:flex;align-items:center;gap:4px;text-decoration:none}
.logout-btn:hover{color:var(--destructive)}

/* ===== FOOTER NAVIGATION ===== */
.footer-nav{
  display:none;
  height:60px;
  background:var(--card);
  border-top:1px solid var(--border);
  padding:0 8px;
  justify-content:space-around;
  align-items:center;
  flex-shrink:0;
}
.footer-nav-item{
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  padding:8px 12px;
  text-decoration:none;
  color:var(--muted-fg);
  border-radius:var(--radius);
  transition:all 0.15s;
  min-width:60px;
}
.footer-nav-item:hover{
  color:var(--primary);
  background:rgba(122,162,47,0.1);
}
.footer-nav-item.active{
  color:var(--primary);
  background:rgba(122,162,47,0.15);
}
.footer-nav-icon{font-size:18px;margin-bottom:2px;}
.footer-nav-label{font-size:10px;font-weight:500;}

/* Show footer nav on mobile, hide topbar elements */
@media (max-width: 768px) {
  /* Hide topbar and script entirely */
  .topbar{display:none !important;}
  .script-panel{display:none !important;}
  .footer-nav{display:none !important;}
  
  /* Full screen workspace */
  .app{height:100vh;height:100dvh;}
  .workspace{flex-direction:column;position:relative;height:100%;}
  body{overflow:hidden;}
  
  /* Lead queue = full screen view */
  .lead-queue{
    width:100%;min-width:unset;max-width:unset;
    position:absolute;inset:0;z-index:10;
    display:flex;flex-direction:column;
    border-right:none;
  }
  .lead-list{padding-bottom:56px;overflow-y:auto;-webkit-overflow-scrolling:touch;}
  .lead-card{padding:10px 12px;}
  .lq-header{padding:10px 12px 10px !important;}
  
  /* Center panel = full screen detail view */
  .center-panel{
    width:100%;
    position:absolute;inset:0;z-index:11;
    display:flex !important;flex-direction:column;
    transform:translateX(100%);
    transition:transform .2s ease;
    overflow-y:auto;-webkit-overflow-scrolling:touch;
    background:var(--bg);
    padding-bottom:56px;
  }
  .center-panel.mobile-active{transform:translateX(0);}
  .center-empty{display:none !important;}
  
  /* Mobile bottom nav */
  .mobile-view-nav{
    display:flex !important;
    position:fixed;bottom:0;left:0;right:0;z-index:100;
    background:var(--card);border-top:1px solid var(--border);
    padding:4px 0;padding-bottom:max(4px, env(safe-area-inset-bottom));
    box-shadow:0 -2px 8px rgba(0,0,0,.06);
  }
  .mobile-view-nav button{
    flex:1;display:flex;flex-direction:column;align-items:center;gap:1px;
    padding:4px 0;font-size:9px;font-weight:600;color:var(--muted-fg);
  }
  .mobile-view-nav button.active{color:var(--primary);}
  .mobile-view-nav button .mv-icon{font-size:18px;}
  
  /* Mobile detail nav bar */
  .mobile-detail-nav{display:flex !important;}
  
  /* Mobile call button sticky at bottom */
  #callControlArea{
    position:sticky !important;bottom:56px;z-index:5;
    padding:10px 12px !important;background:var(--bg);
    border-top:1px solid var(--border);
    margin:0 -12px !important;
  }
  
  /* Smaller fonts */
  .cust-name{font-size:15px !important;}
  .cust-phone{font-size:12px !important;}
  .info-grid{font-size:11px !important;}
  
  /* Dial popup */
  .dial-box{width:94vw !important;max-width:400px;}
  .dial-overlay{padding:12px;}
}

/* Hide mobile elements on desktop */
@media (min-width: 769px) {
  .mobile-view-nav{display:none !important;}
  .mobile-detail-nav{display:none !important;}
}

/* ===== LEAD QUEUE ===== */
.lead-queue{width:28%;min-width:280px;background:var(--card);border-right:1px solid var(--border);display:flex;flex-direction:column;height:100%}
.lq-header{padding:12px;border-bottom:1px solid var(--border);flex-shrink:0}
.lq-header-row{display:flex;justify-content:space-between;margin-bottom:8px}
.lq-title{font-size:13px;font-weight:700;letter-spacing:0.5px}
.lq-count{font-size:12px;color:var(--primary);font-weight:500}
.filter-tabs{display:flex;gap:6px;overflow-x:auto;padding-bottom:4px}
.filter-tabs::-webkit-scrollbar{display:none}
.filter-tab{font-size:11px;padding:4px 10px;border:1px solid var(--border);border-radius:var(--radius);white-space:nowrap;color:var(--muted-fg)}
.filter-tab.active{border-color:var(--primary);color:var(--primary)}
.filter-tab:hover{border-color:var(--muted-fg)}
.lead-list{flex:1;overflow-y:auto;padding:8px}
.lead-card{padding:12px;background:var(--bg);border:1px solid var(--border);border-radius:var(--radius);margin-bottom:8px;cursor:pointer;transition:border-color .15s}
.lead-card:hover{border-color:rgba(122,162,47,0.6)}
.lead-card.active{border-color:var(--primary);background:var(--card);border-left:4px solid var(--primary)}
.lead-card.hot-glow{box-shadow:0 0 12px 2px rgba(229,62,62,0.15)}
.lead-row{display:flex;justify-content:space-between;align-items:flex-start}
.lead-row+.lead-row{margin-top:4px}
.priority-badge{font-size:9px;font-weight:700;text-transform:uppercase;padding:2px 6px;border-radius:var(--radius)}
.priority-hot{background:rgba(229,62,62,0.2);color:var(--priority-hot)}
.priority-warm{background:rgba(249,115,22,0.2);color:var(--priority-warm)}
.priority-medium{background:rgba(202,138,4,0.2);color:var(--priority-medium)}
.priority-low{background:rgba(123,135,148,0.2);color:var(--priority-low)}
.lead-name{font-size:13px;font-weight:600;margin-left:8px}
.cart-val{color:var(--primary);font-size:14px;font-weight:700}
.lead-phone{font-size:12px;color:var(--muted-fg);font-family:monospace}
.lead-time{font-size:11px;color:var(--muted-fg)}
.lead-product{font-size:12px;color:var(--muted-fg);font-style:italic}
.lead-status{font-size:10px;padding:2px 6px;border:1px solid var(--border);border-radius:var(--radius);color:var(--primary)}

/* ===== CENTER PANEL ===== */
.center-panel{flex:1;background:var(--bg);display:flex;flex-direction:column;height:100%;overflow:hidden}

/* Pre-call */
.precall{flex:1;overflow-y:auto;padding:16px}
.precall .panel{padding:16px;margin-bottom:12px}
.cust-name{font-size:15px;font-weight:600}
.cust-phone{font-size:13px;font-family:monospace;color:var(--muted-fg)}
.cust-email{font-size:12px;color:var(--muted-fg)}
.cust-cart{font-size:18px;font-weight:700;color:var(--primary)}
.source-badge{font-size:10px;padding:2px 8px;border:1px solid var(--primary);border-radius:var(--radius);color:var(--primary)}
.info-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-top:12px;font-size:12px;color:var(--muted-fg)}
.info-grid .lbl{color:rgba(26,46,31,0.6)}
.accordion-header{width:100%;display:flex;align-items:center;justify-content:space-between;padding:12px;cursor:pointer}
.accordion-header:hover{background:rgba(0,0,0,0.02)}
.accordion-title{display:flex;align-items:center;gap:8px;font-size:13px;font-weight:600}
.accordion-body{padding:0 12px 12px;border-top:1px solid var(--border)}
.purchase-row{display:flex;justify-content:space-between;font-size:12px;font-family:monospace;color:var(--muted-fg);padding:4px 0;border-bottom:1px solid rgba(0,0,0,0.04)}
.dialer-info{display:flex;justify-content:space-between;align-items:center;padding:12px}
.action-btns{display:flex;gap:12px;padding-top:4px}
.btn-call{display:flex;align-items:center;gap:8px;background:var(--primary);color:var(--primary-fg);padding:12px 24px;border-radius:var(--radius);font-size:13px;font-weight:700}
.btn-call:hover{opacity:.9}
.btn-skip{display:flex;align-items:center;gap:8px;border:1px solid var(--primary);color:var(--primary);padding:12px 24px;border-radius:var(--radius);font-size:13px;font-weight:700}
.btn-skip:hover{background:rgba(122,162,47,0.1)}

/* Active call */
.activecall{flex:1;display:flex;flex-direction:column;padding:16px;gap:12px}
.call-header{display:flex;justify-content:space-between;align-items:center;padding:12px}
.call-status{font-size:12px;display:flex;align-items:center;gap:6px}
.call-timer{font-size:16px;font-weight:700;font-family:monospace}
.call-controls{display:flex;align-items:center;gap:8px;padding:12px}
.ctrl-btn{width:36px;height:36px;display:flex;align-items:center;justify-content:center;border:1px solid var(--border);border-radius:var(--radius);font-size:14px;transition:all .15s}
.ctrl-btn:hover{border-color:var(--primary)}
.ctrl-btn.active-mute{border-color:var(--destructive);color:var(--destructive)}
.ctrl-btn.active-hold{border-color:var(--status-break);color:var(--status-break)}
.btn-endcall{display:flex;align-items:center;gap:8px;padding:8px 16px;border:1px solid var(--destructive);color:var(--destructive);border-radius:var(--radius);font-size:12px;font-weight:700;margin-left:auto}
.btn-endcall:hover{background:rgba(229,62,62,0.1)}
.indicator{font-size:12px;font-weight:700;text-align:center}
.notes-area{flex:1;display:flex;flex-direction:column}
.notes-area label{font-size:12px;color:var(--muted-fg);margin-bottom:4px}
.notes-area textarea{flex:1;min-height:100px;background:var(--bg);border:1px solid var(--border);border-radius:var(--radius);padding:12px;font-size:13px;resize:none;color:var(--fg)}
.notes-area textarea:focus{outline:none;border-color:var(--primary)}
.call-info-compact{display:flex;gap:24px;padding:12px;font-size:12px;color:var(--muted-fg)}

/* Outcome */
.outcome{flex:1;overflow-y:auto;padding:16px}
.outcome h3{font-size:14px;font-weight:700;margin-bottom:12px}
.outcome-option{display:flex;align-items:center;gap:12px;padding:8px;border-radius:var(--radius);cursor:pointer}
.outcome-option:hover{background:rgba(0,0,0,0.02)}
.outcome-option.selected{background:rgba(0,0,0,0.04)}
.outcome-option input[type=radio]{accent-color:var(--primary)}
.outcome-option label{font-size:13px;font-weight:500;cursor:pointer}
.field-group{margin-top:4px}
.field-group label{font-size:12px;color:var(--muted-fg);display:block;margin-bottom:4px}
.field-group input,.field-group textarea{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius);padding:8px;font-size:13px;color:var(--fg);width:100%}
.field-group input:focus,.field-group textarea:focus{outline:none;border-color:var(--primary)}
.field-group textarea{height:80px;resize:none}
.btn-submit{width:100%;padding:12px;border-radius:var(--radius);font-size:13px;font-weight:700;margin-top:12px;transition:opacity .15s}
.btn-submit.enabled{background:var(--primary);color:var(--primary-fg);cursor:pointer}
.btn-submit.enabled:hover{opacity:.9}
.btn-submit.disabled{background:var(--muted);color:var(--muted-fg);opacity:.5;cursor:not-allowed}
.error-text{color:var(--destructive);font-size:11px;margin-top:2px}

/* ===== SCRIPT PANEL ===== */
.script-panel{width:25%;min-width:260px;background:var(--card);border-left:1px solid var(--border);display:flex;flex-direction:column;height:100%;flex-shrink:0}
.script-panel.collapsed{width:32px;min-width:32px;cursor:pointer;display:flex;align-items:center;justify-content:center}
.sp-header{padding:12px;border-bottom:1px solid var(--border);flex-shrink:0}
.sp-title{font-size:13px;font-weight:700;display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}
.sp-search{position:relative}
.sp-search input{width:100%;background:var(--bg);border:1px solid var(--border);border-radius:var(--radius);font-size:12px;padding:6px 8px 6px 28px;color:var(--fg)}
.sp-search input:focus{outline:none;border-color:var(--primary)}
.sp-search .search-icon{position:absolute;left:8px;top:50%;transform:translateY(-50%);font-size:12px;color:var(--muted-fg)}
.script-sections{flex:1;overflow-y:auto}
.script-section{border-bottom:1px solid var(--border)}
.script-section.compliance{border-left:2px solid var(--priority-warm)}
.section-header{width:100%;display:flex;justify-content:space-between;align-items:center;padding:10px 12px;font-size:12px;font-weight:600;cursor:pointer}
.section-header:hover{background:rgba(0,0,0,0.02)}
.section-body{padding:0 12px 12px;font-size:12px;color:rgba(26,46,31,0.8);line-height:1.6;white-space:pre-line}
.sub-header{display:flex;justify-content:space-between;align-items:center;padding:6px 0;cursor:pointer;font-size:12px;color:var(--muted-fg);font-style:italic}
.sub-header:hover{color:var(--primary)}
.sub-body{font-size:12px;color:rgba(26,46,31,0.8);line-height:1.6;padding-left:8px;border-left:1px solid rgba(122,162,47,0.3);margin:0 0 8px 4px}

/* ===== MODALS ===== */
.modal-overlay{position:fixed;inset:0;z-index:50;display:flex;align-items:center;justify-content:center;background:rgba(26,46,31,0.2);backdrop-filter:blur(2px)}
.modal-box{background:var(--card);border:1px solid var(--border);padding:24px;max-height:80vh;overflow-y:auto}
.modal-box h2{font-size:18px;font-weight:700;margin-bottom:8px}
.modal-box h3{font-size:14px;font-weight:700;margin-bottom:8px}
.modal-close{position:absolute;top:12px;right:12px;font-size:18px;color:var(--muted-fg);cursor:pointer;background:none;border:none}

/* Inbound call popup */
.inbound-popup{position:fixed;bottom:24px;right:24px;z-index:50;width:320px;background:var(--card);border:2px solid var(--primary);padding:16px;box-shadow:0 4px 20px rgba(0,0,0,0.1);animation:slideInUp .3s ease-out}
.inbound-avatar{width:48px;height:48px;border-radius:50%;background:var(--muted);display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:700}
.inbound-btns{display:flex;gap:8px;margin-top:12px}
.inbound-btns button{flex:1;display:flex;align-items:center;justify-content:center;gap:8px;padding:10px;border-radius:var(--radius);font-size:12px;font-weight:700}
.btn-accept{background:var(--primary);color:var(--primary-fg)}
.btn-accept:hover{opacity:.9}
.btn-decline{border:1px solid var(--destructive);color:var(--destructive)}
.btn-decline:hover{background:rgba(229,62,62,0.1)}

/* Campaign reassignment */
.campaign-modal .modal-box{width:540px;border:2px solid var(--primary);text-align:center}
.campaign-icon{width:64px;height:64px;border-radius:50%;background:rgba(122,162,47,0.1);border:2px solid var(--primary);display:flex;align-items:center;justify-content:center;margin:0 auto 20px;font-size:28px}
.btn-confirm{width:100%;padding:12px;background:var(--primary);color:var(--primary-fg);font-size:14px;font-weight:700;border-radius:var(--radius);margin-top:24px}
.btn-confirm:hover{opacity:.9}

/* Leaderboard */
.leaderboard .modal-box{width:620px;position:relative}
.lb-tabs{display:flex;gap:8px;margin-bottom:16px}
.lb-tab{padding:6px 12px;font-size:12px;border:1px solid var(--border);border-radius:var(--radius);color:var(--muted-fg)}
.lb-tab.active{background:var(--primary);color:var(--primary-fg);border-color:var(--primary)}
.lb-table{width:100%;font-size:12px;border-collapse:collapse}
.lb-table th{text-align:left;padding:8px;font-weight:500;color:var(--muted-fg);border-bottom:1px solid var(--border)}
.lb-table th:nth-child(n+3){text-align:right}
.lb-table td{padding:10px 8px;border-bottom:1px solid rgba(0,0,0,0.04)}
.lb-table td:nth-child(n+3){text-align:right;font-family:monospace;color:var(--muted-fg)}
.lb-table td:last-child{color:var(--primary);font-weight:600}
.lb-table tr.me{background:rgba(122,162,47,0.1);border-left:4px solid var(--primary)}
.lb-rank-card{background:var(--bg);border-left:4px solid var(--primary);padding:12px;display:flex;justify-content:space-between;align-items:center;margin-top:16px}
.lb-close{width:100%;padding:8px;border:1px solid var(--border);color:var(--muted-fg);font-size:12px;margin-top:16px;border-radius:var(--radius)}
.lb-close:hover{border-color:var(--primary)}

/* Transfer/Conference modals */
.transfer-modal .modal-box,.conference-modal .modal-box{width:400px;position:relative}
.supervisor-item{width:100%;display:flex;align-items:center;gap:12px;padding:12px;border:1px solid var(--border);border-radius:var(--radius);margin-bottom:8px}
.supervisor-item:hover{border-color:var(--primary)}
.supervisor-item.offline{opacity:.5}
.sup-avatar{width:32px;height:32px;border-radius:50%;background:var(--muted);display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:600}
.online-dot{margin-left:auto;font-size:12px}

/* Logout modal */
.logout-modal .modal-box{width:380px}
.warning-box{background:rgba(229,62,62,0.1);border:1px solid rgba(229,62,62,0.3);padding:12px;border-radius:var(--radius);margin-bottom:16px}
.warning-box p{color:var(--destructive);font-size:12px;font-weight:600}
.modal-actions{display:flex;justify-content:flex-end;gap:12px;margin-top:16px}
.btn-cancel{color:var(--muted-fg);font-size:12px}
.btn-cancel:hover{color:var(--fg)}
.btn-danger{padding:8px 16px;border-radius:var(--radius);font-size:12px;font-weight:700;background:var(--destructive);color:var(--destructive-fg)}
.btn-danger:hover{opacity:.9}
.btn-danger:disabled{background:var(--muted);color:var(--muted-fg);opacity:.5;cursor:not-allowed}

/* ===== LOGIN ===== */
.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden}
.login-glow{position:absolute;width:600px;height:600px;border-radius:50%;background:rgba(122,162,47,0.05);filter:blur(60px)}
.login-container{position:relative;z-index:1;display:flex;flex-direction:column;align-items:center}
.login-logo{display:flex;align-items:center;gap:12px;margin-bottom:8px}
.login-logo .logo-box{width:48px;height:48px}
.login-logo .logo-box span{font-size:18px}
.login-brand{font-size:24px;font-weight:700}
.login-subtitle{color:var(--muted-fg);font-size:15px;margin-bottom:32px}
.login-card{width:400px;background:var(--card);border:1px solid var(--border);padding:32px;box-shadow:0 4px 20px rgba(0,0,0,0.08)}
.login-card .field{margin-bottom:20px}
.login-card .field label{display:block;font-size:13px;color:var(--muted-fg);margin-bottom:6px}
.login-card .field input{width:100%;background:var(--bg);border:1px solid var(--border);border-radius:var(--radius);padding:12px;font-size:14px;color:var(--fg)}
.login-card .field input:focus{outline:none;border-color:var(--primary)}
.pass-wrap{position:relative}
.pass-toggle{position:absolute;right:12px;top:50%;transform:translateY(-50%);color:var(--muted-fg);cursor:pointer;font-size:13px}
.btn-signin{width:100%;padding:14px;background:var(--primary);color:var(--primary-fg);border-radius:var(--radius);font-size:14px;font-weight:700;border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:8px}
.btn-signin:hover{opacity:.9}
.btn-signin:disabled{opacity:.7}
.forgot-link{display:block;text-align:center;margin-top:16px;color:var(--primary);font-size:13px;text-decoration:none}
.forgot-link:hover{text-decoration:underline}
.login-error{color:var(--destructive);font-size:12px;margin-bottom:12px;padding:10px;background:rgba(229,62,62,0.1);border:1px solid rgba(229,62,62,0.2);border-radius:var(--radius)}
.shake{animation:shake .3s ease-in-out}

/* Bravo overlay */
.bravo-overlay{position:fixed;inset:0;z-index:60;display:flex;align-items:center;justify-content:center;pointer-events:none}
.bravo-text{text-align:center;animation:bravoScale .5s ease-out}
.bravo-text .big{font-size:48px;font-weight:700;color:var(--primary)}
.bravo-text .sub{font-size:18px;margin-top:4px}

/* Connecting animation */
.pulse-glow{animation:pulseGlow 1.5s ease-in-out infinite}
.connected-dot{width:8px;height:8px;border-radius:50%;display:inline-block}

/* ===== ANIMATIONS ===== */
@keyframes slideInUp{0%{transform:translateY(100%);opacity:0}100%{transform:translateY(0);opacity:1}}
@keyframes shake{0%,100%{transform:translateX(0)}20%{transform:translateX(-8px)}40%{transform:translateX(8px)}60%{transform:translateX(-4px)}80%{transform:translateX(4px)}}
@keyframes bravoScale{0%{transform:scale(.5);opacity:0}60%{transform:scale(1.1);opacity:1}100%{transform:scale(1);opacity:1}}
@keyframes pulseGlow{0%,100%{opacity:1}50%{opacity:.4}}
@keyframes saleFlash{0%{background:var(--card)}50%{background:hsl(73,60%,92%)}100%{background:var(--card)}}

.hidden{display:none!important}
.relative{position:relative}
