:root{--bg:#f5f5f7;--bg-tint:#fbfbfd;--card:#ffffff;--text:#1d1d1f;--muted:#6e6e73;--muted-2:#86868b;--border:rgba(0,0,0,0.08);--border-strong:rgba(0,0,0,0.14);--accent:#0071e3;--accent-hover:#0077ed;--accent-active:#006adb;--accent-soft:#eef5ff;--danger:#c0392b;--green:#1a7f37;--amber:#9a6700;--radius-lg:22px;--radius:18px;--radius-sm:12px;--shadow-sm:0 1px 2px rgba(0,0,0,0.04),0 4px 14px rgba(0,0,0,0.04);--shadow-md:0 4px 16px rgba(0,0,0,0.06),0 16px 48px rgba(0,0,0,0.08);--shadow-lg:0 12px 48px rgba(0,0,0,0.1),0 36px 96px rgba(0,0,0,0.1);--ring:0 0 0 4px rgba(0,113,227,0.22);--ease:0.22s cubic-bezier(0.22,0.61,0.36,1)}*{box-sizing:border-box;-webkit-tap-highlight-color:transparent}body,html{margin:0;padding:0}body{background:var(--bg);color:var(--text);font-family:-apple-system,BlinkMacSystemFont,SF Pro Text,SF Pro Display,Segoe UI,Roboto,Helvetica,Arial,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizeLegibility;font-feature-settings:"kern","liga","calt";font-size:16px;line-height:1.47;letter-spacing:-.003em;min-height:100vh}::selection{background:rgba(0,113,227,.18)}::-webkit-scrollbar{width:12px;height:12px}::-webkit-scrollbar-thumb{background:rgba(0,0,0,.18);border:3px solid transparent;border-radius:999px;background-clip:padding-box}::-webkit-scrollbar-thumb:hover{background:rgba(0,0,0,.3);border:3px solid transparent;background-clip:padding-box}.auth-wrap{min-height:100vh;display:flex;align-items:center;justify-content:center;background:radial-gradient(70% 55% at 50% -5%,#ffffff 0,rgba(255,255,255,0) 60%),var(--bg)}.container{max-width:980px;margin:0 auto;padding:40px 22px 80px}.container-wide{max-width:1340px}.card{position:relative;background:var(--card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:44px;width:100%;max-width:420px;margin:24px;box-shadow:var(--shadow-lg)}.auth-logo{position:absolute;top:32px;right:32px;display:block;border-radius:8px}.panel{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);padding:24px 26px;margin-bottom:18px;box-shadow:var(--shadow-sm)}.topbar{display:flex;align-items:center;justify-content:space-between;padding:13px 24px;background:rgba(245,245,247,.72);backdrop-filter:saturate(180%) blur(24px);-webkit-backdrop-filter:saturate(180%) blur(24px);border-bottom:1px solid var(--border);position:-webkit-sticky;position:sticky;top:0;z-index:50}.topbar .brand{display:inline-flex;align-items:center}.topbar .brand:hover{text-decoration:none}.logo{display:inline-flex;align-items:center;gap:10px}.logo-mark{display:block;border-radius:7px}.logo-word{font-size:17px;font-weight:600;letter-spacing:-.022em;color:var(--text)}.logo-word-muted{color:var(--muted);font-weight:500}.topbar nav{display:flex;align-items:center;gap:18px;font-size:14px}.topbar a{color:var(--muted);text-decoration:none;transition:color var(--ease)}.topbar a:hover{color:var(--text)}.nav-desktop{display:contents}.nav-menu,.nav-theme-mobile{display:none}.theme-toggle{display:inline-flex;align-items:center;justify-content:center;width:32px;height:32px;padding:0;border-radius:999px;border:1px solid var(--border);background:rgba(0,0,0,.04);color:var(--muted);font-size:15px;line-height:1;cursor:pointer;box-shadow:none;-webkit-tap-highlight-color:transparent;transition:background var(--ease),color var(--ease),border-color var(--ease),transform var(--ease)}.theme-toggle:hover{background:rgba(0,0,0,.07);border-color:var(--border-strong);color:var(--text)}.theme-toggle:active{transform:scale(.92)}.theme-toggle:focus{outline:none}.theme-toggle:focus-visible{outline:2px solid var(--accent);outline-offset:2px}[data-theme=dark] .theme-toggle{background:rgba(255,255,255,.08);border-color:var(--border)}[data-theme=dark] .theme-toggle:hover{background:rgba(255,255,255,.12);border-color:var(--border-strong)}h1{font-size:30px;letter-spacing:-.026em;line-height:1.1;margin:0 0 10px}h1,h2{font-weight:600}h2{font-size:19px;letter-spacing:-.015em;margin:0 0 14px}p{color:var(--muted);font-size:15px;line-height:1.55}a{color:var(--accent);text-decoration:none}a:hover{text-decoration:underline}label{display:block;font-size:13px;font-weight:500;color:var(--muted);letter-spacing:-.006em;margin:16px 0 7px}input[type=date],input[type=email],input[type=number],input[type=password],input[type=tel],input[type=text],select,textarea{width:100%;padding:11px 14px;font-size:15px;color:var(--text);border:1px solid var(--border-strong);border-radius:var(--radius-sm);outline:none;background:#fff;font-family:inherit;transition:border-color var(--ease),box-shadow var(--ease)}input[type=date],select{-webkit-appearance:none;-moz-appearance:none;appearance:none;padding-right:38px;background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8' fill='none'><path d='M1 1.5 6 6.5 11 1.5' stroke='%236e6e73' stroke-width='1.6' stroke-linecap='round' stroke-linejoin='round'/></svg>");background-repeat:no-repeat;background-position:right 14px center}input[type=date]::-webkit-calendar-picker-indicator,input[type=date]::-webkit-clear-button,input[type=date]::-webkit-inner-spin-button{display:none;-webkit-appearance:none}textarea{min-height:120px;resize:vertical}input:focus,select:focus,textarea:focus{border-color:var(--accent);box-shadow:var(--ring)}::placeholder{color:var(--muted-2)}.btn,button{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:11px 22px;font-size:15px;font-weight:600;letter-spacing:-.01em;color:#fff;background:var(--accent);border:none;border-radius:var(--radius-sm);cursor:pointer;text-decoration:none;font-family:inherit;box-shadow:0 1px 1px rgba(0,0,0,.04);transition:background-color var(--ease),transform var(--ease),box-shadow var(--ease),opacity var(--ease)}.btn:hover,button:hover{background:var(--accent-hover);text-decoration:none}.btn:active,button:active{background:var(--accent-active);transform:scale(.97)}.btn:focus-visible,button:focus-visible{box-shadow:var(--ring);outline:none}button:disabled{opacity:.45;cursor:default;transform:none}.btn-block{width:100%;margin-top:24px}.btn-big{padding:15px 26px;font-size:17px;border-radius:14px}.btn-secondary,.logout{background:rgba(0,0,0,.04);color:var(--text);border:1px solid var(--border);box-shadow:none}.btn-secondary:hover,.logout:hover{background:rgba(0,0,0,.07);border-color:var(--border-strong)}.btn-secondary:active,.logout:active{background:rgba(0,0,0,.09)}.btn-danger{background:var(--danger)}.btn-danger:hover{background:#d44637}.btn-danger:active{background:#a93226}.linklike{background:none;border:none;padding:0;margin:0;font:inherit;color:var(--accent);cursor:pointer;box-shadow:none;width:auto}.linklike:hover{text-decoration:underline}input[type=file]{font-size:14px;color:var(--muted)}input[type=file]::-webkit-file-upload-button{margin-right:12px;padding:9px 18px;font-size:14px;font-weight:600;letter-spacing:-.01em;color:#fff;background:var(--accent);border:none;border-radius:var(--radius-sm);cursor:pointer;font-family:inherit;box-shadow:0 1px 1px rgba(0,0,0,.04);-webkit-transition:background-color var(--ease),transform var(--ease);transition:background-color var(--ease),transform var(--ease)}input[type=file]::file-selector-button{margin-right:12px;padding:9px 18px;font-size:14px;font-weight:600;letter-spacing:-.01em;color:#fff;background:var(--accent);border:none;border-radius:var(--radius-sm);cursor:pointer;font-family:inherit;box-shadow:0 1px 1px rgba(0,0,0,.04);transition:background-color var(--ease),transform var(--ease)}input[type=file]::-webkit-file-upload-button:hover{background:var(--accent-hover)}input[type=file]::file-selector-button:hover{background:var(--accent-hover)}input[type=file]::-webkit-file-upload-button:active{background:var(--accent-active);transform:scale(.97)}input[type=file]::file-selector-button:active{background:var(--accent-active);transform:scale(.97)}.badge{display:inline-block;padding:4px 11px;border-radius:999px;font-size:12px;font-weight:600;letter-spacing:.01em;white-space:nowrap}.badge,.badge-status{background:var(--accent-soft);color:var(--accent)}.badge-closed{background:rgba(0,0,0,.05);color:var(--muted)}.badge-st-nuevo{background:#8b1e3f;color:#fff}.badge-st-espera{background:#6d28d9;color:#fff}.badge-st-wait-cliente{background:#1f2937;color:#fff}.badge-st-wait-soporte{background:#ea7317;color:#fff}.badge-st-cita{background:#2563eb;color:#fff}.badge-st-proveedor{background:#0891b2;color:#fff}.badge-st-presupuesto{background:#a16207;color:#fff}.badge-st-resuelto{background:#15803d;color:#fff}.badge-st-cerrado{background:#6b7280;color:#fff}.badge-st-cancelado{background:#374151;color:#fff}.badge-prio-Alta,.badge-prio-Urgente{background:#fdecea;color:var(--danger)}.badge-prio-Normal{background:rgba(0,0,0,.05);color:var(--muted)}.list{list-style:none;margin:0;padding:0}.ticket-row{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:16px 18px;border:1px solid var(--border);border-radius:var(--radius);background:#fff;margin-bottom:10px;text-decoration:none;color:var(--text);box-shadow:var(--shadow-sm);transition:transform var(--ease),box-shadow var(--ease),border-color var(--ease)}.ticket-row:hover{border-color:var(--border-strong);box-shadow:var(--shadow-md);transform:translateY(-2px);text-decoration:none}.ticket-row:active{transform:translateY(0)}.ticket-row .meta{font-size:13px;color:var(--muted);margin-top:4px}.ticket-row .subject{font-weight:600;font-size:15px;letter-spacing:-.012em}.tags{gap:8px;align-items:center;flex-wrap:wrap}.row,.tags{display:flex}.row{justify-content:space-between;gap:16px;padding:11px 0;border-bottom:1px solid var(--border);font-size:14px}.row:last-child{border-bottom:none}.muted{color:var(--muted)}.error{color:var(--danger);font-size:14px;margin-top:12px}.empty{text-align:center;padding:56px 20px;color:var(--muted)}.chat{display:flex;flex-direction:column;gap:8px;margin-bottom:16px}.msg{max-width:72%;padding:9px 14px;border-radius:20px;font-size:15px;line-height:1.4;white-space:pre-wrap;word-break:break-word}.msg .who{font-size:12px;color:var(--muted);margin-bottom:3px;font-weight:500}.msg-mine{align-self:flex-end;background:var(--accent);color:#fff;border-bottom-right-radius:6px}.msg-mine .who{color:rgba(255,255,255,.82)}.msg-theirs{align-self:flex-start;background:#e9e9eb;color:var(--text);border-bottom-left-radius:6px}.note{background:#fff8e1;border:1px solid #f4e2a1;border-radius:var(--radius-sm);padding:12px 14px;font-size:14px;white-space:pre-wrap;margin-bottom:8px}.template-picker{margin-bottom:8px;max-width:260px}.composer{display:flex;flex-direction:column;gap:8px}.composer textarea{min-height:70px}.inline-actions{gap:10px;align-items:center}.filters,.inline-actions{display:flex;flex-wrap:wrap}.filters{gap:12px;align-items:flex-end;margin-bottom:18px}.filters>div{flex:1 1;min-width:140px}.filters label{margin-top:0}.attach-list{list-style:none;padding:0;margin:8px 0 0;display:flex;flex-direction:column;gap:6px}.attach-list a{font-size:14px}.page-head{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;margin-bottom:26px}.ticket-grid{display:grid;grid-template-columns:minmax(0,1fr) 340px;grid-gap:18px;gap:18px;align-items:start}.ticket-aside{position:-webkit-sticky;position:sticky;top:80px}@media (max-width:900px){.ticket-grid{grid-template-columns:1fr}.ticket-aside{position:static}}@media (max-width:640px){.container{padding:24px 16px 56px}h1{font-size:26px}.card{padding:32px 26px}.page-head{flex-direction:column;align-items:stretch}.panel{padding:20px 18px}.msg{max-width:86%}.filters>div{min-width:100%}.topbar{padding:12px 16px}.topbar nav{gap:12px}.nav-desktop{display:none}.nav-theme-mobile{display:inline-flex}.nav-menu{display:block;position:relative}.nav-menu-trigger{list-style:none;cursor:pointer;width:40px;height:40px;color:var(--text);display:inline-flex;align-items:center;justify-content:center;transition:color var(--ease);-webkit-tap-highlight-color:transparent}.nav-menu-trigger:focus{outline:none}.nav-menu-trigger:focus-visible{outline:2px solid var(--accent);outline-offset:2px;border-radius:8px}.nav-menu-trigger::-webkit-details-marker{display:none}.nav-menu-trigger:after{content:"▼";font-size:22px;line-height:1}.nav-menu[open] .nav-menu-trigger:after{content:"▲"}.nav-menu-panel{position:absolute;right:0;top:calc(100% + 10px);min-width:210px;display:flex;flex-direction:column;align-items:flex-start;gap:12px;padding:14px 16px;background:var(--card);border:1px solid var(--border);border-radius:var(--radius-sm);box-shadow:var(--shadow-lg);z-index:60}.nav-menu-panel .muted{font-size:13px;word-break:break-all}.nav-menu-panel .logout,.nav-menu-panel form{width:100%}}[data-theme=dark]{--bg:#000000;--bg-tint:#1c1c1e;--card:#1c1c1e;--text:#f5f5f7;--muted:#a1a1a6;--muted-2:#8a8a8e;--border:rgba(255,255,255,0.12);--border-strong:rgba(255,255,255,0.2);--accent:#0a84ff;--accent-hover:#409cff;--accent-active:#0974e0;--accent-soft:rgba(10,132,255,0.18);--danger:#ff453a;--green:#30d158;--amber:#ffd60a;--shadow-sm:0 1px 2px rgba(0,0,0,0.6);--shadow-md:0 4px 16px rgba(0,0,0,0.5),0 16px 48px rgba(0,0,0,0.5);--shadow-lg:0 12px 48px rgba(0,0,0,0.6),0 36px 96px rgba(0,0,0,0.55);--ring:0 0 0 4px rgba(10,132,255,0.3)}[data-theme=dark] .auth-wrap{background:radial-gradient(70% 55% at 50% -5%,#1c1c1e 0,rgba(0,0,0,0) 60%),var(--bg)}[data-theme=dark] .topbar{background:rgba(0,0,0,.72)}[data-theme=dark] .auth-logo,[data-theme=dark] .logo-mark{background:#fff;padding:3px;border-radius:8px}[data-theme=dark] input[type=date],[data-theme=dark] input[type=email],[data-theme=dark] input[type=number],[data-theme=dark] input[type=password],[data-theme=dark] input[type=tel],[data-theme=dark] input[type=text],[data-theme=dark] select,[data-theme=dark] textarea{background-color:#2c2c2e;border-color:var(--border-strong)}[data-theme=dark] input[type=date],[data-theme=dark] select{background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8' fill='none'><path d='M1 1.5 6 6.5 11 1.5' stroke='%23a1a1a6' stroke-width='1.6' stroke-linecap='round' stroke-linejoin='round'/></svg>")}[data-theme=dark] .ticket-row{background:var(--card)}[data-theme=dark] .msg-theirs{background:#2c2c2e;color:var(--text)}[data-theme=dark] .note{background:rgba(255,214,10,.1);border-color:rgba(255,214,10,.28);color:var(--text)}[data-theme=dark] .btn-secondary,[data-theme=dark] .logout{background:rgba(255,255,255,.08);color:var(--text);border-color:var(--border)}[data-theme=dark] .btn-secondary:hover,[data-theme=dark] .logout:hover{background:rgba(255,255,255,.12);border-color:var(--border-strong)}[data-theme=dark] .btn-secondary:active,[data-theme=dark] .logout:active{background:rgba(255,255,255,.16)}[data-theme=dark] .badge-closed,[data-theme=dark] .badge-prio-Normal{background:rgba(255,255,255,.1);color:var(--muted)}[data-theme=dark] .badge-prio-Alta,[data-theme=dark] .badge-prio-Urgente{background:rgba(255,69,58,.2);color:#ff6961}[data-theme=dark] .badge-st-cancelado,[data-theme=dark] .badge-st-cerrado,[data-theme=dark] .badge-st-cita,[data-theme=dark] .badge-st-espera,[data-theme=dark] .badge-st-nuevo,[data-theme=dark] .badge-st-presupuesto,[data-theme=dark] .badge-st-proveedor,[data-theme=dark] .badge-st-resuelto,[data-theme=dark] .badge-st-wait-cliente,[data-theme=dark] .badge-st-wait-soporte{box-shadow:inset 0 0 0 1px rgba(255,255,255,.16)}[data-theme=dark] ::-webkit-scrollbar-thumb{background:rgba(255,255,255,.18);border:3px solid transparent;background-clip:padding-box}[data-theme=dark] ::-webkit-scrollbar-thumb:hover{background:rgba(255,255,255,.32);border:3px solid transparent;background-clip:padding-box}@media (prefers-reduced-motion:reduce){*{transition:none!important;animation:none!important;scroll-behavior:auto!important}}