*,*:before,*:after{box-sizing:border-box}body{margin:0;font-family:Segoe UI,system-ui,-apple-system,sans-serif;background:var(--bg);color:var(--text);min-height:100vh;transition:background-color .28s ease,color .28s ease}a{color:inherit}input,select,button{font:inherit;color:inherit}:root{--bg: #f5f7fb;--surface: #ffffff;--text: #1b2430;--muted: #5b677a;--primary: #2d6cdf;--primary-contrast: #ffffff;--border: #e3e8f0;--shadow: 0 10px 30px rgba(20, 33, 61, .08);--bg-line: rgba(148, 163, 184, .32);--bg-line-strong: rgba(37, 99, 235, .35)}html[data-theme=dark]{--bg: #0f172a;--surface: #16213a;--text: #e2e8f0;--muted: #9aa4b2;--primary: #60a5fa;--primary-contrast: #0f172a;--border: #26324c;--shadow: 0 10px 30px rgba(2, 6, 23, .5);--bg-line: rgba(30, 64, 175, .6);--bg-line-strong: rgba(56, 189, 248, .6)}html[data-theme=semi]{--bg: #1b1f2e;--surface: #2f3443;--text: #e5e7eb;--muted: #cbd5f5;--primary: #2d6cdf;--primary-contrast: #ffffff;--border: #41485e;--shadow: 0 12px 28px rgba(24, 24, 40, .22);--bg-line: rgba(129, 140, 248, .55);--bg-line-strong: rgba(45, 212, 191, .55)}#root{width:100%}.page{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:32px;animation:fade-up .42s ease;position:relative;overflow:hidden;background-color:var(--bg);background-image:radial-gradient(circle at top left,rgba(45,108,223,.16),transparent 55%),radial-gradient(circle at bottom right,rgba(15,23,42,.5),transparent 60%),linear-gradient(90deg,rgba(148,163,184,.16) 1px,transparent 1px),linear-gradient(180deg,rgba(148,163,184,.12) 1px,transparent 1px);background-size:100% 100%,100% 100%,72px 72px,72px 72px;background-position:center,center,0 0,0 0}.admin-page{align-items:stretch;justify-content:flex-start;padding:0;flex-direction:column}.page:before{content:"";position:absolute;inset:-30%;background-image:repeating-linear-gradient(120deg,transparent 0,transparent 18px,var(--bg-line) 18px,var(--bg-line) 19px),repeating-linear-gradient(60deg,transparent 0,transparent 26px,var(--bg-line-strong) 26px,var(--bg-line-strong) 27px);opacity:.32;transform:translateZ(0);animation:bg-lines 26s linear infinite;pointer-events:none;mix-blend-mode:soft-light}.card{width:min(520px,100%);background:var(--surface);border:1px solid var(--border);border-radius:18px;box-shadow:var(--shadow);padding:32px;display:flex;flex-direction:column;gap:24px;animation:float-in .52s ease;transition:transform .22s ease,box-shadow .22s ease,background-color .28s ease,border-color .28s ease;position:relative;z-index:1}.modal-overlay{position:fixed;inset:0;background-color:#000000b3;display:flex;justify-content:center;align-items:center;z-index:1000}.modal-content{background-color:var(--surface);padding:24px;border-radius:8px;width:420px;max-width:92vw;box-shadow:0 4px 20px #0000004d}.modal-content h3{margin-top:0;margin-bottom:20px;color:var(--text)}.form-group{margin-bottom:16px}.form-group label{display:block;margin-bottom:8px;color:var(--text);font-size:.9rem}.form-group input,.form-group select{width:100%;padding:10px;border-radius:6px;border:1px solid var(--border);background-color:var(--bg);color:var(--text);font-size:1rem}.modal input[type=number]::-webkit-outer-spin-button,.modal input[type=number]::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}.modal input[type=number]{-moz-appearance:textfield;appearance:textfield}.modal-actions{display:flex;justify-content:flex-end;gap:10px;margin-top:24px}.card.card-wide{width:min(620px,100%)}.admin-topbar{width:100%;padding:14px 28px 10px;display:flex;align-items:center;justify-content:space-between;gap:20px;position:relative;z-index:60}.admin-topbar-brand{display:inline-flex;align-items:center;gap:10px}.admin-topbar-mark{width:24px;height:24px;border-radius:10px;background:linear-gradient(135deg,var(--primary),#0f172a)}.admin-topbar-title{font-size:14px;font-weight:700}.admin-header{align-items:center}.admin-header-right{display:flex;align-items:center;gap:10px}.admin-role-badge{display:inline-flex;align-items:center;justify-content:center;padding:4px 10px;border-radius:999px;font-size:12px;font-weight:600;border:1px solid var(--border);color:var(--muted);background:var(--surface)}.admin-body{display:grid;grid-template-columns:minmax(160px,200px) minmax(0,1fr);gap:16px;padding:10px clamp(14px,2vw,28px) 22px;width:100%;box-sizing:border-box;min-width:0}.admin-body.admin-body-single{grid-template-columns:minmax(0,1fr)}.admin-sidebar{border-radius:18px;background:linear-gradient(180deg,var(--primary) 0%,rgba(37,99,235,.92) 100%);padding:16px 12px;display:grid;grid-template-rows:auto 1fr;gap:12px;color:var(--primary-contrast);position:relative;z-index:1}.admin-sidebar-header{display:flex;align-items:center;gap:10px;padding:4px 6px 8px}.admin-sidebar-logo{width:28px;height:28px;border-radius:10px;background:#0f172a38}.admin-sidebar-title{font-size:13px;font-weight:600}.admin-sidebar-nav{display:flex;flex-direction:column;gap:5px}.admin-nav-item{width:100%;height:50px;display:flex;align-items:center;justify-content:flex-start;text-align:left;margin:0;border-radius:999px;border:1px solid rgba(15,23,42,.2);background:var(--surface);color:var(--text);cursor:pointer;padding:8px 12px;font-size:13px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;transition:background-color .18s ease,color .18s ease,border-color .18s ease,transform .16s ease}.admin-nav-item:hover{background:#e5edff;transform:translate(1px)}.admin-nav-item.active{background:var(--primary-contrast);color:var(--primary);border-color:#fffc}.admin-main{border-radius:14px;border:1px solid var(--border);background:var(--surface);padding:16px 18px 20px;display:grid;gap:12px;color:var(--text);min-width:0;max-width:100%}.admin-main>*{min-width:0;max-width:100%}.admin-main-title{margin:0;font-size:18px}.admin-main-text{margin:0;font-size:14px;color:var(--muted)}.admin-toolbar{border-radius:999px;padding:8px 10px;background:var(--surface);border:1px solid var(--border);display:flex;align-items:center;column-gap:5px;row-gap:5px;color:var(--text)}.admin-toolbar-pill{padding:6px 12px;border-radius:999px;background:var(--surface);border:1px solid var(--border);font-size:12px;cursor:pointer}.admin-toolbar-pill.primary{background:var(--primary);color:var(--primary-contrast)}.admin-table-shell{margin-top:4px;border-radius:14px;border:1px solid var(--border);background:var(--surface);padding:10px 0;overflow-x:auto}.admin-table-actions{display:flex;align-items:center;column-gap:5px;row-gap:5px;padding:0 14px 8px}.admin-table-form{display:grid;grid-template-columns:minmax(0,1fr) minmax(0,2fr) auto;gap:8px;padding:0 14px 8px}.admin-table-form input{border-radius:999px;border:1px solid var(--border);padding:6px 10px;background:var(--surface);color:var(--text);font-size:12px}.admin-table-filters{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:8px;padding:0 14px 8px;font-size:12px}.admin-table-filters input{border-radius:999px;border:1px solid var(--border);padding:6px 10px;background:var(--surface);color:var(--text);font-size:12px}.admin-table-shell .theme-button{background:var(--surface);max-width:160px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;flex-shrink:0}.admin-table-header{display:grid;grid-template-columns:minmax(0,2fr) minmax(0,1fr) minmax(0,1fr) auto;gap:4px;padding:0 14px 8px;font-size:12px}.admin-table-header .admin-table-cell:last-child{display:flex;justify-content:flex-end}.admin-table{width:100%;border-collapse:collapse}.admin-table thead th{text-align:left;font-size:12px;font-weight:600;color:var(--muted);padding:10px 14px;border-bottom:1px solid var(--border)}.admin-table tbody td{padding:10px 14px;border-bottom:1px solid var(--border);font-size:13px;vertical-align:middle}.admin-table tbody tr.admin-table-row{cursor:pointer}.admin-table tbody tr.admin-table-row:hover td{background:#94a3b814}.admin-table thead th:last-child,.admin-table tbody td:last-child{text-align:right;width:1%;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.admin-table-view-toggle{display:flex;justify-content:flex-end;align-items:center;gap:6px;padding:0 14px 8px}.admin-table-view-toggle button{border-radius:999px;border:1px solid var(--border);background:var(--surface);color:var(--text);font-size:12px;padding:4px 10px;cursor:pointer}.admin-table-view-toggle button.active{background:var(--primary);color:var(--primary-contrast);border-color:var(--primary)}@media(max-width:768px){.admin-table--cards{border-collapse:separate;border-spacing:0 8px}.admin-table--cards thead{display:none}.admin-table--cards tbody{display:block}.admin-table--cards tbody tr{display:block;margin:0 8px 8px;background:var(--surface);border-radius:12px;border:1px solid var(--border);box-shadow:0 4px 10px #0f172a14}.admin-table--cards tbody td{display:flex;justify-content:space-between;align-items:flex-start;gap:8px;border-bottom:1px solid var(--border)}.admin-table--cards tbody td:last-child{border-bottom:none}.admin-table--cards tbody td:before{content:attr(data-label);font-weight:600;color:var(--muted);margin-right:8px;flex:0 0 auto}}.catalogo-desktop-table{width:100%}.catalogo-mobile-cards{display:none}.catalogo-card-grid{display:grid;grid-template-columns:minmax(0,1fr);gap:10px;padding:0 14px 10px}.catalogo-card{border-radius:12px;border:1px solid var(--border);background:var(--surface);padding:10px 12px;text-align:left;display:grid;gap:6px;cursor:pointer;box-shadow:0 4px 10px #0f172a14}.catalogo-card-header{display:flex;align-items:flex-start;justify-content:space-between;gap:8px}.catalogo-card-title-group{display:grid;gap:2px}.catalogo-card-sku{font-size:11px;color:var(--muted)}.catalogo-card-nombre{font-size:14px;font-weight:600}.catalogo-card-precio{font-size:13px;font-weight:600}.catalogo-card-tags{display:flex;flex-wrap:wrap;gap:6px}.catalogo-card-chip{font-size:11px;padding:2px 8px;border-radius:999px;border:1px solid var(--border);background:#94a3b814}.catalogo-card-chip.chip-success{border-color:#16a34a;color:#16a34a;background:#16a34a14}.catalogo-card-chip.chip-danger{border-color:#b91c1c;color:#b91c1c;background:#f8717114}.catalogo-card-body{border-top:1px solid var(--border);padding-top:6px;display:grid;gap:6px}.catalogo-card-descripcion{margin:0;font-size:12px;color:var(--muted)}.catalogo-card-actions{display:flex;flex-wrap:wrap;gap:6px}.modal-backdrop{position:fixed;inset:0;background:#0f172a8c;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:50;padding:16px;overflow-y:auto}.modal{background:var(--surface);border-radius:14px;border:1px solid var(--border);padding:16px 18px 18px;max-width:420px;width:min(420px,100% - 32px);box-shadow:0 18px 40px var(--shadow);color:var(--text);position:relative;max-height:90vh;overflow-y:auto}.modal-large{max-width:1040px;width:min(1040px,100% - 32px)}.modal-title{margin:0 0 6px;font-size:16px}.modal-text{margin:0 0 12px;font-size:13px;color:var(--muted)}.modal-form{display:grid;gap:10px}.modal-form input{border-radius:10px;border:1px solid var(--border);padding:8px 10px;background:var(--surface);color:var(--text);font-size:13px}.modal-form select{border-radius:10px;border:1px solid var(--border);padding:8px 10px;background:var(--surface);color:var(--text);font-size:13px;width:100%;position:relative;z-index:1}.modal-form select:focus{outline:2px solid var(--primary);outline-offset:-1px;z-index:10}.modal-actions{margin-top:8px;display:flex;justify-content:flex-end;gap:8px}.almacen-shape-editor{margin-top:14px;padding-top:12px;border-top:1px solid var(--border);display:grid;gap:10px}.almacen-shape-header{font-size:13px;font-weight:600;display:flex;justify-content:space-between;align-items:center}.editor-zoom-controls{display:flex;align-items:center;gap:4px}.editor-zoom-controls .theme-button.icon-only{padding:2px 6px;min-width:24px}.editor-zoom-controls .theme-button.text-only{padding:2px 6px;font-size:11px}.zoom-label{font-size:11px;color:var(--muted);min-width:32px;text-align:center}.almacen-shape-scroll-wrapper{border-radius:12px;border:1px solid var(--border);background:radial-gradient(circle at top,rgba(148,163,184,.18),transparent 60%),var(--surface);width:100%;height:min(340px,45vh);overflow:auto;position:relative;scrollbar-width:thin;scrollbar-color:rgba(45,108,223,.6) rgba(15,23,42,.06);display:flex}.almacen-shape-canvas-container{position:relative;transform-origin:0 0;margin:auto;flex-shrink:0;box-shadow:0 4px 20px #0000001a}.almacen-shape-svg-element{display:block;width:100%;height:100%}.almacen-shape-actions{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.almacen-shape-hint{font-size:11px;color:var(--muted)}.almacen-shape-options{display:none}.role-permissions-list{max-height:260px;overflow:auto;border-radius:10px;border:1px solid var(--border);padding:6px 8px;background:var(--surface);display:grid;gap:4px;position:relative;z-index:1}.role-permission-item{display:flex;align-items:center;gap:8px;padding:4px 6px;border-radius:8px;font-size:12px}.role-permission-item input[type=checkbox]{margin:0}.role-permission-item.active{background:#2563eb1f}.role-permission-main{display:flex;flex-direction:column;gap:2px}.role-permission-name{font-weight:500}.role-permission-meta{font-size:11px;color:var(--muted)}.role-permission-crud{margin-left:auto;display:flex;gap:6px}.role-permission-crud-button{border-radius:999px;border:1px solid var(--border);padding:3px 8px;font-size:11px;background:var(--surface);color:var(--text);cursor:pointer}.role-permission-crud-button.active{background:var(--primary);color:var(--primary-contrast);border-color:var(--primary)}.acciones-buttons{display:flex;align-items:center;gap:6px;background-color:transparent;flex-wrap:nowrap}.action-button{border:1px solid var(--border);background-color:var(--surface);color:var(--text);padding:4px 8px;border-radius:6px;font-size:12px;cursor:pointer;transition:all .2s}.action-button:hover{border-color:var(--primary);color:var(--primary)}.role-permission-crud-button:disabled{opacity:.4;cursor:default}.admin-table-cell{padding-bottom:4px}.admin-sidebar-nav-mobile{display:none}.admin-sidebar-nav-mobile,.user-menu{position:relative;min-width:0;isolation:isolate}.admin-section-mobile-nav{display:none}@media(max-width:900px){.admin-body{grid-template-columns:minmax(0,1fr);padding:12px 16px 20px}.mobile-nav-menu{display:inline-block;width:118px;max-width:100%}.header-right>.theme-button,.admin-header-right>.theme-button{display:none}.admin-sidebar{grid-template-rows:auto auto;padding:16px;margin-bottom:12px;display:flex;flex-direction:column;border-radius:12px;gap:10px;min-height:0}.admin-sidebar-header{margin-bottom:0;padding:0}.admin-sidebar-nav-desktop{display:none}.admin-sidebar-nav-mobile{display:block;width:100%;margin-top:0}.admin-sidebar.admin-sidebar-mobile-hidden{display:none}.admin-section-mobile-nav{display:block;margin-bottom:12px}.admin-nav-dropdown-trigger{width:100%;padding:10px 14px;border-radius:10px;border:1px solid rgba(255,255,255,.2);background:#0f172a52;color:#f8fafc;font-size:14px;font-weight:500;display:flex;align-items:center;justify-content:space-between;text-align:left;box-sizing:border-box;min-height:44px;cursor:pointer}.admin-nav-dropdown-trigger:hover,.admin-nav-dropdown-trigger.open{background:#0f172a75;border-color:#ffffff47}.admin-nav-dropdown-trigger span{color:#f8fafc}.admin-nav-dropdown-trigger:after{content:"";width:16px;height:16px;background-image:url("data:image/svg+xml;charset=UTF-8,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='white' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3e%3cpolyline points='6 9 12 15 18 9'%3e%3c/polyline%3e%3c/svg%3e");background-repeat:no-repeat;background-position:center;background-size:16px;flex-shrink:0;transition:transform .18s ease}.admin-nav-dropdown-trigger.open:after{transform:rotate(180deg)}.admin-nav-dropdown-menu{position:absolute;top:calc(100% + 8px);left:0;right:0;z-index:20;display:grid;gap:6px;padding:8px;width:100%;max-width:100%;border-radius:12px;border:1px solid rgba(255,255,255,.18);background:#0f172a;box-shadow:0 16px 30px #02061759;box-sizing:border-box;overflow:hidden}.admin-nav-dropdown-item{width:100%;border:1px solid transparent;background:transparent;color:#f8fafc;border-radius:10px;padding:10px 12px;text-align:left;font-size:14px;cursor:pointer}.admin-nav-dropdown-item.active{background:#60a5fa3d;border-color:#93c5fd80;color:#fff}.admin-nav-dropdown-item:hover{background:#ffffff1f}}@media(max-width:768px){.admin-table-filters,.admin-table-form{grid-template-columns:1fr;gap:12px}.admin-table-actions{flex-wrap:wrap;gap:12px}.admin-table-actions button,.admin-table-actions select{width:100%;max-width:none}.admin-table-shell .theme-button{max-width:100%}.admin-table-shell{overflow-x:auto;-webkit-overflow-scrolling:touch;margin-left:-16px;margin-right:-16px;border-radius:0;border-left:none;border-right:none;padding-bottom:10px}.admin-table{min-width:600px}.pagination{flex-wrap:wrap;justify-content:center;gap:10px}.pagination .theme-button{min-width:120px;min-height:40px;padding-inline:16px}.catalogo-desktop-table{display:none}.catalogo-mobile-cards{display:block}}.home-hero{margin-top:4px;margin-bottom:16px;padding:16px 18px;border-radius:14px;border:1px dashed rgba(148,163,184,.45);background:var(--surface);display:grid;grid-template-columns:auto 1fr;gap:14px}.home-hero-graphic{display:grid;gap:4px}.home-hero-block{width:40px;height:10px;border-radius:999px;background:#0f172a2e}.home-hero-block:nth-child(2){width:54px}.home-hero-block:nth-child(3){width:32px}.home-hero-copy{display:grid;gap:4px}.home-hero-title{margin:0;font-size:14px;font-weight:600}.home-hero-text{margin:0;font-size:12px;color:var(--muted)}.almacenes-layout{margin-top:10px;display:grid;grid-template-columns:260px minmax(0,1fr);gap:14px}.almacenes-sidebar{border-radius:14px;border:1px solid var(--border);background:var(--surface);padding:10px 10px 12px;display:grid;grid-template-rows:auto 1fr auto;row-gap:10px}.almacenes-sidebar-title{font-size:13px;font-weight:600}.almacenes-sidebar-empty{font-size:12px;color:var(--muted);padding:6px 2px}.almacenes-list{overflow:auto;display:grid;gap:6px}.almacenes-list-item{border-radius:10px;border:1px solid var(--border);padding:8px 9px;display:grid;gap:2px;text-align:left;background:var(--surface);cursor:pointer;font-size:12px}.almacenes-list-item.active{border-color:var(--primary);background:#2563eb0f}.almacenes-list-name{font-weight:600}.almacenes-list-sub{font-size:11px;color:var(--muted)}.almacenes-create{border-top:1px dashed var(--border);padding-top:8px;display:grid;gap:6px}.almacenes-create-title{font-size:12px;font-weight:600}.almacenes-create input,.almacenes-create select{border-radius:999px;border:1px solid var(--border);padding:6px 10px;background:var(--surface);color:var(--text);font-size:12px}.almacenes-main{border-radius:14px;border:1px solid var(--border);background:radial-gradient(circle at top left,rgba(37,99,235,.15),transparent 46%),var(--surface);padding:12px 14px 14px;display:grid;gap:10px}.almacenes-error{font-size:12px;color:#b91c1c;padding:6px 8px;border-radius:10px;border:1px solid rgba(248,113,113,.6);background:#fef2f2cc}.almacenes-placeholder{font-size:12px;color:var(--muted);padding:10px 4px}.almacenes-toolbar{border-radius:999px;border:1px solid var(--border);background:#0f172a05;padding:6px 8px;display:flex;flex-wrap:wrap;gap:6px;align-items:center;justify-content:space-between}.almacenes-toolbar-left,.almacenes-toolbar-right{display:flex;flex-wrap:wrap;gap:6px;align-items:center}.almacenes-toolbar-label{font-size:11px;color:var(--muted)}.almacenes-toolbar input{border-radius:999px;border:1px solid var(--border);padding:4px 8px;background:var(--surface);color:var(--text);font-size:12px}.almacenes-floor-pills{display:flex;gap:5px;align-items:center}.almacenes-floor-pill{border-radius:999px;border:1px solid var(--border);padding:4px 10px;font-size:11px;background:var(--surface);cursor:pointer}.almacenes-floor-pill.active{background:var(--primary);color:var(--primary-contrast);border-color:var(--primary)}.almacenes-floor-empty{font-size:11px;color:var(--muted)}.almacenes-3d-shell{border-radius:12px;border:1px solid rgba(148,163,184,.5);padding:10px 10px 12px;background:radial-gradient(circle at top,rgba(15,23,42,.14),transparent 50%),linear-gradient(180deg,#0f172a05,#0f172a0f)}.almacenes-3d-grid{display:grid;grid-auto-flow:column;grid-auto-columns:minmax(120px,1fr);gap:10px}.almacenes-column{display:grid;grid-template-rows:auto 1fr;gap:6px}.almacenes-column-header{display:flex;align-items:center;justify-content:space-between}.almacenes-column-title{font-size:12px;font-weight:600;color:var(--primary-contrast)}.almacenes-column-add{width:22px;height:22px;border-radius:999px;border:1px solid rgba(255,255,255,.8);background:#0f172a80;color:var(--primary-contrast);font-size:14px;line-height:1;display:flex;align-items:center;justify-content:center;cursor:pointer}.almacenes-shelves{display:grid;gap:6px}.almacenes-shelf{position:relative;border-radius:10px;border:1px solid rgba(148,163,184,.9);background:linear-gradient(180deg,#1e40af73,#0f172af2);box-shadow:0 10px 18px #0f172a73,inset 0 0 0 1px #94a3b859;overflow:hidden}.almacenes-shelf.free{border-color:#22c55e;box-shadow:0 12px 22px #16a34a80,inset 0 0 0 1px #22c55ecc}.almacenes-shelf.full{border-color:#f97316;box-shadow:0 12px 22px #f9731673,inset 0 0 0 1px #f8fafc99}.almacenes-shelf-top{height:6px;background:linear-gradient(135deg,#f8fafcb3,#94a3b840)}.almacenes-shelf-body{padding:6px 8px 7px;display:grid;gap:2px;font-size:11px;color:#f8fafcf5}.almacenes-shelf-label{font-weight:600}.almacenes-shelf-meta{color:#e2e8f0e6}.almacenes-shelf-status{font-size:10px;text-transform:uppercase;letter-spacing:.04em;padding:2px 6px;border-radius:999px;background:#0f172ab3;justify-self:flex-start}.almacenes-shelf.empty{border-style:dashed;background:#0f172ab3;box-shadow:none}.almacenes-shelf.empty .almacenes-shelf-body{color:#94a3b8e6}.card:hover{transform:translateY(-2px);box-shadow:0 16px 36px #14213d29}.top-header{display:flex;align-items:center;justify-content:space-between;width:100%;padding:16px 24px;background:var(--surface);border-bottom:1px solid var(--border);position:sticky;top:0;z-index:40}.header-left{display:flex;align-items:center;gap:12px}.header-left h1{margin:0;font-size:1.25rem}.header-left .btn-icon{background:transparent;border:none;cursor:pointer;color:var(--text);display:flex;align-items:center;justify-content:center;padding:8px;border-radius:8px;transition:background-color .2s}.header-left .btn-icon:hover{background:#94a3b81a}.main-content{padding:24px;width:100%;max-width:1200px;margin:0 auto}.header{display:flex;align-items:center;justify-content:space-between;gap:18px;flex-wrap:wrap}.header-right{display:inline-flex;align-items:center;gap:10px}.mobile-nav-menu{display:none;position:relative;min-width:0;isolation:isolate}.mobile-nav-trigger{border:1px solid var(--border);border-radius:999px;padding:8px 34px 8px 12px;background-color:var(--surface);color:var(--text);font-size:13px;font-weight:600;text-align:left;cursor:pointer;position:relative;min-height:40px;min-width:110px;max-width:100%}.mobile-nav-trigger:after{content:"";position:absolute;right:10px;top:50%;width:14px;height:14px;transform:translateY(-50%);background-image:url("data:image/svg+xml;charset=UTF-8,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%239aa4b2' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3e%3cpolyline points='6 9 12 15 18 9'%3e%3c/polyline%3e%3c/svg%3e");background-repeat:no-repeat;background-position:center;background-size:14px;transition:transform .18s ease}.mobile-nav-trigger.open:after{transform:translateY(-50%) rotate(180deg)}.mobile-nav-dropdown-menu{position:absolute;top:calc(100% + 8px);left:0;right:auto;min-width:100%;width:max-content;max-width:min(240px,calc(100vw - 24px));display:grid;gap:4px;padding:6px;border-radius:12px;border:1px solid var(--border);background:var(--surface);box-shadow:0 16px 30px #0f172a38;z-index:70;box-sizing:border-box;overflow:hidden}.mobile-nav-dropdown-item{width:100%;border:1px solid transparent;background:transparent;color:var(--text);text-align:left;border-radius:8px;padding:8px 10px;font-size:13px;font-weight:600;cursor:pointer}.mobile-nav-dropdown-item.active{background:#2d6cdf24;border-color:#2d6cdf3d;color:var(--primary)}.mobile-nav-dropdown-item:hover{background:#94a3b81f}.title{margin:0;font-size:26px}.subtitle{margin:6px 0 0;color:var(--muted);font-size:14px}.theme-row{display:inline-flex;align-items:center;gap:10px}.theme-label{font-size:14px;color:var(--muted)}.theme-buttons{display:inline-flex;align-items:center;gap:5px}.theme-dropdown-mobile{display:none}.theme-button{border:1px solid var(--border);border-radius:999px;padding:6px 12px;background:transparent;color:var(--text);cursor:pointer;font-size:13px;font-weight:600;transition:transform .16s ease,background-color .22s ease,color .22s ease,box-shadow .16s ease,border-color .22s ease}.theme-button.active{background:var(--primary);color:var(--primary-contrast);border-color:transparent;box-shadow:0 8px 18px #2d6cdf59;transform:translateY(-1px)}.form{display:flex;flex-direction:column;gap:16px}.field{display:flex;flex-direction:column;gap:8px;font-size:14px;color:var(--muted)}.field input{border-radius:12px;border:1px solid var(--border);padding:10px 12px;background:transparent;color:var(--text);transition:color .22s ease,border-color .22s ease,background-color .22s ease}.actions{display:grid;grid-template-columns:1fr;gap:12px}.divider{display:grid;grid-template-columns:1fr auto 1fr;align-items:center;gap:12px;color:var(--muted);font-size:12px;text-transform:uppercase;letter-spacing:1px}.divider:before,.divider:after{content:"";height:1px;background:var(--border)}.social-buttons{display:grid;gap:5px}.button.social{display:inline-flex;align-items:center;justify-content:center;gap:10px;background:var(--surface);color:var(--text);border:1px solid var(--border);box-shadow:none}.button.social .social-icon{width:20px;height:20px;display:inline-flex}.button.social .social-icon svg{width:100%;height:100%;display:block}.button.social.google{background:#fff;color:#1f2937;border-color:#e5e7eb}.button.social.google:hover{box-shadow:0 10px 22px #1118271f}.button.social.microsoft{background:#0078d4;color:#fff;border-color:transparent}.button.social.microsoft:hover{box-shadow:0 10px 22px #0078d459}.grid{display:grid;gap:12px}.grid.grid-cards{grid-template-columns:repeat(2,minmax(0,220px));gap:24px;justify-content:center}@media(max-width:720px){.grid.grid-cards{grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}}@media(max-width:420px){.grid.grid-cards{grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}}@media(max-width:600px){.page{padding:16px}.card{padding:22px}.grid.grid-cards{align-items:stretch}.grid.grid-cards .card-button{min-height:168px;padding:12px;gap:8px}.grid.grid-cards .card-title{font-size:14px}.grid.grid-cards .card-text{font-size:12px;line-height:1.35}.grid.grid-cards .card-users-header{align-items:flex-start;gap:8px;flex-direction:column}.grid.grid-cards .card-users-badge{font-size:10px;padding:3px 8px}.grid.grid-cards .card-users-avatar{width:20px;height:20px}.title{font-size:22px}.header{align-items:flex-start}.admin-topbar{flex-direction:column;align-items:flex-start;gap:12px}.admin-toolbar{flex-wrap:wrap}.admin-role-badge{display:none}.theme-row{min-width:0}.theme-label,.theme-buttons{display:none}.theme-dropdown-mobile{display:inline-block;position:relative;width:110px;max-width:100%;min-width:0}.theme-dropdown-trigger{width:100%;border-radius:999px;border:1px solid var(--border);padding:8px 34px 8px 12px;background-color:var(--surface);color:var(--text);font-size:13px;font-weight:600;text-align:left;cursor:pointer;position:relative;background-image:url("data:image/svg+xml;charset=UTF-8,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%239aa4b2' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3e%3cpolyline points='6 9 12 15 18 9'%3e%3c/polyline%3e%3c/svg%3e");background-repeat:no-repeat;background-position:right 10px center;background-size:14px}.theme-dropdown-trigger.open{border-color:var(--primary)}.theme-dropdown-menu{position:absolute;top:calc(100% + 8px);right:0;min-width:100%;width:max-content;max-width:min(220px,calc(100vw - 24px));display:grid;gap:4px;padding:6px;border-radius:12px;border:1px solid var(--border);background:var(--surface);box-shadow:0 16px 30px #0f172a38;z-index:40;box-sizing:border-box;overflow:hidden}.theme-dropdown-item{width:100%;border:1px solid transparent;background:transparent;color:var(--text);text-align:left;border-radius:8px;padding:8px 10px;font-size:13px;font-weight:600;cursor:pointer}.theme-dropdown-item.active{background:#2d6cdf24;border-color:#2d6cdf3d;color:var(--primary)}.theme-dropdown-item:hover{background:#94a3b81f}.header-right,.admin-header-right{width:100%;min-width:0;justify-content:space-between;gap:8px;flex-wrap:nowrap;overflow:visible}.user-menu{flex:1;min-width:0;display:flex;justify-content:flex-end}.user-trigger{width:auto;max-width:min(100%,180px);min-width:0;padding:4px 6px;gap:6px}.user-dropdown{right:0;left:auto;width:min(240px,calc(100vw - 24px));max-width:min(240px,calc(100vw - 24px))}.user-avatar{width:24px;height:24px;font-size:11px;flex-shrink:0}.user-meta{min-width:0}.user-name{font-size:11px}.user-email{font-size:10px}.user-chevron{flex-shrink:0}.top-header{padding:12px 16px;flex-direction:column;gap:12px;align-items:flex-start}.header-left h1{font-size:1.1rem}.header-right{width:100%;justify-content:flex-end}.main-content{padding:16px}.table-container{margin:0 -16px;border-radius:0;border-left:none;border-right:none}.controls-bar{flex-direction:column;align-items:stretch}.controls-bar>*{width:100%}.modal-backdrop{padding:20px 8px 8px;align-items:flex-start}.modal{max-width:100%;width:100%;max-height:calc(100vh - 40px);margin:0}.modal-large{max-width:100%;width:100%}.modal-form{gap:12px}.modal-form select,.modal-form input{font-size:16px;min-height:44px}.modal-actions{flex-direction:column-reverse;gap:8px}.modal-actions button{width:100%}.role-permissions-list{max-height:200px}.role-permission-item{flex-wrap:wrap;padding:10px}.role-permission-crud{width:100%;margin-left:0;margin-top:8px;justify-content:flex-start}.role-permission-crud-button{flex:1;text-align:center}}.card-button{border:1px solid var(--border);border-radius:14px;padding:16px;background:var(--surface);color:var(--text);cursor:pointer;text-align:center;display:grid;gap:12px;min-height:220px;transition:transform .2s ease,box-shadow .2s ease,border-color .2s ease,background-color .2s ease}.card-button:hover{transform:translateY(-3px);border-color:#2d6cdf73;box-shadow:0 14px 26px #1e40af2e}.card-button.card-button-users{position:relative;text-align:left;align-items:stretch;background:radial-gradient(circle at top left,rgba(45,108,223,.22),transparent 55%),var(--surface);border-color:#2d6cdf8c}.card-users-header{display:flex;align-items:center;justify-content:space-between}.card-users-avatars{display:inline-flex;align-items:center;gap:6px}.card-users-avatar{width:24px;height:24px;border-radius:999px;background:linear-gradient(135deg,var(--primary),#0f172a);opacity:.9}.card-users-badge{padding:4px 10px;border-radius:999px;font-size:11px;font-weight:600;border:1px solid rgba(148,163,184,.6)}.card-users-body{display:grid;gap:6px}.card-title{font-weight:700;font-size:16px;text-align:center}.card-text{font-size:14px;color:var(--muted);line-height:1.45}.button{text-decoration:none;border:none;border-radius:12px;padding:12px 16px;background:var(--primary);color:var(--primary-contrast);cursor:pointer;font-weight:600;text-align:center;transition:transform .18s ease,box-shadow .18s ease,filter .18s ease,background-color .22s ease,color .22s ease}.button:hover{transform:translateY(-2px) scale(1.01);box-shadow:0 10px 22px #1e40af3d;filter:brightness(1.02)}.button.ghost{background:var(--surface);color:var(--text);border:1px solid var(--border);box-shadow:none;transition:transform .18s ease,box-shadow .18s ease,color .22s ease,border-color .22s ease,background-color .22s ease}.user-menu{min-width:0}.user-trigger{display:inline-flex;align-items:center;gap:8px;padding:4px 8px;border-radius:999px;border:1px solid var(--border);background:var(--surface);cursor:pointer;font-size:12px;color:var(--text);max-width:100%}.user-avatar{width:28px;height:28px;border-radius:999px;overflow:hidden;display:inline-flex;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--primary),#0f172a);color:var(--primary-contrast);font-size:12px;font-weight:600}.user-avatar img{width:100%;height:100%;object-fit:cover}.user-meta{display:flex;flex-direction:column;align-items:flex-start;min-width:0}.user-name{font-size:12px;font-weight:600;max-width:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.user-email{font-size:11px;color:var(--muted);max-width:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.user-chevron{font-size:10px;color:var(--muted)}.user-dropdown{position:absolute;right:0;top:calc(100% + 6px);min-width:180px;width:max-content;max-width:min(280px,calc(100vw - 24px));border-radius:12px;border:1px solid var(--border);background:var(--surface);box-shadow:0 16px 30px #0f172a38;padding:4px;z-index:80;color:var(--text);box-sizing:border-box;overflow:hidden}.user-dropdown-item{width:100%;border:none;background:transparent;text-align:left;padding:8px 10px;border-radius:8px;font-size:13px;cursor:pointer}.user-dropdown-item:hover{background:#94a3b82e}@keyframes fade-up{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}@keyframes float-in{0%{opacity:0;transform:translateY(18px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}@keyframes bg-lines{0%{transform:translateZ(0)}to{transform:translate3d(-120px,-120px,0)}}.almacen-visualizacion{display:grid;grid-template-columns:minmax(0,1fr) minmax(0,1fr);gap:20px;height:calc(100vh - 140px);min-height:500px;align-items:stretch;min-width:0}.almacen-shape-container{background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:12px;display:flex;flex-direction:column;align-items:stretch;justify-content:flex-start;gap:10px;height:100%;min-height:0;min-width:0}.almacen-canvas{position:relative;border:1px solid var(--border);border-radius:10px;background:var(--surface);overflow:hidden;box-shadow:0 4px 12px #0000000d;max-width:none;max-height:none}.almacen-zoom-controls{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.almacen-zoom-controls .theme-button{padding:4px 10px;font-size:12px}.almacen-zoom-slider{flex:1;min-width:160px;accent-color:var(--primary)}.almacen-zoom-scroll{flex:1;min-height:0;width:100%;overflow-x:auto;overflow-y:auto;scrollbar-gutter:stable both-edges;border-radius:10px;background:#0f172a05;padding:10px;scrollbar-width:thin;scrollbar-color:rgba(45,108,223,.6) rgba(15,23,42,.06)}.almacen-zoom-scroll::-webkit-scrollbar{width:10px;height:10px}.almacen-zoom-scroll::-webkit-scrollbar-track{background:#0f172a0f;border-radius:999px}.almacen-zoom-scroll::-webkit-scrollbar-thumb{background:#2d6cdf99;border-radius:999px;border:2px solid rgba(15,23,42,.06)}.almacen-zoom-scroll::-webkit-scrollbar-thumb:hover{background:#2d6cdfcc}.almacen-shape-layer{position:absolute;inset:0}.almacen-armarios-layer{position:absolute;inset:0;background-color:#ffffff0d}.almacen-shape-svg{width:100%;height:100%;display:block;border-radius:8px;box-shadow:0 2px 8px #00000014}.almacen-shape-svg-container{width:100%;height:100%;display:block}.almacen-shape-svg-container svg{width:100%;height:100%;display:block}.almacen-shape-placeholder{position:absolute;inset:0;text-align:center;color:var(--muted);font-size:14px;display:flex;align-items:center;justify-content:center}.almacen-armarios-list{background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:20px;height:100%;display:flex;flex-direction:column;overflow:hidden;min-width:0;max-width:100%}.almacen-list-title{margin:0 0 16px;font-size:16px;color:var(--text)}.armarios-list-container{overflow-y:auto;flex:1;display:flex;flex-direction:column;gap:8px;padding-right:4px;scrollbar-width:thin;scrollbar-color:rgba(148,163,184,.55) transparent}.armarios-list-container::-webkit-scrollbar{width:10px}.armarios-list-container::-webkit-scrollbar-track{background:transparent}.armarios-list-container::-webkit-scrollbar-thumb{background:#94a3b873;border-radius:999px;border:3px solid transparent;background-clip:content-box}.armarios-list-container::-webkit-scrollbar-thumb:hover{background:#94a3b8a6;background-clip:content-box}.armario-list-item{padding:12px;border:1px solid var(--border);border-radius:8px;cursor:pointer;transition:all .2s;background:var(--surface);display:flex;justify-content:space-between;align-items:center}.armario-list-right{display:flex;align-items:center;gap:10px}.armario-caret{display:inline-flex;width:18px;height:18px;align-items:center;justify-content:center;font-size:14px;color:var(--muted);transition:transform .2s ease,color .2s ease}.armario-caret.expanded{transform:rotate(90deg);color:var(--primary)}.armario-open-btn{border:1px solid var(--border);background:#94a3b814;color:var(--text);padding:6px 10px;border-radius:10px;font-size:12px;cursor:pointer;transition:background-color .16s ease,border-color .16s ease}.armario-open-btn:hover{background:#2563eb1a;border-color:#2563eb59}.armario-accordion{overflow:hidden;transition:max-height .26s ease}.armario-accordion-inner{margin-top:8px;padding-left:10px;display:flex;flex-direction:column;gap:6px;animation:armarioAccordionIn .24s ease}@keyframes armarioAccordionIn{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.repisa-list-item{padding:10px;border:1px solid var(--border);border-radius:10px;background:#94a3b80f;cursor:pointer;display:flex;align-items:center;justify-content:space-between;gap:10px;transition:background-color .16s ease,border-color .16s ease}.repisa-list-item:hover{background:#2563eb14;border-color:#2563eb47}html[data-theme=dark] .repisa-list-item:hover{background:#60a5fa1a;border-color:#60a5fa4d}.repisa-list-main{display:flex;flex-direction:column;gap:2px}.repisa-list-title{font-weight:600;font-size:13px;color:var(--text)}.repisa-list-meta{font-size:12px;color:var(--muted)}.repisa-list-stats{text-align:right;font-size:12px;color:var(--muted);display:flex;flex-direction:column;gap:2px}.armario-list-item:hover,.armario-list-item.hovered{border-color:var(--primary);background:#2563eb0d}.armario-header{display:flex;align-items:center;gap:8px}.armario-icon{font-size:16px}.armario-name{font-weight:500;font-size:14px;color:var(--text)}.repisas-count{font-size:12px;color:var(--muted);background:#94a3b81a;padding:2px 8px;border-radius:99px}.no-armarios-container{display:flex;align-items:center;justify-content:center;height:100%;color:var(--muted);font-size:14px}.armario-box.hovered{border-color:#fbbf24;background:#fbbf2433;z-index:10;box-shadow:0 0 0 1px #fbbf2480}.armario-box{position:absolute;border:1px solid #b91c1c;background:#f8717114;border-radius:6px;cursor:grab;touch-action:none;-webkit-user-select:none;user-select:none;display:flex;align-items:flex-start;justify-content:flex-start;padding:6px;box-sizing:border-box}.armario-box.dragging{cursor:grabbing;border-color:#ef4444;background:#ef444424}.armario-box-label{font-size:12px;font-weight:600;color:#7f1d1d;background:#ffffffbf;padding:2px 4px;border-radius:4px}.armario-floating-label{position:absolute;z-index:30;background:#111827eb;color:#fff;font-size:12px;font-weight:600;padding:6px 8px;border-radius:8px;box-shadow:0 6px 18px #00000040;pointer-events:none;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.admin-success-notification{position:fixed;top:20px;right:20px;background:#10b981;color:#fff;padding:12px 24px;border-radius:8px;font-size:14px;font-weight:500;box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;animation:slide-in .3s ease;z-index:9999;white-space:nowrap;display:flex;align-items:center;gap:8px}.admin-table-actions select,.admin-table-filters select,.admin-table-form select,select{border-radius:8px;border:1px solid var(--border);padding:6px 10px;background-color:var(--surface);color:var(--text);font-size:12px;outline:none}.admin-table-actions select:focus,.admin-table-filters select:focus,.admin-table-form select:focus,select:focus{border-color:var(--primary)}@media(max-width:900px){.almacen-visualizacion{grid-template-columns:1fr;height:auto;min-height:0}.almacen-shape-container{height:min(60vh,520px)}}
