/* GAgenda — Premium Design System v2 */
@import url('https://fonts.googleapis.com/css2?family=DM+Sans:wght@400;500;600;700&display=swap');

:root {
    --bg: #0B0F19;
    --bg-elevated: #111827;
    --surface: #1F2937;
    --surface-hover: #374151;
    --border: rgba(255,255,255,0.06);
    --border-hover: rgba(255,255,255,0.12);
    --primary: #3B82F6;
    --primary-glow: rgba(59,130,246,0.25);
    --accent: #10B981;
    --accent-glow: rgba(16,185,129,0.2);
    --cta: #F97316;
    --danger: #EF4444;
    --warning: #F59E0B;
    --info: #3B82F6;
    --success: #10B981;
    --text: #F1F5F9;
    --text-secondary: #94A3B8;
    --text-muted: #64748B;
    --sidebar-w: 260px;
    --radius: 12px;
    --radius-lg: 16px;
    --radius-xl: 20px;
    --transition: all .2s ease;
}

*, *::before, *::after { margin:0; padding:0; box-sizing:border-box; }

body {
    background: var(--bg);
    color: var(--text);
    font-family: 'DM Sans', system-ui, sans-serif;
    font-size: 15px;
    line-height: 1.6;
    -webkit-font-smoothing: antialiased;
}

h1,h2,h3,h4,h5,h6 { color:#fff; font-weight:700; line-height:1.3; }
a { color: var(--primary); text-decoration:none; transition: var(--transition); }
a:hover { color: #60A5FA; }

/* ===== LAYOUT ===== */
.app-layout { display:flex; min-height:100vh; }
.main-content { flex:1; margin-left:var(--sidebar-w); min-height:100vh; }
.page-content { padding: 2rem; max-width: 1400px; }

@media(max-width:992px){
    .main-content { margin-left:0; }
    .sidebar { transform:translateX(-100%); }
    .sidebar.active { transform:translateX(0); }
    .page-content { padding:1rem; }
}

/* ===== SIDEBAR ===== */
.sidebar {
    width: var(--sidebar-w);
    background: var(--bg-elevated);
    border-right: 1px solid var(--border);
    height: 100vh;
    position: fixed;
    left:0; top:0;
    display: flex;
    flex-direction: column;
    z-index: 1000;
    transition: var(--transition);
}

.sidebar-header { padding: 1.5rem; }
.logo { display:flex; align-items:center; gap:.75rem; }
.logo-icon {
    width:38px; height:38px;
    background: linear-gradient(135deg, var(--primary), var(--accent));
    border-radius: 10px;
    display:flex; align-items:center; justify-content:center;
    font-size:1.1rem; color:#fff;
    box-shadow: 0 4px 12px var(--primary-glow);
}
.logo-text { font-size:1.35rem; font-weight:700; color:#fff; }
.logo-sub {
    font-size:.7rem; color:var(--text-muted);
    text-transform:uppercase; letter-spacing:1.5px;
    margin-top:.25rem; display:block;
    padding-left: 3.25rem;
}

.sidebar-nav { flex:1; padding:.75rem; overflow-y:auto; }
.nav-item {
    display:flex; align-items:center; gap:.85rem;
    padding:.75rem 1rem;
    color: var(--text-secondary);
    border-radius: var(--radius);
    margin-bottom:2px;
    font-weight:500; font-size:.9rem;
    cursor:pointer;
    transition: var(--transition);
}
.nav-item i { font-size:1.05rem; width:20px; text-align:center; }
.nav-item:hover { background:var(--surface); color:var(--text); }
.nav-item.active { background: rgba(59,130,246,0.12); color:var(--primary); }

.nav-divider {
    font-size:.65rem; color:var(--text-muted);
    text-transform:uppercase; letter-spacing:1.5px;
    padding: 1.25rem 1rem .5rem;
    font-weight:600;
}

.sidebar-footer { padding:1rem 1.25rem; border-top:1px solid var(--border); }
.sidebar-status { font-size:.8rem; padding:.5rem .75rem; border-radius:var(--radius); display:flex; align-items:center; gap:.5rem; }
.sidebar-status.connected { color:var(--success); background:rgba(16,185,129,0.08); }
.sidebar-status.disconnected { color:var(--warning); background:rgba(245,158,11,0.08); }
.sidebar-version { font-size:.75rem; color:var(--text-muted); text-align:center; }

.sidebar-toggle { background:none; border:none; color:var(--text-secondary); font-size:1.25rem; cursor:pointer; display:none; padding:.5rem; }
@media(max-width:992px){ .sidebar-toggle { display:block; } }

/* ===== TOP BAR ===== */
.top-bar {
    display:flex; justify-content:space-between; align-items:center;
    padding: 1rem 2rem;
    border-bottom: 1px solid var(--border);
    background: var(--bg-elevated);
}
.top-bar-right { display:flex; align-items:center; gap:1.25rem; }
.admin-badge {
    display:inline-flex; align-items:center; gap:.4rem;
    background: rgba(59,130,246,0.1); color:var(--primary);
    padding:.35rem .85rem; border-radius:100px;
    font-size:.75rem; font-weight:600;
}
.user-menu { display:flex; align-items:center; gap:.75rem; font-size:.9rem; }
.impersonate-bar {
    background: linear-gradient(90deg, rgba(249,115,22,0.15), rgba(249,115,22,0.05));
    border-bottom: 1px solid rgba(249,115,22,0.2);
    padding:.5rem 2rem; display:flex; align-items:center; justify-content:space-between;
    font-size:.85rem; color: #FDBA74;
}

/* ===== PAGE HEADER ===== */
.page-header {
    display:flex; justify-content:space-between; align-items:center;
    margin-bottom:2rem; flex-wrap:wrap; gap:1rem;
}
.page-title { font-size:1.75rem; }
.page-subtitle { color:var(--text-secondary); font-size:.9rem; margin-top:.25rem; }

/* ===== CARDS ===== */
.card {
    background: var(--bg-elevated);
    border: 1px solid var(--border);
    border-radius: var(--radius-lg);
    margin-bottom: 1.5rem;
    transition: var(--transition);
}
.card:hover { border-color: var(--border-hover); }
.card-header {
    padding: 1.25rem 1.5rem;
    border-bottom: 1px solid var(--border);
    display:flex; justify-content:space-between; align-items:center;
}
.card-header h3 { font-size:1rem; font-weight:600; display:flex; align-items:center; gap:.6rem; }
.card-body { padding: 1.5rem; }

/* ===== STATS ===== */
.stats-grid {
    display:grid;
    grid-template-columns: repeat(auto-fit, minmax(220px,1fr));
    gap:1.25rem; margin-bottom:2rem;
}
.stat-card {
    background: var(--bg-elevated);
    border: 1px solid var(--border);
    padding: 1.25rem 1.5rem;
    border-radius: var(--radius-lg);
    display:flex; align-items:center; gap:1.25rem;
    transition: var(--transition);
    cursor: default;
}
.stat-card:hover { border-color:var(--primary); transform:translateY(-2px); box-shadow: 0 8px 25px rgba(0,0,0,0.3); }
.stat-icon {
    width:52px; height:52px; border-radius:var(--radius);
    display:flex; align-items:center; justify-content:center;
    font-size:1.25rem; color:#fff; flex-shrink:0;
}
.stat-info { display:flex; flex-direction:column; }
.stat-value { font-size:1.75rem; font-weight:700; color:#fff; line-height:1.2; }
.stat-label { color:var(--text-muted); font-size:.8rem; margin-top:.15rem; }

/* ===== TABLES ===== */
.table-responsive { overflow-x:auto; }
.table { width:100%; border-collapse:collapse; }
.table th {
    text-align:left; padding:.85rem 1rem;
    color:var(--text-muted); font-weight:600; font-size:.75rem;
    text-transform:uppercase; letter-spacing:.5px;
    border-bottom: 1px solid var(--border);
    background: rgba(255,255,255,0.02);
}
.table td { padding:1rem; border-bottom:1px solid var(--border); vertical-align:middle; }
.table tbody tr { transition: var(--transition); }
.table tbody tr:hover { background: rgba(255,255,255,0.02); }
.cell-main { font-weight:600; color:#fff; font-size:.9rem; }
.cell-sub { font-size:.8rem; color:var(--text-muted); margin-top:.1rem; }
.text-accent { color:var(--primary); }
.text-success { color:var(--success); }

/* ===== BADGES ===== */
.badge {
    display:inline-flex; align-items:center;
    padding:.3rem .7rem; border-radius:100px;
    font-size:.7rem; font-weight:600; text-transform:uppercase; letter-spacing:.3px;
}
.badge-ativo, .badge-confirmado { background:rgba(16,185,129,0.1); color:var(--success); }
.badge-inativo, .badge-cancelado { background:rgba(239,68,68,0.1); color:var(--danger); }
.badge-trial { background:rgba(245,158,11,0.1); color:var(--warning); }
.badge-pendente { background:rgba(59,130,246,0.1); color:var(--primary); }
.badge-ghost { background:var(--surface); color:var(--text-secondary); }
.badge-plan-basico { background:rgba(100,116,139,0.15); color:var(--text-secondary); }
.badge-plan-pro { background:rgba(59,130,246,0.1); color:var(--primary); }
.badge-plan-premium { background:rgba(249,115,22,0.1); color:var(--cta); }

/* ===== FORMS ===== */
.form-grid { display:grid; grid-template-columns:1fr 1fr; gap:1.25rem; }
.form-grid .full-width { grid-column:1/-1; }
.form-group { margin-bottom:0; }
label { display:block; margin-bottom:.4rem; color:var(--text-secondary); font-weight:500; font-size:.85rem; }

.form-control {
    width:100%;
    background: var(--surface);
    border: 1px solid var(--border);
    padding:.7rem 1rem;
    border-radius: var(--radius);
    color: var(--text);
    font-family:inherit; font-size:.9rem;
    outline:none;
    transition: var(--transition);
}
.form-control:focus { border-color:var(--primary); box-shadow: 0 0 0 3px var(--primary-glow); }
.form-control::placeholder { color:var(--text-muted); }
select.form-control { cursor:pointer; }
textarea.form-control { resize:vertical; min-height:80px; }
.form-hint { font-size:.75rem; color:var(--text-muted); margin-top:.3rem; display:block; }
.form-actions { display:flex; gap:1rem; padding-top:.5rem; align-items:flex-end; }
.checkbox-group { display:flex; flex-wrap:wrap; gap:.75rem; }
.checkbox-item { display:flex; align-items:center; gap:.4rem; font-size:.85rem; color:var(--text-secondary); cursor:pointer; }
.input-group { display:flex; gap:.5rem; }
.input-group .form-control { flex:1; }

/* ===== BUTTONS ===== */
.btn {
    display:inline-flex; align-items:center; gap:.5rem;
    padding:.65rem 1.25rem; border-radius:var(--radius);
    font-weight:600; font-size:.875rem;
    cursor:pointer; transition:var(--transition);
    border:none; font-family:inherit; line-height:1.4;
}
.btn-primary {
    background: var(--primary); color:#fff;
    box-shadow: 0 2px 8px var(--primary-glow);
}
.btn-primary:hover { background:#2563EB; transform:translateY(-1px); box-shadow: 0 4px 16px var(--primary-glow); }
.btn-ghost { background:var(--surface); color:var(--text); border:1px solid var(--border); }
.btn-ghost:hover { background:var(--surface-hover); border-color:var(--border-hover); }
.btn-sm { padding:.4rem .8rem; font-size:.8rem; }
.btn-lg { padding:.85rem 1.75rem; font-size:1rem; }
.btn-icon {
    width:36px; height:36px; border-radius:var(--radius);
    display:inline-flex; align-items:center; justify-content:center;
    background:var(--surface); color:var(--text-secondary);
    border:1px solid var(--border); cursor:pointer; transition:var(--transition);
    font-size:.85rem;
}
.btn-icon:hover { background:var(--surface-hover); color:var(--text); }
.btn-success { background:rgba(16,185,129,0.1)!important; color:var(--success)!important; border-color:rgba(16,185,129,0.2)!important; }
.btn-success:hover { background:rgba(16,185,129,0.2)!important; }
.btn-danger { background:rgba(239,68,68,0.1)!important; color:var(--danger)!important; border-color:rgba(239,68,68,0.2)!important; }
.btn-danger:hover { background:rgba(239,68,68,0.2)!important; }
.btn-copy { font-size:.75rem; }
.action-btns { display:flex; gap:.4rem; }
.inline { display:inline; }

/* ===== ALERTS ===== */
.alert {
    padding:.85rem 1.25rem; border-radius:var(--radius);
    margin-bottom:1.25rem; display:flex; align-items:center; gap:.75rem;
    font-size:.9rem; position:relative;
}
.alert-success { background:rgba(16,185,129,0.08); border:1px solid rgba(16,185,129,0.15); color:#6EE7B7; }
.alert-error { background:rgba(239,68,68,0.08); border:1px solid rgba(239,68,68,0.15); color:#FCA5A5; }
.alert-warning { background:rgba(245,158,11,0.08); border:1px solid rgba(245,158,11,0.15); color:#FCD34D; }
.alert-info { background:rgba(59,130,246,0.08); border:1px solid rgba(59,130,246,0.15); color:#93C5FD; }
.alert-close { position:absolute; right:1rem; background:none; border:none; color:inherit; cursor:pointer; font-size:1.2rem; opacity:.6; }
.alert-close:hover { opacity:1; }

/* ===== DASHBOARD ===== */
.dashboard-grid { display:grid; grid-template-columns:1.5fr 1fr; gap:1.5rem; }
@media(max-width:1200px){ .dashboard-grid { grid-template-columns:1fr; } }
.schedule-list { display:flex; flex-direction:column; gap:.5rem; }
.schedule-item {
    display:flex; align-items:center; gap:1rem;
    padding:.85rem 1rem; background:var(--surface);
    border-radius:var(--radius); transition:var(--transition);
}
.schedule-item:hover { background:var(--surface-hover); }
.schedule-time { font-size:1rem; font-weight:700; color:var(--primary); min-width:50px; }
.schedule-info { flex:1; }
.schedule-name { display:block; font-weight:600; color:#fff; font-size:.9rem; }
.schedule-meta { font-size:.8rem; color:var(--text-muted); }
.schedule-date { text-align:center; min-width:45px; }
.schedule-day { display:block; font-size:1.25rem; font-weight:700; color:#fff; line-height:1; }
.schedule-month { font-size:.7rem; color:var(--text-muted); text-transform:uppercase; }

/* ===== EMPTY STATE ===== */
.empty-state {
    text-align:center; padding:3rem 1rem; color:var(--text-muted);
}
.empty-state i { font-size:2.5rem; margin-bottom:1rem; display:block; opacity:.4; }
.empty-state p { margin-bottom:1rem; }
.empty-state.small { padding:2rem 1rem; }
.empty-state.small i { font-size:1.75rem; }

/* ===== FILTERS ===== */
.filters-card { margin-bottom:1.5rem; }
.filters-grid { display:grid; grid-template-columns:repeat(auto-fit,minmax(180px,1fr)); gap:1rem; align-items:end; }

/* ===== WEBHOOK ===== */
.webhook-url-cell { display:flex; align-items:center; gap:.4rem; }
.webhook-code { font-size:.75rem; color:var(--text-muted); background:var(--surface); padding:.25rem .5rem; border-radius:6px; }

/* ===== STATUS INDICATORS ===== */
.status-connected, .status-disconnected {
    display:flex; align-items:center; gap:.75rem;
    padding:1rem; border-radius:var(--radius); font-size:.9rem;
}
.status-connected { background:rgba(16,185,129,0.08); color:var(--success); }
.status-disconnected { background:rgba(239,68,68,0.08); color:var(--danger); }

/* ===== LOGIN / REGISTER ===== */
.login-body {
    display:flex; align-items:center; justify-content:center;
    min-height:100vh;
    background: var(--bg);
    background-image: radial-gradient(ellipse at top, rgba(59,130,246,0.08) 0%, transparent 60%);
}
.login-card {
    width:100%; max-width:420px; padding:2.5rem;
    background: var(--bg-elevated);
    border:1px solid var(--border);
    border-radius: var(--radius-xl);
    box-shadow: 0 25px 60px rgba(0,0,0,0.4);
}
.login-header { text-align:center; margin-bottom:2rem; }
.text-muted { color:var(--text-muted); }

/* ===== LANDING PAGE ===== */
.landing-body { background:var(--bg); }
.nav-landing {
    display:flex; justify-content:space-between; align-items:center;
    padding:1.25rem 2rem; max-width:1200px; margin:0 auto;
}
.nav-links { display:flex; gap:.75rem; align-items:center; }
.hero-section { text-align:center; padding:5rem 2rem 4rem; max-width:800px; margin:0 auto; }
.hero-badge {
    display:inline-block; padding:.4rem 1rem;
    background:rgba(59,130,246,0.1); color:var(--primary);
    border-radius:100px; font-size:.8rem; font-weight:600;
    margin-bottom:1.5rem; border:1px solid rgba(59,130,246,0.15);
}
.hero-title { font-size:3rem; margin-bottom:1.25rem; line-height:1.15; }
.hero-desc { color:var(--text-secondary); font-size:1.1rem; line-height:1.7; max-width:600px; margin:0 auto 2rem; }
.hero-actions { margin-top:2rem; }

@media(max-width:768px){ .hero-title { font-size:2rem; } .hero-section { padding:3rem 1rem; } }

.features-section, .pricing-section, .faq-section {
    padding:4rem 2rem; max-width:1200px; margin:0 auto;
}
.section-title { text-align:center; font-size:2rem; margin-bottom:.75rem; }
.section-subtitle { text-align:center; color:var(--text-secondary); margin-bottom:3rem; }
.features-grid { display:grid; grid-template-columns:repeat(auto-fit,minmax(280px,1fr)); gap:1.5rem; }
.feature-card {
    background:var(--bg-elevated); border:1px solid var(--border);
    border-radius:var(--radius-lg); padding:2rem;
    transition:var(--transition);
}
.feature-card:hover { border-color:var(--primary); transform:translateY(-3px); }
.feature-icon {
    width:48px; height:48px; border-radius:var(--radius);
    display:flex; align-items:center; justify-content:center;
    font-size:1.25rem; margin-bottom:1.25rem;
}
.feature-card h3 { font-size:1.1rem; margin-bottom:.5rem; }
.feature-card p { color:var(--text-secondary); font-size:.9rem; }

/* Pricing */
.pricing-grid { display:grid; grid-template-columns:repeat(auto-fit,minmax(280px,1fr)); gap:1.5rem; }
.pricing-card {
    background:var(--bg-elevated); border:1px solid var(--border);
    border-radius:var(--radius-xl); padding:2rem;
    transition:var(--transition); position:relative;
}
.pricing-card.featured {
    border-color:var(--primary);
    box-shadow: 0 0 40px var(--primary-glow);
}
.pricing-card.featured::before {
    content:'POPULAR'; position:absolute; top:-12px; left:50%; transform:translateX(-50%);
    background:var(--primary); color:#fff; padding:.25rem 1rem;
    border-radius:100px; font-size:.7rem; font-weight:700; letter-spacing:.5px;
}
.pricing-header { margin-bottom:1.5rem; }
.pricing-header h4 { font-size:1.25rem; margin-bottom:.5rem; }
.pricing-price { font-size:2.5rem; font-weight:700; color:#fff; }
.pricing-price span { font-size:.9rem; color:var(--text-muted); font-weight:400; }
.pricing-features { list-style:none; margin-bottom:2rem; }
.pricing-features li { padding:.5rem 0; display:flex; align-items:center; gap:.6rem; font-size:.9rem; color:var(--text-secondary); }
.pricing-features i { font-size:.8rem; }
.pricing-features .fa-check { color:var(--success); }
.pricing-features .fa-times { color:var(--danger); }

/* FAQ */
.faq-list { max-width:700px; margin:0 auto; }
.faq-item { border-bottom:1px solid var(--border); }
.faq-question {
    width:100%; background:none; border:none; color:var(--text);
    padding:1.25rem 0; font-size:1rem; font-weight:600;
    text-align:left; cursor:pointer; display:flex;
    justify-content:space-between; align-items:center;
    font-family:inherit;
}
.faq-question:hover { color:var(--primary); }
.faq-answer { padding:0 0 1.25rem; color:var(--text-secondary); font-size:.9rem; display:none; line-height:1.7; }
.faq-item.open .faq-answer { display:block; }

/* Footer */
.footer-landing { text-align:center; padding:3rem 2rem; color:var(--text-muted); font-size:.85rem; border-top:1px solid var(--border); }

/* ===== CHART ===== */
.chart-container { position:relative; height:250px; width:100%; }

/* ===== SPECIALIST CARDS ===== */
.grid-cards { display:grid; grid-template-columns:repeat(auto-fill,minmax(300px,1fr)); gap:1.25rem; }
.specialist-card { transition:var(--transition); }
.specialist-card:hover { border-color:var(--primary); transform:translateY(-3px); }
.specialist-header { display:flex; align-items:center; gap:1rem; margin-bottom:1.25rem; }
.specialist-avatar {
    width:48px; height:48px; background:rgba(59,130,246,0.1);
    color:var(--primary); border-radius:var(--radius);
    display:flex; align-items:center; justify-content:center; font-size:1.25rem;
}
.specialist-main { flex:1; }
.specialist-name { font-size:1rem; font-weight:700; margin-bottom:.15rem; }
.specialist-role { font-size:.8rem; color:var(--text-muted); }
.specialist-details { display:flex; flex-direction:column; gap:.6rem; padding-top:1rem; border-top:1px solid var(--border); }
.detail-item { display:flex; align-items:center; gap:.6rem; font-size:.85rem; color:var(--text-muted); }
.detail-item i { width:16px; color:var(--primary); }

/* ===== UTILITIES ===== */
.text-truncate { overflow:hidden; text-overflow:ellipsis; white-space:nowrap; }
.full-width { grid-column:1/-1; }

/* ===== RESPONSIVE ===== */
@media(max-width:768px){
    .stats-grid { grid-template-columns:1fr 1fr; }
    .form-grid { grid-template-columns:1fr; }
    .features-grid, .pricing-grid { grid-template-columns:1fr; }
    .nav-landing { padding:1rem; }
    .hero-section { padding:2rem 1rem; }
}
@media(max-width:480px){
    .stats-grid { grid-template-columns:1fr; }
    .page-title { font-size:1.35rem; }
}

/* ===== AGENT PREMIUM DASHBOARD ===== */
.agente-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(320px, 1fr));
    gap: 1.5rem;
}

.agente-card {
    background: var(--bg-elevated);
    border: 1px solid var(--border);
    border-radius: var(--radius-xl);
    padding: 1.5rem;
    transition: var(--transition);
    position: relative;
    overflow: hidden;
    animation: fadeIn .4s ease both;
}

.agente-card:hover {
    border-color: var(--primary);
    transform: translateY(-4px);
    box-shadow: 0 12px 30px rgba(0,0,0,0.3), 0 0 20px var(--primary-glow);
}

.agente-header {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    margin-bottom: 1.25rem;
}

.agente-avatar {
    width: 48px;
    height: 48px;
    background: var(--primary-glow);
    color: var(--primary);
    border-radius: 14px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1.5rem;
}

.agente-status-toggle {
    display: flex;
    align-items: center;
    gap: 0.5rem;
}

.agente-info h3 {
    font-size: 1.15rem;
    font-weight: 700;
    margin-bottom: 0.25rem;
}

.agente-info p {
    color: var(--text-muted);
    font-size: 0.85rem;
    margin-bottom: 1rem;
}

.agente-stats {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 0.75rem;
    padding: 1rem 0;
    border-top: 1px solid var(--border);
    border-bottom: 1px solid var(--border);
    margin-bottom: 1.25rem;
}

.agente-stat-item {
    text-align: center;
}

.agente-stat-value {
    display: block;
    font-size: 1.1rem;
    font-weight: 700;
    color: #fff;
}

.agente-stat-label {
    font-size: 0.65rem;
    color: var(--text-muted);
    text-transform: uppercase;
    letter-spacing: 0.5px;
}

.agente-footer {
    display: flex;
    gap: 0.75rem;
}

.agente-footer .btn {
    flex: 1;
}

/* Animations */
@keyframes fadeIn {
    from { opacity: 0; transform: translateY(10px); }
    to { opacity: 1; transform: translateY(0); }
}

/* Toasts */
#toast-container {
    position: fixed;
    bottom: 2rem;
    right: 2rem;
    z-index: 9999;
    display: flex;
    flex-direction: column;
    gap: 0.5rem;
}

.toast {
    padding: 1rem 1.5rem;
    background: var(--bg-elevated);
    border: 1px solid var(--border);
    border-radius: var(--radius);
    box-shadow: 0 10px 25px rgba(0,0,0,0.5);
    color: #fff;
    font-size: 0.9rem;
    display: flex;
    align-items: center;
    gap: 0.75rem;
    animation: slideIn .3s ease both;
    min-width: 250px;
}

.toast-success { border-left: 4px solid var(--success); }
.toast-error { border-left: 4px solid var(--danger); }

@keyframes slideIn {
    from { opacity: 0; transform: translateX(100%); }
    to { opacity: 1; transform: translateX(0); }
}
