:root{--bg:#070a12;--panel:#10141f;--panel2:#151927;--muted:#9da3b4;--text:#f7f7fb;--pink:#ff4fa3;--pink2:#ff7cc5;--green:#54e38a;--purple:#9b6cff;--blue:#5ab0ff;--line:rgba(255,255,255,.09);--danger:#ff5b6e;--shadow:0 18px 45px rgba(0,0,0,.35)}*{box-sizing:border-box}body{margin:0;font-family:Inter,system-ui,-apple-system,Segoe UI,Arial,sans-serif;background:radial-gradient(circle at top right,#251020 0,#070a12 35%,#060811 100%);color:var(--text)}a{color:inherit;text-decoration:none}.app-shell{min-height:100vh;display:flex}.sidebar{width:250px;border-right:1px solid var(--line);background:rgba(9,12,20,.82);backdrop-filter:blur(18px);padding:22px 16px;position:fixed;inset:0 auto 0 0;z-index:10}.brand{display:flex;align-items:center;gap:12px;margin-bottom:28px}.brand img{width:48px;height:48px;object-fit:contain;border-radius:14px}.bra-icon{width:48px;height:48px;border-radius:15px;background:linear-gradient(135deg,var(--pink),var(--pink2));display:grid;place-items:center;font-size:27px}.brand strong{display:block;font-size:18px}.brand span,.mobile-brand span{display:block;color:var(--pink2);font-size:28px;font-family:cursive;margin-top:-6px}.sidebar nav{display:grid;gap:8px}.sidebar a{padding:14px 16px;border-radius:14px;color:#d5d8e3}.sidebar a.active,.sidebar a:hover{background:linear-gradient(90deg,rgba(255,79,163,.23),rgba(255,79,163,.08));color:#fff}.main{margin-left:250px;width:calc(100% - 250px);padding-bottom:30px}.topbar{height:82px;border-bottom:1px solid var(--line);display:flex;align-items:center;justify-content:space-between;padding:0 34px;background:rgba(9,12,20,.48);position:sticky;top:0;z-index:5;backdrop-filter:blur(16px)}.menu-btn{display:none;background:none;border:0;color:white;font-size:25px}.mobile-brand{display:none}.user-pill{background:rgba(255,255,255,.06);border:1px solid var(--line);padding:10px 15px;border-radius:999px}.content{padding:34px;max-width:1240px}.page-head{display:flex;justify-content:space-between;gap:16px;align-items:flex-start;margin-bottom:24px}.page-head h1{margin:0;font-size:31px}.page-head p{margin:8px 0 0;color:var(--muted)}.btn{border:0;border-radius:14px;padding:13px 18px;background:linear-gradient(135deg,var(--pink),#d93489);color:white;font-weight:800;box-shadow:0 10px 28px rgba(255,79,163,.23);cursor:pointer;display:inline-flex;align-items:center;justify-content:center;gap:8px}.btn.secondary{background:#1b2030;box-shadow:none;border:1px solid var(--line)}.btn.danger{background:var(--danger)}.grid{display:grid;gap:18px}.cards{grid-template-columns:repeat(4,1fr)}.card{background:linear-gradient(180deg,rgba(255,255,255,.055),rgba(255,255,255,.025));border:1px solid var(--line);border-radius:22px;padding:22px;box-shadow:var(--shadow)}.kpi small{color:var(--muted)}.kpi h2{margin:12px 0 8px;font-size:27px}.kpi.pink{border-color:rgba(255,79,163,.28)}.kpi.green{border-color:rgba(84,227,138,.22)}.kpi.purple{border-color:rgba(155,108,255,.24)}.kpi.blue{border-color:rgba(90,176,255,.24)}.pos{color:var(--green);font-size:13px}.quick{grid-template-columns:repeat(4,1fr)}.quick .btn{height:74px;flex-direction:column;border-radius:18px}.layout{grid-template-columns:1.35fr .85fr;align-items:start}.table-wrap{overflow:auto}table{width:100%;border-collapse:collapse;min-width:690px}th,td{text-align:left;padding:14px;border-bottom:1px solid var(--line);font-size:14px}th{color:#c8ccda;font-size:12px;font-weight:600}.thumb{width:44px;height:44px;border-radius:12px;object-fit:cover;background:#202536}.profit{color:var(--green);font-weight:800}.loss{color:var(--danger);font-weight:800}.form{display:grid;gap:16px}.form-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:16px}.field label{display:block;font-size:13px;color:#cdd2df;margin-bottom:8px}.field input,.field select,.field textarea{width:100%;background:#0d111d;border:1px solid var(--line);color:#fff;border-radius:14px;padding:13px 14px;outline:none}.field textarea{min-height:90px}.hint{color:var(--muted);font-size:13px}.alert{padding:13px 15px;border-radius:14px;margin-bottom:16px}.alert.ok{background:rgba(84,227,138,.1);border:1px solid rgba(84,227,138,.25)}.alert.err{background:rgba(255,91,110,.1);border:1px solid rgba(255,91,110,.25)}.product-grid{grid-template-columns:repeat(3,1fr)}.product-card img{width:100%;height:190px;object-fit:cover;border-radius:18px;background:#202536}.product-card h3{margin:13px 0 4px}.pill{display:inline-block;padding:5px 9px;border-radius:999px;background:rgba(255,79,163,.13);color:var(--pink2);font-size:12px}.bottom-nav{display:none}.login-page{min-height:100vh;display:grid;place-items:center;padding:22px}.login-box{width:100%;max-width:420px}.logo-login{text-align:center;margin-bottom:18px}.logo-login .bra-icon{margin:auto}.logo-login span{color:var(--pink2);font-size:34px;font-family:cursive}.chart-list{display:grid;gap:12px}.bar-row{display:grid;grid-template-columns:120px 1fr 80px;gap:10px;align-items:center;font-size:13px}.bar{height:10px;background:#202536;border-radius:999px;overflow:hidden}.bar i{display:block;height:100%;background:linear-gradient(90deg,var(--pink),var(--purple));border-radius:999px}@media(max-width:960px){.cards{grid-template-columns:repeat(2,1fr)}.layout{grid-template-columns:1fr}.quick{grid-template-columns:repeat(2,1fr)}.product-grid{grid-template-columns:repeat(2,1fr)}}@media(max-width:720px){body{background:#070a12}.sidebar{transform:translateX(-105%);transition:.2s}.menu-open .sidebar{transform:translateX(0)}.main{margin-left:0;width:100%;padding-bottom:82px}.topbar{height:68px;padding:0 16px}.menu-btn,.mobile-brand{display:block}.user-pill{font-size:13px;padding:8px 10px}.content{padding:18px}.page-head{display:block}.page-head h1{font-size:25px}.page-head .btn{width:100%;margin-top:15px}.cards{grid-template-columns:repeat(2,1fr);gap:12px}.card{padding:16px;border-radius:18px}.kpi h2{font-size:21px}.form-grid{grid-template-columns:1fr}.product-grid{grid-template-columns:1fr}.bottom-nav{position:fixed;left:0;right:0;bottom:0;height:72px;background:rgba(12,15,24,.96);border-top:1px solid var(--line);display:grid;grid-template-columns:repeat(5,1fr);z-index:12}.bottom-nav a{display:grid;place-items:center;font-size:12px;color:#dce0ea}.bottom-nav .fab{width:58px;height:58px;border-radius:50%;background:linear-gradient(135deg,var(--pink),#d93489);margin:-20px auto 0;font-size:32px;color:white;box-shadow:0 12px 30px rgba(255,79,163,.35)}table{min-width:560px}.bar-row{grid-template-columns:90px 1fr 65px}.mobile-brand{font-weight:700}.mobile-brand span{font-size:22px;display:inline}}@media(max-width:390px){.cards{grid-template-columns:1fr}.quick{grid-template-columns:1fr 1fr}.content{padding:14px}}
.recommend-box{background:rgba(255,79,163,.08);border:1px solid rgba(255,79,163,.22);border-radius:18px;padding:16px;display:grid;gap:9px}.recommend-box div{display:flex;justify-content:space-between;gap:12px;align-items:center}.recommend-box b{color:#fff}.recommend-box strong{color:var(--pink2)}.recommend-box .divider{height:1px;background:var(--line);padding:0;margin:4px 0;display:block}.recommend-box .profit{color:var(--green)}.recommend-box .loss{color:var(--danger)}@media(max-width:720px){.recommend-box div{display:grid;gap:3px}}
.btn.small{padding:9px 12px;border-radius:12px;font-size:12px}.inline-form{display:inline}.actions-row{display:flex;gap:10px;align-items:center;flex-wrap:wrap;margin-top:14px}.muted-pill{background:rgba(255,255,255,.08);color:#cfd3df}.product-card.is-inactive{opacity:.72}.modal-backdrop{position:fixed;inset:0;background:rgba(0,0,0,.62);display:none;align-items:center;justify-content:center;padding:20px;z-index:100}.modal-backdrop.show{display:flex}.modal-card{width:min(440px,100%);background:#121725;border:1px solid var(--line);border-radius:24px;padding:24px;box-shadow:0 25px 80px rgba(0,0,0,.55)}.modal-card h3{margin:0 0 10px}.modal-card p{margin:0;color:#d7dbea;line-height:1.5}.modal-actions{display:flex;gap:12px;justify-content:flex-end;margin-top:22px}@media(max-width:720px){.actions-row .btn,.actions-row form{width:100%}.actions-row form .btn{width:100%}.modal-actions{display:grid;grid-template-columns:1fr}.modal-actions .btn{width:100%}}

/* v1.3 - Ajustes móviles para evitar desplazamiento horizontal */
html,body{max-width:100%;overflow-x:hidden}.app-shell,.main,.content{max-width:100%;min-width:0}.grid,.layout,.layout>* ,.card,.table-wrap{min-width:0}.table-wrap{max-width:100%;}
@media(max-width:720px){
  .content{width:100%;max-width:100vw;overflow-x:hidden}
  .bottom-nav{width:100vw;max-width:100vw;overflow:hidden}
  .bottom-nav a{min-width:0;white-space:nowrap}
  .card{width:100%;max-width:100%;overflow:hidden}
  .table-wrap{overflow-x:auto;overscroll-behavior-x:contain;-webkit-overflow-scrolling:touch}
  .table-wrap table{min-width:0;width:100%;table-layout:fixed}
  .table-wrap th,.table-wrap td{padding:11px 8px;font-size:12px;vertical-align:middle;word-break:normal;overflow-wrap:anywhere}
  .thumb{width:42px;height:42px;display:block;margin-bottom:6px}
  .dashboard-recent th:nth-child(5),.dashboard-recent td:nth-child(5){display:none}
  .dashboard-recent th:nth-child(1),.dashboard-recent td:nth-child(1){width:38%}
  .dashboard-recent th:nth-child(2),.dashboard-recent td:nth-child(2){width:22%}
  .dashboard-recent th:nth-child(3),.dashboard-recent td:nth-child(3){width:20%}
  .dashboard-recent th:nth-child(4),.dashboard-recent td:nth-child(4){width:20%}
  .dashboard-recent td:nth-child(1){font-size:12px;line-height:1.2}
  .dashboard-recent .profit,.dashboard-recent .loss{font-size:12px;white-space:nowrap}
  .bar-row{grid-template-columns:1fr 34px;gap:8px;width:100%;align-items:center}
  .bar-row span{grid-column:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
  .bar-row b{grid-column:2;text-align:right}
  .bar-row .bar{grid-column:1 / -1;grid-row:2;width:100%}
}
@media(max-width:390px){
  .dashboard-recent th:nth-child(3),.dashboard-recent td:nth-child(3){display:none}
  .dashboard-recent th:nth-child(1),.dashboard-recent td:nth-child(1){width:48%}
  .dashboard-recent th:nth-child(2),.dashboard-recent td:nth-child(2){width:25%}
  .dashboard-recent th:nth-child(4),.dashboard-recent td:nth-child(4){width:27%}
}

/* v1.4 - Ajuste final del menú inferior móvil: FAB completo y margen de seguridad */
@media(max-width:720px){
  .main{padding-bottom:118px}
  .content{padding-bottom:132px}
  .bottom-nav{
    height:86px;
    padding-top:20px;
    padding-bottom:calc(10px + env(safe-area-inset-bottom, 0px));
    overflow:visible;
  }
  .bottom-nav .fab{
    width:64px;
    height:64px;
    margin:-42px auto 0;
    line-height:1;
    position:relative;
    z-index:2;
  }
}
