/* ============================================================
   WM Agency — Plataforma de Fidelización
   Sistema visual: claro, limpio, acento naranja
   ============================================================ */
:root{
  /* Brand */
  --wm-orange:#FF8A00;
  --wm-orange-600:#F97316;
  --wm-orange-700:#EA6A00;
  --wm-orange-tint:#FFF3E4;
  --wm-orange-tint-2:#FFE7CC;

  /* Neutrals (cool-warm slate) */
  --bg:#F6F7F9;
  --surface:#FFFFFF;
  --surface-2:#FBFBFC;
  --border:#ECEEF2;
  --border-strong:#E1E4EA;
  --ink:#1B2330;
  --ink-2:#3A4456;
  --muted:#7C8696;
  --muted-2:#A4ADBB;

  /* Status */
  --green:#16A34A; --green-tint:#E7F6ED;
  --blue:#2F6BF6;  --blue-tint:#E8F0FE;
  --gray:#94A3B8;  --gray-tint:#EEF1F5;
  --amber:#D97706; --amber-tint:#FCF1DC;
  --violet:#7C3AED;--violet-tint:#F1EAFE;

  /* Radii & shadow */
  --r-sm:8px; --r:12px; --r-lg:16px; --r-xl:22px;
  --sh-1:0 1px 2px rgba(20,28,44,.04), 0 1px 1px rgba(20,28,44,.03);
  --sh-2:0 4px 16px rgba(20,28,44,.06), 0 1px 3px rgba(20,28,44,.04);
  --sh-3:0 18px 50px rgba(20,28,44,.12), 0 4px 14px rgba(20,28,44,.06);
  --sh-pop:0 24px 70px rgba(20,28,44,.18);

  --sidebar-w:256px;
  --font: "Plus Jakarta Sans", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  --mono:"JetBrains Mono", ui-monospace, SFMono-Regular, Menlo, monospace;
}

*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{
  font-family:var(--font);
  background:var(--bg);
  color:var(--ink);
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
button{font-family:inherit;cursor:pointer;border:none;background:none}
input,select,textarea{font-family:inherit}
::selection{background:var(--wm-orange-tint-2)}
::-webkit-scrollbar{width:10px;height:10px}
::-webkit-scrollbar-thumb{background:#D7DCE3;border-radius:20px;border:2px solid transparent;background-clip:padding-box}
::-webkit-scrollbar-thumb:hover{background:#C2C9D2;background-clip:padding-box}

/* ---------- App layout ---------- */
.app{display:flex;min-height:100vh}
.main{flex:1;min-width:0;display:flex;flex-direction:column}
.page{flex:1;padding:30px 40px 64px;max-width:1340px;width:100%;margin:0 auto}

/* ---------- Sidebar ---------- */
.sidebar{
  width:var(--sidebar-w);flex-shrink:0;background:var(--surface);
  border-right:1px solid var(--border);height:100vh;position:sticky;top:0;
  display:flex;flex-direction:column;padding:18px 14px 14px;
}
.sb-brand{display:flex;align-items:center;gap:10px;padding:4px 8px 16px}
.sb-logo{display:flex;align-items:baseline;gap:2px;font-weight:800;font-size:21px;letter-spacing:-.5px}
.sb-logo .wm{color:var(--ink)}
.sb-logo .ag{color:var(--wm-orange)}
.sb-logo .mark{width:26px;height:26px;margin-right:4px;border-radius:8px;background:linear-gradient(135deg,var(--wm-orange),#FFB347);display:grid;place-items:center;color:#fff;font-weight:800;font-size:13px;box-shadow:0 4px 10px rgba(255,138,0,.35)}

.switcher{margin:0 4px 6px;position:relative}
.switcher>button{
  width:100%;display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:var(--r);
  background:var(--surface-2);border:1px solid var(--border);text-align:left;transition:.15s;
}
.switcher>button:hover{border-color:var(--border-strong);background:#fff}
.switcher .sw-ava{width:26px;height:26px;border-radius:7px;display:grid;place-items:center;color:#fff;font-weight:700;font-size:12px;flex-shrink:0}
.switcher .sw-lbl{flex:1;min-width:0;display:flex;flex-direction:column;line-height:1.25}
.switcher .sw-lbl .t{display:block;font-size:13px;font-weight:700;color:var(--ink);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.switcher .sw-lbl .s{display:block;font-size:11px;color:var(--muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.switcher .sub{padding:7px 12px}
.switcher .sub .t{font-size:12.5px}

.sw-menu{position:absolute;top:calc(100% + 6px);left:0;right:0;z-index:60;background:#fff;border:1px solid var(--border);border-radius:var(--r);box-shadow:var(--sh-3);padding:6px;animation:pop .14s ease}
.sw-menu button{width:100%;display:flex;align-items:center;gap:10px;padding:9px 10px;border-radius:9px;text-align:left;font-size:13px;font-weight:600;color:var(--ink-2)}
.sw-menu button:hover{background:var(--wm-orange-tint)}
.sw-menu button.active{background:var(--wm-orange-tint);color:var(--wm-orange-700)}

.nav{margin-top:10px;display:flex;flex-direction:column;gap:2px;overflow-y:auto;flex:1;padding:0 4px}
.nav::-webkit-scrollbar{width:6px}
.nav-item{
  display:flex;align-items:center;gap:12px;padding:9px 12px;border-radius:11px;
  font-size:13.5px;font-weight:600;color:var(--ink-2);transition:.13s;position:relative;width:100%;text-align:left;white-space:nowrap;
}
.nav-item>span:not(.badge-n){overflow:hidden;text-overflow:ellipsis}
.nav-item:hover{background:var(--surface-2);color:var(--ink)}
.nav-item.active{background:var(--wm-orange);color:#fff;box-shadow:0 6px 16px rgba(255,138,0,.32)}
.nav-item.active .ic{color:#fff}
.nav-item .ic{color:var(--muted);flex-shrink:0}
.nav-item:hover .ic{color:var(--ink-2)}
.nav-item .badge-n{margin-left:auto;background:var(--wm-orange-tint);color:var(--wm-orange-700);font-size:11px;font-weight:800;padding:1px 7px;border-radius:20px}
.nav-item.active .badge-n{background:rgba(255,255,255,.25);color:#fff}
.nav-sep{height:1px;background:var(--border);margin:8px 12px}
.nav-label{font-size:10.5px;font-weight:800;letter-spacing:.08em;text-transform:uppercase;color:var(--muted-2);padding:10px 12px 4px}

/* ---------- Topbar ---------- */
.topbar{
  height:64px;display:flex;align-items:center;gap:14px;padding:0 40px;
  border-bottom:1px solid var(--border);background:rgba(255,255,255,.82);
  backdrop-filter:blur(10px);position:sticky;top:0;z-index:40;
}
.tb-search{flex:1;max-width:420px;position:relative}
.tb-search input{
  width:100%;height:40px;border-radius:11px;border:1px solid var(--border);background:var(--surface-2);
  padding:0 14px 0 40px;font-size:13.5px;color:var(--ink);outline:none;transition:.15s;
}
.tb-search input:focus{border-color:var(--wm-orange);background:#fff;box-shadow:0 0 0 4px var(--wm-orange-tint)}
.tb-search .ic{position:absolute;left:13px;top:50%;transform:translateY(-50%);color:var(--muted)}
.tb-actions{margin-left:auto;display:flex;align-items:center;gap:8px}
.tb-btn{width:40px;height:40px;border-radius:11px;display:grid;place-items:center;color:var(--ink-2);border:1px solid var(--border);background:var(--surface-2);transition:.15s;position:relative}
.tb-btn:hover{background:#fff;border-color:var(--border-strong);color:var(--ink)}
.tb-btn .dot{position:absolute;top:9px;right:9px;width:7px;height:7px;border-radius:50%;background:var(--wm-orange);border:2px solid #fff}
.tb-user{display:flex;align-items:center;gap:10px;padding:5px 10px 5px 5px;border-radius:30px;border:1px solid var(--border);background:var(--surface-2);transition:.15s}
.tb-user:hover{background:#fff;border-color:var(--border-strong)}
.tb-user .ava{width:30px;height:30px;border-radius:50%;display:grid;place-items:center;color:#fff;font-weight:700;font-size:12px;background:linear-gradient(135deg,#5B6BFF,#9C5BFF)}
.tb-user .nm{font-size:13px;font-weight:700}

/* ---------- Headings ---------- */
.page-head{display:flex;align-items:flex-end;gap:16px;margin-bottom:24px;flex-wrap:wrap}
.page-head .eyebrow{font-size:12px;font-weight:800;color:var(--wm-orange);letter-spacing:.04em;text-transform:uppercase;margin-bottom:6px}
.page-title{font-size:28px;font-weight:800;letter-spacing:-.6px;color:var(--ink);margin:0}
.page-sub{color:var(--muted);font-size:14px;margin:6px 0 0;max-width:560px}
.page-head .right{margin-left:auto;display:flex;gap:10px;align-items:center}

/* ---------- Buttons ---------- */
.btn{display:inline-flex;align-items:center;gap:8px;height:40px;padding:0 16px;border-radius:11px;font-size:13.5px;font-weight:700;transition:.15s;white-space:nowrap}
.btn-primary{background:var(--wm-orange);color:#fff;box-shadow:0 6px 16px rgba(255,138,0,.3)}
.btn-primary:hover{background:var(--wm-orange-600);box-shadow:0 8px 22px rgba(255,138,0,.4);transform:translateY(-1px)}
.btn-ghost{background:var(--surface);color:var(--ink-2);border:1px solid var(--border)}
.btn-ghost:hover{background:var(--surface-2);border-color:var(--border-strong);color:var(--ink)}
.btn-soft{background:var(--wm-orange-tint);color:var(--wm-orange-700)}
.btn-soft:hover{background:var(--wm-orange-tint-2)}
.btn-sm{height:34px;padding:0 12px;font-size:12.5px;border-radius:9px}
.btn-icon{width:40px;padding:0;justify-content:center}

/* ---------- Cards ---------- */
.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);box-shadow:var(--sh-1)}
.card-pad{padding:22px}

/* KPI */
.kpi-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:26px}
.kpi{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);padding:18px 20px;box-shadow:var(--sh-1);position:relative;overflow:hidden;transition:.18s}
.kpi:hover{box-shadow:var(--sh-2);transform:translateY(-2px)}
.kpi .top{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px}
.kpi .ic-wrap{width:40px;height:40px;border-radius:12px;display:grid;place-items:center}
.kpi .delta{font-size:12px;font-weight:800;display:inline-flex;align-items:center;gap:3px;padding:3px 8px;border-radius:20px}
.kpi .delta.up{background:var(--green-tint);color:var(--green)}
.kpi .delta.down{background:#FDECEC;color:#DC2626}
.kpi .val{font-size:30px;font-weight:800;letter-spacing:-1px;color:var(--ink);line-height:1}
.kpi .val.flash{animation:flash .7s ease}
.kpi .lbl{font-size:13px;color:var(--muted);font-weight:600;margin-top:6px}

/* ---------- Action grid (¿Qué quieres hacer?) ---------- */
.action-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}
.action-card{
  background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);padding:20px;
  box-shadow:var(--sh-1);text-align:left;transition:.18s;position:relative;min-height:148px;display:flex;flex-direction:column;
}
.action-card:hover{border-color:var(--wm-orange);box-shadow:0 14px 34px rgba(255,138,0,.14);transform:translateY(-3px)}
.action-card .ic-wrap{width:42px;height:42px;border-radius:12px;display:grid;place-items:center;background:var(--surface-2);color:var(--ink-2);margin-bottom:16px;transition:.18s}
.action-card:hover .ic-wrap{background:var(--wm-orange-tint);color:var(--wm-orange-700)}
.action-card h4{margin:0 0 4px;font-size:15.5px;font-weight:800;letter-spacing:-.2px;color:var(--ink)}
.action-card p{margin:0;font-size:12.5px;color:var(--muted);line-height:1.45}
.action-card .arr{position:absolute;right:18px;bottom:18px;color:var(--muted-2);transition:.18s}
.action-card:hover .arr{color:var(--wm-orange);transform:translateX(3px)}
.action-card.hl{border-color:var(--green)}
.action-card.hl .ic-wrap{background:var(--green-tint);color:var(--green)}

/* ---------- Badges ---------- */
.badge{display:inline-flex;align-items:center;gap:5px;font-size:11.5px;font-weight:800;padding:3px 9px;border-radius:20px;white-space:nowrap}
.badge .b-dot{width:6px;height:6px;border-radius:50%}
.badge.green{background:var(--green-tint);color:var(--green)} .badge.green .b-dot{background:var(--green)}
.badge.blue{background:var(--blue-tint);color:var(--blue)} .badge.blue .b-dot{background:var(--blue)}
.badge.gray{background:var(--gray-tint);color:#64748B} .badge.gray .b-dot{background:var(--gray)}
.badge.amber{background:var(--amber-tint);color:var(--amber)} .badge.amber .b-dot{background:var(--amber)}
.badge.violet{background:var(--violet-tint);color:var(--violet)} .badge.violet .b-dot{background:var(--violet)}
.badge.orange{background:var(--wm-orange-tint);color:var(--wm-orange-700)} .badge.orange .b-dot{background:var(--wm-orange)}

/* tier chips */
.tier{display:inline-flex;align-items:center;gap:6px;font-size:12px;font-weight:800;padding:3px 10px;border-radius:8px}
.tier.bronce{background:#F6ECE2;color:#B07A4B}
.tier.plata{background:#EEF1F5;color:#6B7686}
.tier.oro{background:#FBF1D7;color:#B58A1B}

/* ---------- Table ---------- */
.tbl-wrap{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);box-shadow:var(--sh-1);overflow:hidden}
.tbl-toolbar{display:flex;align-items:center;gap:12px;padding:16px 18px;border-bottom:1px solid var(--border);flex-wrap:wrap}
.tbl-search{position:relative;flex:1;min-width:220px;max-width:360px}
.tbl-search input{width:100%;height:38px;border-radius:10px;border:1px solid var(--border);background:var(--surface-2);padding:0 12px 0 38px;font-size:13px;outline:none;transition:.15s}
.tbl-search input:focus{border-color:var(--wm-orange);background:#fff;box-shadow:0 0 0 4px var(--wm-orange-tint)}
.tbl-search .ic{position:absolute;left:12px;top:50%;transform:translateY(-50%);color:var(--muted)}
.seg{display:flex;background:var(--surface-2);border:1px solid var(--border);border-radius:10px;padding:3px;gap:2px}
.seg button{padding:6px 12px;border-radius:7px;font-size:12.5px;font-weight:700;color:var(--muted);transition:.13s;white-space:nowrap}
.seg button:hover{color:var(--ink-2)}
.seg button.active{background:#fff;color:var(--wm-orange-700);box-shadow:var(--sh-1)}

table.tt{width:100%;border-collapse:collapse}
.tt thead th{
  text-align:left;font-size:11.5px;font-weight:800;letter-spacing:.03em;text-transform:uppercase;color:var(--muted);
  padding:12px 16px;background:var(--surface-2);border-bottom:1px solid var(--border);white-space:nowrap;
}
.tt thead th.sortable{cursor:pointer;user-select:none}
.tt thead th.sortable:hover{color:var(--ink-2)}
.tt th .th-in{display:inline-flex;align-items:center;gap:5px}
.tt th .sort-ic{display:inline-flex;flex-direction:column;color:var(--muted-2)}
.tt tbody tr{border-bottom:1px solid var(--border);transition:.12s;cursor:pointer}
.tt tbody tr:hover{background:var(--surface-2)}
.tt tbody tr.open{background:var(--wm-orange-tint)}
.tt tbody tr.open:hover{background:var(--wm-orange-tint)}
.tt td{padding:13px 16px;font-size:13.5px;color:var(--ink-2);vertical-align:middle}
.tt .cust{display:flex;align-items:center;gap:11px}
.tt .cust .ava{width:36px;height:36px;border-radius:50%;display:grid;place-items:center;color:#fff;font-weight:700;font-size:13px;flex-shrink:0}
.tt .cust .nm{font-weight:700;color:var(--ink);font-size:13.5px}
.tt .cust .em{font-size:12px;color:var(--muted)}

/* stamp dots */
.stamps{display:flex;align-items:center;gap:4px}
.stamps .s{width:14px;height:14px;border-radius:50%;border:1.5px solid var(--border-strong);background:#fff;transition:.2s}
.stamps .s.on{background:var(--wm-orange);border-color:var(--wm-orange)}
.stamps .s.pop{animation:stamp .45s cubic-bezier(.34,1.56,.64,1)}
.stamp-num{font-size:12px;font-weight:800;color:var(--muted);margin-left:4px}

/* inline edit */
.cell-edit{display:inline-flex;align-items:center;gap:6px;padding:3px 8px;border-radius:8px;transition:.13s;cursor:text}
.cell-edit:hover{background:var(--wm-orange-tint);box-shadow:inset 0 0 0 1px var(--wm-orange-tint-2)}
.cell-edit .pen{opacity:0;color:var(--wm-orange);transition:.13s}
.cell-edit:hover .pen{opacity:1}
.inline-input{width:64px;height:30px;border-radius:8px;border:1.5px solid var(--wm-orange);padding:0 8px;font-size:13px;font-weight:700;outline:none;box-shadow:0 0 0 4px var(--wm-orange-tint)}
.note-input{width:100%;min-width:180px;height:32px;border-radius:8px;border:1.5px solid var(--wm-orange);padding:0 10px;font-size:13px;outline:none;box-shadow:0 0 0 4px var(--wm-orange-tint)}
.note-txt{color:var(--muted);font-style:italic;font-size:12.5px}

.row-detail{background:#fff;border-bottom:1px solid var(--border)}
.row-detail .inner{padding:0 16px}

/* ---------- Drawer ---------- */
.drawer-scrim{position:fixed;inset:0;background:rgba(20,28,44,.34);backdrop-filter:blur(2px);z-index:80;animation:fade .2s ease}
.drawer{position:fixed;top:0;right:0;height:100vh;width:440px;max-width:92vw;background:#fff;z-index:90;box-shadow:var(--sh-pop);display:flex;flex-direction:column;animation:slideIn .26s cubic-bezier(.16,1,.3,1)}
.drawer-head{padding:22px 24px;border-bottom:1px solid var(--border);display:flex;align-items:flex-start;gap:14px}
.drawer-body{flex:1;overflow-y:auto;padding:22px 24px}
.drawer .x{margin-left:auto;width:34px;height:34px;border-radius:9px;display:grid;place-items:center;color:var(--muted);background:var(--surface-2)}
.drawer .x:hover{background:var(--border);color:var(--ink)}

/* timeline */
.tl{position:relative;padding-left:26px}
.tl::before{content:"";position:absolute;left:7px;top:6px;bottom:6px;width:2px;background:var(--border)}
.tl-item{position:relative;padding-bottom:18px}
.tl-item:last-child{padding-bottom:0}
.tl-dot{position:absolute;left:-26px;top:2px;width:16px;height:16px;border-radius:50%;border:3px solid #fff;display:grid;place-items:center}
.tl-item .tt-row{display:flex;justify-content:space-between;gap:10px}
.tl-item .tt-t{font-size:13px;font-weight:700;color:var(--ink)}
.tl-item .tt-d{font-size:11.5px;color:var(--muted)}
.tl-item .tt-m{font-size:12.5px;color:var(--muted);margin-top:1px}

/* ---------- Phone simulator ---------- */
.phone-fab{position:fixed;right:26px;bottom:26px;z-index:70;height:52px;padding:0 18px;border-radius:30px;background:var(--ink);color:#fff;display:flex;align-items:center;gap:10px;font-weight:700;font-size:13.5px;box-shadow:var(--sh-3);transition:.18s}
.phone-fab:hover{transform:translateY(-2px);box-shadow:var(--sh-pop)}
.phone-panel{position:fixed;right:26px;bottom:26px;z-index:75;width:312px;animation:popUp .3s cubic-bezier(.16,1,.3,1)}
.phone{background:#0E1422;border-radius:38px;padding:11px;box-shadow:var(--sh-pop);border:1px solid #232c3e}
.phone-screen{background:linear-gradient(180deg,#fff,#FBFBFC);border-radius:30px;overflow:hidden;position:relative;height:512px;display:flex;flex-direction:column}
.phone-notch{position:absolute;top:9px;left:50%;transform:translateX(-50%);width:84px;height:18px;background:#0E1422;border-radius:12px;z-index:5}
.phone-status{height:36px;display:flex;align-items:flex-end;justify-content:space-between;padding:0 22px 4px;font-size:11px;font-weight:700;color:var(--ink)}
.pcard{margin:8px 14px 0;border-radius:20px;padding:16px;color:#fff;position:relative;overflow:hidden;box-shadow:0 10px 24px rgba(255,138,0,.3)}
.pcard .biz{font-size:11px;font-weight:700;opacity:.85;letter-spacing:.04em;text-transform:uppercase}
.pcard .cust{font-size:17px;font-weight:800;margin-top:2px}
.pgrid{display:grid;grid-template-columns:repeat(5,1fr);gap:9px;margin-top:14px}
.pgrid .ps{aspect-ratio:1;border-radius:11px;background:rgba(255,255,255,.22);display:grid;place-items:center;transition:.25s}
.pgrid .ps.on{background:#fff}
.pgrid .ps.pop{animation:stamp .5s cubic-bezier(.34,1.56,.64,1)}
.phone-foot{margin-top:auto;padding:14px}
.phone-select{width:100%;height:40px;border-radius:11px;border:1px solid var(--border);background:var(--surface-2);padding:0 12px;font-size:12.5px;font-weight:700;color:var(--ink);margin-bottom:10px;outline:none}
.scan-btn{width:100%;height:46px;border-radius:13px;background:var(--wm-orange);color:#fff;font-weight:800;font-size:14px;display:flex;align-items:center;justify-content:center;gap:9px;box-shadow:0 8px 18px rgba(255,138,0,.34);transition:.15s}
.scan-btn:hover{background:var(--wm-orange-600)}
.scan-btn:active{transform:scale(.97)}
.scan-btn.done{background:var(--green);box-shadow:0 8px 18px rgba(22,163,74,.34)}
.phone-close{position:absolute;top:-12px;right:-12px;width:30px;height:30px;border-radius:50%;background:#fff;box-shadow:var(--sh-2);display:grid;place-items:center;color:var(--ink-2);z-index:10}
.qr-pulse{position:absolute;inset:0;display:grid;place-items:center;background:rgba(14,20,34,.6);backdrop-filter:blur(2px);z-index:8;border-radius:30px;animation:fade .2s}

/* toast */
.toast-wrap{position:fixed;left:50%;bottom:30px;transform:translateX(-50%);z-index:120;display:flex;flex-direction:column;gap:8px;align-items:center}
.toast{display:flex;align-items:center;gap:11px;background:var(--ink);color:#fff;padding:12px 18px;border-radius:13px;box-shadow:var(--sh-pop);font-size:13.5px;font-weight:600;animation:toastIn .3s cubic-bezier(.16,1,.3,1)}
.toast .tc{width:26px;height:26px;border-radius:50%;display:grid;place-items:center;flex-shrink:0}

/* ---------- Generic bits ---------- */
.section-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);box-shadow:var(--sh-1);overflow:hidden}
.section-card .sc-head{padding:18px 22px;border-bottom:1px solid var(--border);display:flex;align-items:center;gap:12px}
.section-card .sc-head h3{margin:0;font-size:16px;font-weight:800;letter-spacing:-.2px}
.section-card .sc-head .sub{font-size:12.5px;color:var(--muted);margin-top:2px}
.field{margin-bottom:18px}
.field label{display:block;font-size:12.5px;font-weight:700;color:var(--ink-2);margin-bottom:7px}
.field .hint{font-size:11.5px;color:var(--muted);margin-top:6px}
.input{width:100%;height:42px;border-radius:11px;border:1px solid var(--border);background:var(--surface-2);padding:0 14px;font-size:13.5px;color:var(--ink);outline:none;transition:.15s}
.input:focus{border-color:var(--wm-orange);background:#fff;box-shadow:0 0 0 4px var(--wm-orange-tint)}
textarea.input{height:auto;padding:12px 14px;resize:vertical;min-height:84px;line-height:1.5}

/* toggle cards (program type) */
.choice{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.choice-card{border:1.5px solid var(--border);border-radius:var(--r-lg);padding:18px;cursor:pointer;transition:.16s;background:var(--surface-2);position:relative}
.choice-card:hover{border-color:var(--border-strong);background:#fff}
.choice-card.sel{border-color:var(--wm-orange);background:var(--wm-orange-tint);box-shadow:0 0 0 4px var(--wm-orange-tint)}
.choice-card .ck{position:absolute;top:14px;right:14px;width:22px;height:22px;border-radius:50%;border:2px solid var(--border-strong);display:grid;place-items:center;transition:.16s}
.choice-card.sel .ck{background:var(--wm-orange);border-color:var(--wm-orange);color:#fff}
.choice-card h4{margin:8px 0 4px;font-size:15px;font-weight:800}
.choice-card p{margin:0;font-size:12.5px;color:var(--muted);line-height:1.45}
.choice-card .ic-wrap{width:42px;height:42px;border-radius:12px;display:grid;place-items:center;background:#fff;border:1px solid var(--border);color:var(--wm-orange)}
.choice-card.sel .ic-wrap{background:#fff}

/* switch */
.switch{width:42px;height:24px;border-radius:20px;background:var(--border-strong);position:relative;transition:.18s;flex-shrink:0;cursor:pointer}
.switch.on{background:var(--wm-orange)}
.switch .knob{position:absolute;top:2px;left:2px;width:20px;height:20px;border-radius:50%;background:#fff;box-shadow:0 1px 3px rgba(0,0,0,.2);transition:.18s}
.switch.on .knob{transform:translateX(18px)}
.opt-row{display:flex;align-items:center;gap:14px;padding:14px 0;border-bottom:1px solid var(--border)}
.opt-row:last-child{border-bottom:none}
.opt-row .ic-wrap{width:38px;height:38px;border-radius:10px;display:grid;place-items:center;background:var(--surface-2);color:var(--ink-2);flex-shrink:0}
.opt-row .t{font-size:13.5px;font-weight:700;color:var(--ink)}
.opt-row .s{font-size:12px;color:var(--muted);margin-top:1px}

/* tier list */
.tier-row{display:flex;align-items:center;gap:14px;padding:16px;border:1px solid var(--border);border-radius:var(--r);margin-bottom:10px;background:var(--surface-2);transition:.15s}
.tier-row:hover{border-color:var(--border-strong);background:#fff;box-shadow:var(--sh-1)}
.tier-badge{width:46px;height:46px;border-radius:13px;display:grid;place-items:center;color:#fff;font-weight:800;flex-shrink:0;box-shadow:var(--sh-1)}

/* empty/coming */
.placeholder{border:1.5px dashed var(--border-strong);border-radius:var(--r-lg);background:repeating-linear-gradient(45deg,#fafbfc,#fafbfc 11px,#f3f4f6 11px,#f3f4f6 22px);min-height:220px;display:grid;place-items:center;text-align:center;color:var(--muted);padding:30px}
.placeholder .mono{font-family:var(--mono);font-size:11.5px;letter-spacing:.02em;color:var(--muted-2);margin-top:6px}

/* qr block */
.qr-box{width:188px;height:188px;border-radius:var(--r-lg);background:#fff;border:1px solid var(--border);display:grid;place-items:center;box-shadow:var(--sh-1);padding:14px}
.qr-grid{display:grid;grid-template-columns:repeat(11,1fr);gap:2px;width:100%;height:100%}
.qr-grid i{border-radius:1px}

/* mini bar chart */
.bars{display:flex;align-items:flex-end;gap:10px;height:170px;padding-top:10px}
.bars .bar{flex:1;border-radius:7px 7px 0 0;background:linear-gradient(180deg,var(--wm-orange),#FFB85C);position:relative;transition:.3s;min-height:6px}
.bars .bar.alt{background:linear-gradient(180deg,#CBD3DE,#E4E8EE)}
.bars .bar:hover{filter:brightness(1.05)}
.bar-x{display:flex;gap:10px;margin-top:8px}
.bar-x span{flex:1;text-align:center;font-size:11px;color:var(--muted);font-weight:600}

/* donut */
.donut{width:150px;height:150px;border-radius:50%;display:grid;place-items:center;position:relative}
.donut .hole{width:96px;height:96px;border-radius:50%;background:#fff;display:grid;place-items:center;text-align:center}

.list-row{display:flex;align-items:center;gap:14px;padding:14px 18px;border-bottom:1px solid var(--border);transition:.12s}
.list-row:last-child{border-bottom:none}
.list-row:hover{background:var(--surface-2)}

/* template cards (email) */
.tpl-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.tpl{border:1px solid var(--border);border-radius:var(--r-lg);overflow:hidden;background:#fff;transition:.16s;cursor:pointer}
.tpl:hover{border-color:var(--wm-orange);box-shadow:var(--sh-2);transform:translateY(-2px)}
.tpl .prev{height:130px;background:var(--surface-2);position:relative;overflow:hidden}
.tpl .meta{padding:12px 14px}
.tpl .meta .t{font-size:13.5px;font-weight:800}
.tpl .meta .s{font-size:11.5px;color:var(--muted)}

/* ---------- Animations ---------- */
@keyframes pop{from{opacity:0;transform:translateY(-6px) scale(.98)}to{opacity:1;transform:none}}
@keyframes popUp{from{opacity:0;transform:translateY(20px) scale(.96)}to{opacity:1;transform:none}}
@keyframes fade{from{opacity:0}to{opacity:1}}
@keyframes slideIn{from{transform:translateX(40px);opacity:.4}to{transform:none;opacity:1}}
@keyframes stamp{0%{transform:scale(1)}40%{transform:scale(1.4)}100%{transform:scale(1)}}
@keyframes flash{0%{color:var(--wm-orange)}100%{color:var(--ink)}}
@keyframes toastIn{from{opacity:0;transform:translateY(16px)}to{opacity:1;transform:none}}
@keyframes spin{to{transform:rotate(360deg)}}
.spin{animation:spin 1s linear infinite}

/* responsive */
@media(max-width:1180px){
  .kpi-grid,.action-grid{grid-template-columns:repeat(2,1fr)}
  .tpl-grid{grid-template-columns:repeat(2,1fr)}
}
@media(max-width:900px){
  .sidebar{display:none}
  .page,.topbar{padding-left:20px;padding-right:20px}
}

/* ---------- Login (integración) ---------- */
.login-wrap{min-height:100vh;display:grid;place-items:center;padding:24px;
  background:radial-gradient(1200px 600px at 50% -10%,var(--wm-orange-tint),var(--bg) 60%)}
.login-card{width:100%;max-width:380px;background:var(--surface);border:1px solid var(--border);
  border-radius:var(--r-xl);box-shadow:var(--sh-3);padding:30px 28px}
.login-logo{display:flex;align-items:baseline;gap:2px;font-weight:800;font-size:22px;letter-spacing:-.5px;justify-content:center;margin-bottom:18px}
.login-logo .mark{width:28px;height:28px;margin-right:6px;border-radius:9px;background:linear-gradient(135deg,var(--wm-orange),#FFB347);display:grid;place-items:center;color:#fff;font-weight:800;font-size:14px;box-shadow:0 4px 10px rgba(255,138,0,.35);align-self:center}
.login-logo .wm{color:var(--ink)} .login-logo .ag{color:var(--wm-orange)}
.login-title{font-size:22px;font-weight:800;letter-spacing:-.4px;text-align:center;margin:0}
.login-sub{font-size:13px;color:var(--muted);text-align:center;margin:6px 0 22px}
.login-err{display:flex;align-items:center;gap:7px;background:#FDECEC;color:#DC2626;font-size:12.5px;font-weight:600;padding:9px 12px;border-radius:10px;margin-top:6px}
.login-foot{font-size:11.5px;color:var(--muted);text-align:center;margin-top:18px;line-height:1.5}
.login-foot .mono{font-family:var(--mono);font-size:11px;color:var(--muted-2)}

/* ---------- Plan Free/Pro ---------- */
.pro-pill{margin-left:auto;font-size:9.5px;font-weight:800;letter-spacing:.04em;padding:2px 7px;border-radius:20px;background:linear-gradient(135deg,#FFD27A,#F6A623);color:#5a3d00}
.nav-item.active .pro-pill{background:rgba(255,255,255,.9);color:#a36a00}
.plan-pill{font-size:10px;font-weight:800;padding:2px 8px;border-radius:20px;margin-left:8px}
.plan-pill.pro{background:linear-gradient(135deg,#FFD27A,#F6A623);color:#5a3d00}
.upgrade-hero{background:linear-gradient(135deg,#1b2330,#2b3650);color:#fff;border-radius:var(--r-xl);padding:38px 34px;text-align:center;box-shadow:var(--sh-3);position:relative;overflow:hidden}
.upgrade-hero .up-badge{display:inline-block;font-size:12px;font-weight:800;letter-spacing:.08em;padding:4px 12px;border-radius:20px;background:linear-gradient(135deg,#FFD27A,#F6A623);color:#5a3d00;margin-bottom:14px}
.upgrade-hero h1{font-size:26px;font-weight:800;letter-spacing:-.5px;margin:0 0 10px;max-width:560px;margin-inline:auto}
.upgrade-hero p{color:#c7d0de;font-size:14.5px;max-width:520px;margin:0 auto 22px;line-height:1.55}
.upgrade-hero .up-note{font-size:12px;color:#9fb0c8;margin-top:12px}
.up-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-top:22px}
.up-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);padding:18px;box-shadow:var(--sh-1)}
.up-card .ic-wrap{width:40px;height:40px;border-radius:12px;display:grid;place-items:center;background:var(--wm-orange-tint);color:var(--wm-orange-700);margin-bottom:12px}
.up-card h4{margin:0 0 4px;font-size:14.5px;font-weight:800}
.up-card p{margin:0;font-size:12.5px;color:var(--muted);line-height:1.45}
@media(max-width:1180px){ .up-grid{grid-template-columns:repeat(2,1fr)} }
