:root{--bg-root: #0e0f11;--bg-card: #16181c;--bg-elevated: #1c1f25;--bg-input: #1c1f25;--bg-hover: #22262e;--text-primary: #e8eaed;--text-secondary: #8b8f98;--text-muted: #555962;--accent: #d4a853;--accent-hover: #e0b96a;--accent-muted: rgba(212, 168, 83, .12);--btn-primary: #d4a853;--btn-primary-hover: #e0b96a;--status-unassigned: #6b7280;--status-wait-hold: #a855f7;--status-assigned: #5b8def;--status-review: #d4a853;--status-done: #4ecb71;--priority-critical: #ef4444;--priority-high: #f59e0b;--priority-medium: #5b8def;--priority-low: #8b8f98;--danger: #ef4444;--danger-hover: #dc2626;--border: #2a2d35;--radius-sm: 4px;--radius-md: 8px;--radius-lg: 12px;--font-body: "DM Sans", system-ui, sans-serif;--font-mono: "JetBrains Mono", monospace;--shadow-sm: 0 1px 2px rgba(0, 0, 0, .3);--shadow-md: 0 4px 12px rgba(0, 0, 0, .4)}*,*:before,*:after{margin:0;padding:0;box-sizing:border-box}html{font-size:15px;overflow-x:hidden}body{font-family:var(--font-body);background:var(--bg-root);color:var(--text-primary);line-height:1.6;-webkit-font-smoothing:antialiased;overflow-x:hidden}a{color:inherit;text-decoration:none}.btn{display:inline-flex;align-items:center;gap:6px;padding:8px 16px;border:1px solid transparent;border-radius:var(--radius-md);font-family:var(--font-body);font-size:.875rem;font-weight:500;cursor:pointer;transition:all .15s ease;white-space:nowrap}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:var(--btn-primary);color:#0e0f11;border-color:var(--btn-primary)}.btn-primary:hover:not(:disabled){background:var(--btn-primary-hover)}.btn-secondary{background:var(--bg-elevated);color:var(--text-primary);border-color:var(--border)}.btn-secondary:hover:not(:disabled){background:var(--bg-hover)}.btn-ghost{background:transparent;color:var(--text-secondary)}.btn-ghost:hover:not(:disabled){color:var(--text-primary);background:var(--bg-hover)}.btn-danger{background:transparent;color:var(--danger);border-color:var(--danger)}.btn-danger:hover:not(:disabled){background:var(--danger);color:#fff}.btn-full{width:100%;justify-content:center}.btn-sm{padding:4px 10px;font-size:.8rem}.btn-link{background:none;border:none;color:var(--accent);cursor:pointer;font-family:var(--font-body);font-size:.875rem;padding:0}.btn-link:hover{text-decoration:underline}.form-group{display:flex;flex-direction:column;gap:6px;flex:1}.form-group-checkbox{flex:none}.checkbox-label{display:flex;align-items:center;gap:8px;font-size:.9rem;color:var(--text-primary);cursor:pointer;-webkit-user-select:none;user-select:none}.checkbox-label input[type=checkbox]{width:16px;height:16px;accent-color:var(--accent);cursor:pointer}.form-group label{font-size:.8rem;font-weight:500;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em}.form-group input,.form-group select,.form-group textarea{padding:10px 12px;background:var(--bg-input);border:1px solid var(--border);border-radius:var(--radius-md);color:var(--text-primary);font-family:var(--font-body);font-size:.95rem;transition:border-color .15s ease}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:var(--accent)}.form-group select{cursor:pointer}.form-group textarea{resize:vertical;min-height:80px}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}.alert{padding:10px 14px;border-radius:var(--radius-md);font-size:.9rem;margin-bottom:16px}.alert-error{background:#ef44441f;border:1px solid rgba(239,68,68,.3);color:#fca5a5}.alert-success{background:#4ecb711f;border:1px solid rgba(78,203,113,.3);color:#86efac}.loading-state,.empty-state{display:flex;align-items:center;justify-content:center;min-height:300px;color:var(--text-muted);font-size:1rem}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:24px;background:radial-gradient(ellipse at 30% 20%,rgba(212,168,83,.06) 0%,transparent 50%),var(--bg-root)}.login-card{width:100%;max-width:400px;padding:40px 32px;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-md)}.login-header{text-align:center;margin-bottom:28px}.login-logo{color:var(--btn-primary);margin-bottom:8px;display:flex;justify-content:center}.login-header h1{font-size:1.4rem;font-weight:600;letter-spacing:-.02em}.login-header p{color:var(--text-secondary);font-size:.9rem;margin-top:4px}.login-card form{display:flex;flex-direction:column;gap:16px}.login-card .btn-primary{margin-top:8px;padding:12px}.login-footer{text-align:center;margin-top:20px}.dashboard{max-width:1100px;margin:0 auto;padding:24px 24px 60px}.topbar{border-bottom:1px solid var(--border)}.topbar-inner{max-width:1100px;margin:0 auto;padding:20px 24px;display:flex;align-items:center;justify-content:space-between}.topbar-left{display:flex;align-items:center;gap:12px}.topbar-home{text-decoration:none;color:inherit}.topbar-home:hover .topbar-logo{color:var(--accent)}.topbar-home:hover h1{color:var(--text-primary)}.topbar-logo{color:var(--btn-primary);flex-shrink:0}.topbar-left h1{font-size:1.2rem;font-weight:600;letter-spacing:-.02em}.topbar-right{display:flex;align-items:center;gap:12px}.menu-wrap{position:relative}.menu-dropdown{position:absolute;top:calc(100% + 6px);right:0;min-width:160px;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-md);box-shadow:var(--shadow-md);display:flex;flex-direction:column;z-index:200;overflow:hidden}.menu-item{display:block;width:100%;padding:10px 16px;text-align:left;font-size:.9rem;font-family:var(--font-body);color:var(--text-primary);background:none;border:none;cursor:pointer;text-decoration:none;transition:background .12s}.menu-item:hover{background:var(--bg-hover)}.menu-item--danger{color:var(--btn-primary)}.menu-item--danger:hover{background:color-mix(in srgb,var(--btn-primary) 12%,transparent)}.topbar-email{font-size:.85rem;color:var(--text-muted);font-family:var(--font-mono)}.stats-row{display:grid;grid-template-columns:repeat(7,1fr);gap:10px;margin-bottom:24px}.stat-card{position:relative;padding:12px 8px;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-md);text-align:center;transition:border-color .15s ease}.stat-card.clickable{cursor:pointer}.stat-card.clickable:hover{border-color:var(--text-muted)}.stat-card-active{border-color:var(--btn-primary)!important}.stat-value{display:block;font-size:1.8rem;font-weight:700;letter-spacing:-.03em;line-height:1.2}.stat-label{display:block;font-size:.75rem;text-transform:uppercase;letter-spacing:.08em;color:var(--text-secondary);margin-top:2px}.stat-dot{position:absolute;top:10px;right:10px;width:8px;height:8px;border-radius:50%}.toolbar{display:flex;align-items:center;gap:10px;margin-bottom:10px;flex-wrap:wrap}.activity-strip{display:flex;align-items:center;flex-wrap:nowrap;overflow:hidden;margin:0 0 20px;padding:5px 12px;background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius-md);font-size:.75rem;color:var(--text-muted);line-height:1.6}.activity-label{font-weight:600;font-size:.68rem;text-transform:uppercase;letter-spacing:.07em;color:var(--text-secondary);margin-right:8px;flex-shrink:0}.activity-items-wrap{flex:1;overflow:hidden;min-width:0;position:relative}.activity-items{display:flex;align-items:baseline;gap:6px;white-space:nowrap;width:max-content}.activity-strip[data-overflow=true]:hover .activity-items{animation:activity-ticker var(--ticker-dur, 6s) ease-in-out forwards}@keyframes activity-ticker{0%{transform:translate(0)}12%{transform:translate(0)}88%{transform:translate(var(--scroll-dist))}to{transform:translate(var(--scroll-dist))}}.activity-ellipsis{position:absolute;right:0;top:0;bottom:0;display:flex;align-items:center;padding-left:28px;background:linear-gradient(to right,transparent,var(--bg-elevated) 55%);color:var(--text-muted);font-size:.8rem;pointer-events:none;transition:opacity .3s}.activity-strip[data-overflow=true]:hover .activity-ellipsis{opacity:0;transition:opacity .15s}.activity-sep{color:var(--border);margin:0 4px}.activity-ref{font-weight:600;color:var(--text-secondary);font-family:var(--font-mono)}.activity-time{margin-left:4px;font-size:.68rem;color:var(--text-muted);opacity:.7}.search-group{display:flex;flex:1;min-width:280px}.search-type-select{padding:9px 10px;background:var(--bg-elevated);border:1px solid var(--border);border-right:none;border-radius:var(--radius-md) 0 0 var(--radius-md);color:var(--text-secondary);font-family:var(--font-body);font-size:.82rem;cursor:pointer;white-space:nowrap;flex-shrink:0}.search-type-select:focus{outline:none;border-color:var(--accent)}.search-input{flex:1;min-width:0;padding:9px 14px;background:var(--bg-card);border:1px solid var(--border);border-radius:0 var(--radius-md) var(--radius-md) 0;color:var(--text-primary);font-family:var(--font-body);font-size:.9rem}.search-input:focus{outline:none;border-color:var(--accent);z-index:1;position:relative}.filter-select{padding:9px 12px;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-md);color:var(--text-primary);font-family:var(--font-body);font-size:.85rem;cursor:pointer}.filter-select:focus{outline:none;border-color:var(--accent)}.pagination-row{display:grid;grid-template-columns:1fr auto 1fr;align-items:center;padding:12px 4px}.pagination-center{display:flex;align-items:center;justify-content:center;gap:10px}.pagination-row>.btn:last-child{justify-self:end}.pagination-info{font-size:.85rem;color:var(--text-secondary);white-space:nowrap}.action-bar{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-bottom:10px}.action-bar-left{display:flex;gap:8px}.sort-count{font-size:.8rem;color:var(--text-muted);font-family:var(--font-mono);white-space:nowrap}.ticket-table-header{background:var(--bg-elevated)!important;border-bottom:1px solid var(--border);cursor:default}.ticket-table-header:hover{background:var(--bg-elevated)!important}.sort-col{cursor:pointer;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted);-webkit-user-select:none;user-select:none;white-space:nowrap}.sort-col:hover{color:var(--text-primary)}.ticket-table{display:flex;flex-direction:column;gap:2px;border:1px solid var(--border);border-radius:var(--radius-md);overflow:hidden}.ticket-row{display:grid;grid-template-columns:56px 90px 1fr 90px 90px 110px 24px 210px;align-items:center;gap:12px;padding:12px 18px;background:var(--bg-card);transition:background .12s ease}.ticket-row:hover{background:var(--bg-hover)}.ticket-row-my-assigned{outline:2px solid var(--highlight-assigned, var(--status-assigned));outline-offset:-2px;border-radius:2px}.ticket-row-my-review{outline:2px solid var(--highlight-review, var(--text-primary));outline-offset:-2px;border-radius:2px}.ticket-col-ref,.ticket-col-status{display:flex;align-items:center}.ticket-col-info{display:flex;flex-direction:column;min-width:0;cursor:pointer}.ticket-col-client{display:flex;align-items:center;min-width:0}.ticket-col-priority{display:flex;align-items:center}.ticket-col-owner{display:flex;align-items:center;min-width:0}.ticket-col-files{display:flex;align-items:center;justify-content:center}.ticket-col-dates{display:flex;flex-direction:column;align-items:flex-end;gap:2px}.status-select{-moz-appearance:none;appearance:none;-webkit-appearance:none;padding:3px 10px;border-radius:20px;font-size:.72rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;border:none;cursor:pointer;font-family:var(--font-body);text-align:center;width:100%;outline:none}.status-select:hover{opacity:.85}.status-select option{background:var(--bg-card);color:var(--text-primary);text-transform:uppercase}.status-select-lg{padding:6px 16px;font-size:.9rem;font-weight:600;border-radius:20px;flex:0 1 auto;width:auto;min-width:0}.status-badge{display:inline-block;padding:3px 10px;border-radius:20px;font-size:.72rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:#0e0f11;white-space:nowrap}.status-badge-lg{padding:5px 14px;font-size:.8rem}.ticket-info{display:flex;flex-direction:column;min-width:0}.ticket-ref{font-family:var(--font-mono);font-size:.85rem;font-weight:700;color:var(--text-primary);white-space:nowrap}.ticket-title{font-weight:500;font-size:.95rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.ticket-meta{font-size:.8rem;color:var(--text-muted)}.priority-tag{font-size:.78rem;font-weight:500;font-family:var(--font-mono);white-space:nowrap}.priority-critical{color:var(--priority-critical)}.priority-high{color:var(--priority-high)}.priority-medium{color:var(--priority-medium)}.priority-low{color:var(--priority-low)}.file-count{display:inline-flex;align-items:center;gap:3px;font-size:.8rem;color:var(--text-muted)}.icon-clip{width:14px;height:14px;flex-shrink:0}.ticket-dates{display:flex;flex-direction:column;align-items:flex-end;gap:2px}.ticket-date{font-size:.72rem;color:var(--text-muted);font-family:var(--font-mono);white-space:nowrap}.form-page{max-width:720px;margin:0 auto;padding:24px 24px 60px}.form-header{display:flex;align-items:center;gap:16px;padding:20px 0;border-bottom:1px solid var(--border);margin-bottom:28px}.form-header h1{font-size:1.2rem;font-weight:600}.ticket-form{display:flex;flex-direction:column;gap:20px}.activity-page-table{border:1px solid var(--border);border-radius:var(--radius-md);overflow:hidden;margin-bottom:16px}.activity-page-header,.activity-page-row{display:grid;grid-template-columns:180px 80px 1fr 1fr;gap:0;align-items:center}.activity-page-header{background:var(--bg-hover);border-bottom:1px solid var(--border);font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted)}.activity-page-row{border-bottom:1px solid var(--border);transition:background .1s}.activity-page-row:last-child{border-bottom:none}.activity-page-row:hover{background:var(--bg-hover)}.activity-page-col{padding:10px 14px;font-size:.88rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.activity-page-col--time{color:var(--text-secondary);font-size:.82rem}.activity-page-col--ticket{text-align:center}.activity-page-col--action{color:var(--text-secondary)}.settings-section{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-md);padding:24px;margin-bottom:24px}.settings-section-title{font-size:.95rem;font-weight:600;color:var(--text-primary);margin:0 0 6px}.settings-section-desc{font-size:.85rem;color:var(--text-secondary);margin:0 0 20px;line-height:1.5}.settings-hint{font-size:.85rem;color:var(--text-muted);margin:0 0 14px}.settings-hint--warn code{font-family:var(--font-mono);background:var(--bg-elevated);padding:1px 5px;border-radius:3px;font-size:.82em;color:var(--accent)}.settings-gmail-row{display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap}.settings-gmail-info{display:flex;flex-direction:column;gap:2px}.settings-gmail-label{font-size:.72rem;text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted)}.settings-gmail-email{font-size:.9rem;color:var(--text-primary);font-weight:500}.settings-gmail-actions{display:flex;gap:8px}.alert-success{padding:10px 14px;background:#4ecb711a;border:1px solid rgba(78,203,113,.3);border-radius:var(--radius-md);color:#4ecb71;font-size:.875rem;margin-bottom:16px}.form-actions{display:flex;justify-content:flex-end;gap:12px;padding-top:12px;border-top:1px solid var(--border)}.detail-page{max-width:820px;margin:0 auto;padding:24px 24px 60px}.detail-header{display:flex;align-items:center;justify-content:space-between;padding:20px 0;border-bottom:1px solid var(--border);margin-bottom:28px}.detail-actions{display:flex;gap:8px}.detail-title-row{display:flex;align-items:center;gap:16px;margin-bottom:12px}.detail-title-row h1{font-size:1.5rem;font-weight:700;letter-spacing:-.02em;flex:1 1 auto;min-width:0}.detail-ref{font-family:var(--font-mono);font-size:1.1rem;font-weight:700;color:var(--btn-primary);white-space:nowrap}.detail-description{color:var(--text-secondary);font-size:.95rem;line-height:1.7;margin-bottom:28px;white-space:pre-wrap}.detail-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:16px;padding:24px;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-md);margin-bottom:28px}.detail-field{display:flex;flex-direction:column;gap:4px}.field-label{font-size:.72rem;text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted);font-weight:500}.field-value{font-size:.95rem;font-weight:500}.detail-section{margin-bottom:28px}.detail-section h2{font-size:1rem;font-weight:600;margin-bottom:12px;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.04em}.section-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}.section-actions{display:flex;gap:8px}.email-list{display:flex;flex-direction:column;gap:8px}.email-card{background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius-md);overflow:hidden}.email-card-header{padding:12px 14px}.email-card-meta-row{display:flex;justify-content:space-between;align-items:baseline;gap:12px;margin-bottom:4px}.email-card-from{font-size:.82rem;color:var(--text-secondary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:60%}.email-card-date{font-size:.75rem;color:var(--text-muted);white-space:nowrap;flex-shrink:0}.email-card-subject-row{display:flex;justify-content:space-between;align-items:center;gap:8px}.email-card-subject{font-size:.9rem;font-weight:600;color:var(--text-primary)}.email-card-actions{display:flex;gap:4px;flex-shrink:0}.email-card-snippet{margin:6px 0 0;font-size:.8rem;color:var(--text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.email-card-body{border-top:1px solid var(--border)}.email-iframe{display:block;width:100%;min-height:320px;max-height:600px;border:none;background:#fff}.email-body-text{padding:14px;margin:0;font-family:var(--font-mono);font-size:.82rem;color:var(--text-secondary);white-space:pre-wrap;word-break:break-word;max-height:400px;overflow-y:auto}.gmail-picker-modal{width:min(820px,96vw);max-width:min(820px,96vw)!important;max-height:88vh;display:flex;flex-direction:column;gap:0;padding:0}.gmail-picker-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px 12px;border-bottom:1px solid var(--border);flex-shrink:0}.gmail-picker-header .modal-title{margin:0}.gmail-picker-connect{padding:20px;display:flex;flex-direction:column;gap:16px;align-items:flex-start}.gmail-picker-hint{font-size:.85rem;color:var(--text-secondary);margin:0;line-height:1.5}.gmail-picker-hint code{font-family:var(--font-mono);background:var(--bg-elevated);padding:1px 5px;border-radius:3px;font-size:.82em}.gmail-picker-loading{padding:16px 20px}.gmail-picker-search{padding:12px 20px;border-bottom:1px solid var(--border);flex-shrink:0}.gmail-search-input{width:100%;padding:8px 12px;background:var(--bg-input);border:1px solid var(--border);border-radius:var(--radius-md);color:var(--text-primary);font-size:.875rem}.gmail-search-input:focus{outline:none;border-color:var(--accent)}.gmail-msg-list{flex:1;overflow-y:auto;padding:8px 0;min-height:0}.gmail-msg-item{display:flex;align-items:flex-start;gap:12px;padding:10px 20px;cursor:pointer;transition:background .1s;border-bottom:1px solid var(--border)}.gmail-msg-item:last-child{border-bottom:none}.gmail-msg-item:hover{background:var(--bg-hover)}.gmail-msg-item--selected{background:var(--accent-muted)}.gmail-msg-item--imported{opacity:.5;cursor:default}.gmail-msg-item input[type=checkbox]{margin-top:3px;flex-shrink:0;accent-color:var(--accent);width:15px;height:15px}.gmail-msg-info{flex:1;min-width:0}.gmail-msg-top{display:flex;justify-content:space-between;align-items:baseline;gap:8px;margin-bottom:2px}.gmail-msg-from{font-size:.82rem;font-weight:600;color:var(--text-secondary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:70%}.gmail-msg-date{font-size:.75rem;color:var(--text-muted);white-space:nowrap;flex-shrink:0}.gmail-msg-subject{font-size:.875rem;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-bottom:2px}.gmail-msg-snippet{font-size:.78rem;color:var(--text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.gmail-msg-badge{display:inline-block;margin-top:4px;font-size:.7rem;padding:1px 6px;border-radius:10px;background:var(--bg-hover);color:var(--text-muted);border:1px solid var(--border)}.gmail-picker-count{font-size:.82rem;color:var(--text-muted);flex:1}.gmail-picker-pagination{display:flex;align-items:center;justify-content:center;gap:16px;padding:8px 20px;border-top:1px solid var(--border);flex-shrink:0}.gmail-picker-page{font-size:.8rem;color:var(--text-muted);min-width:48px;text-align:center}.gmail-picker-modal .modal-actions{padding:12px 20px;border-top:1px solid var(--border);flex-shrink:0}.comment-list{display:flex;flex-direction:column;gap:12px;margin-bottom:20px}.comment-item{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-md);padding:12px 16px}.comment-header{display:flex;align-items:baseline;gap:10px;margin-bottom:8px}.comment-author{font-weight:600;font-size:.9rem}.comment-date{font-size:.78rem;color:var(--text-muted);flex:1}.comment-edit-btn{opacity:.6;font-size:.78rem;padding:2px 8px}.comment-edit-btn:hover{opacity:1}.comment-body{font-size:.9rem;line-height:1.55;white-space:pre-wrap;margin:0}.comment-edit{display:flex;flex-direction:column;gap:8px}.comment-edit textarea{width:100%;box-sizing:border-box;background:var(--bg-input);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-primary);font-size:.9rem;padding:8px 10px;resize:vertical}.comment-edit-actions{display:flex;justify-content:flex-end;gap:8px}.comment-add{display:flex;flex-direction:column;gap:8px;margin-top:4px}.comment-add textarea{width:100%;box-sizing:border-box;background:var(--bg-input);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-primary);font-size:.9rem;padding:8px 10px;resize:vertical}.comment-add .btn{align-self:flex-end}.file-list{display:flex;flex-direction:column;gap:2px;border:1px solid var(--border);border-radius:var(--radius-md);overflow:hidden}.file-row{display:flex;align-items:center;justify-content:space-between;padding:10px 14px;background:var(--bg-card)}.file-info{display:flex;flex-direction:column}.file-name{font-size:.9rem;font-weight:500}.file-meta{font-size:.78rem;color:var(--text-muted);font-family:var(--font-mono)}.files-drop-zone{transition:background .15s,border-color .15s}.files-drop-zone--active{background:color-mix(in srgb,var(--accent) 8%,var(--bg-card));border-radius:var(--radius-lg);outline:2px dashed var(--accent);outline-offset:-2px}.files-drop-hint{text-align:center;font-size:.8rem;color:var(--text-muted);padding:8px 0 2px;pointer-events:none;transition:color .15s}.files-drop-zone--active .files-drop-hint{color:var(--accent);font-weight:500}.empty-files{color:var(--text-muted);font-size:.9rem;padding:20px;text-align:center;background:var(--bg-card);border:1px dashed var(--border);border-radius:var(--radius-md)}@media (max-width: 768px){.dashboard,.form-page,.detail-page{padding:16px 16px 40px}.topbar{flex-direction:row;align-items:center;gap:8px;padding:14px 16px}.topbar-left{flex:1;min-width:0}.topbar-right{flex-shrink:0;gap:6px}.topbar-email{display:none}.stats-row{grid-template-columns:repeat(4,1fr)}.action-bar,.action-bar-left{flex-wrap:wrap}.toolbar{flex-direction:column;align-items:stretch}.form-row{grid-template-columns:1fr}.detail-grid{grid-template-columns:1fr 1fr;padding:16px}.detail-header{flex-wrap:wrap;gap:10px}.detail-actions{display:flex;gap:8px}.pagination-row{gap:4px}.pagination-center{gap:6px;flex-wrap:wrap;justify-content:center}.sort-count,.ticket-table-header{display:none}.ticket-row{display:grid;grid-template-columns:auto 1fr auto;grid-template-rows:auto auto auto auto;gap:4px 8px;padding:12px 14px;align-items:start}.ticket-col-ref{grid-column:1;grid-row:1;align-self:center}.ticket-col-status{grid-column:3;grid-row:1;align-self:center}.ticket-col-info{grid-column:1 / -1;grid-row:2}.ticket-col-priority{grid-column:1;grid-row:3;align-self:center}.ticket-col-owner{grid-column:2 / span 2;grid-row:3;align-self:center}.ticket-col-dates{grid-column:1 / -1;grid-row:4;flex-direction:row;flex-wrap:wrap;align-items:center;gap:6px}.ticket-col-client,.ticket-col-files{display:none}}@media (max-width: 480px){.dashboard,.form-page,.detail-page{padding:0 12px 32px}.stats-row{grid-template-columns:repeat(4,1fr);gap:6px}.stat-card{padding:10px 4px}.stat-value{font-size:1.4rem}.stat-label{font-size:.65rem}.detail-grid{grid-template-columns:1fr;padding:12px}}@keyframes shimmer{0%{background-position:-400px 0}to{background-position:400px 0}}.skeleton{display:block;border-radius:var(--radius-sm);background:linear-gradient(90deg,var(--bg-elevated) 25%,var(--bg-hover) 50%,var(--bg-elevated) 75%);background-size:800px 100%;animation:shimmer 1.6s ease-in-out infinite}.skeleton-value{width:48px;height:32px;margin:0 auto 4px;border-radius:var(--radius-sm)}.skeleton-badge{width:72px;height:24px;border-radius:20px;flex-shrink:0}.skeleton-title{width:220px;height:16px;margin-bottom:6px}.skeleton-meta{width:140px;height:12px}.skeleton-priority{width:80px;height:16px}.ticket-row-skeleton{cursor:default}.ticket-row-skeleton:hover{background:var(--bg-card)}.ticket-col-text{font-size:.8rem;color:var(--text-secondary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.ticket-client-tag{display:inline-block;margin-left:8px;padding:1px 8px;font-size:.72rem;font-weight:600;color:var(--accent);background:var(--accent-muted);border-radius:20px;vertical-align:middle;text-transform:uppercase;letter-spacing:.03em}.clients-page{max-width:820px;margin:0 auto;padding:0 24px 60px}.new-client-form{display:flex;gap:10px;margin-bottom:24px}.new-client-form .search-input{flex:1}.client-list{display:flex;flex-direction:column;gap:16px}.client-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-md);overflow:hidden}.client-header{display:flex;align-items:center;justify-content:space-between;padding:16px 18px;border-bottom:1px solid var(--border)}.client-name{font-size:1.05rem;font-weight:600}.client-actions{display:flex;gap:6px}.client-edit-row{display:flex;gap:8px;align-items:center;width:100%}.client-edit-row .search-input{flex:1}.contacts-section{padding:14px 18px}.contacts-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px}.contacts-label{font-size:.78rem;font-weight:500;text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted)}.contact-list{display:flex;flex-direction:column;gap:2px;border:1px solid var(--border);border-radius:var(--radius-sm);overflow:hidden}.contact-row{display:flex;align-items:center;justify-content:space-between;padding:10px 14px;background:var(--bg-elevated)}.contact-info{display:flex;flex-direction:column}.contact-name{font-size:.9rem;font-weight:500}.contact-meta{font-size:.78rem;color:var(--text-muted)}.contact-actions{display:flex;gap:4px}.contact-form{padding:12px;background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius-sm);margin-bottom:10px}.contact-form-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-bottom:10px}.contact-form-grid input{padding:8px 10px;background:var(--bg-input);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-primary);font-family:var(--font-body);font-size:.85rem}.contact-form-grid input:focus{outline:none;border-color:var(--accent)}.contact-form-actions{display:flex;gap:8px}.contact-distribute-label{display:flex;align-items:center;gap:8px;font-size:.85rem;color:var(--text-secondary);margin-top:10px;margin-bottom:10px;cursor:pointer;-webkit-user-select:none;user-select:none}.contact-distribute-label input[type=checkbox]{width:15px;height:15px;cursor:pointer;flex-shrink:0}.contact-distribute-badge{display:inline-block;margin-left:6px;padding:1px 6px;background:var(--btn-primary);color:#0e0f11;font-size:.7rem;font-weight:600;border-radius:var(--radius-sm);letter-spacing:.03em;vertical-align:middle}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:1000}.modal{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:28px;width:100%;max-width:380px;display:flex;flex-direction:column;gap:16px;box-shadow:var(--shadow-md)}.modal-title{font-size:1rem;font-weight:600}.modal-body{font-size:.9rem;color:var(--text-secondary)}.modal-select{width:100%}.modal-textarea{width:100%;padding:10px 12px;background:var(--bg-input);border:1px solid var(--border);border-radius:var(--radius-md);color:var(--text-primary);font-family:var(--font-body);font-size:.95rem;resize:vertical;min-height:80px}.modal-textarea:focus{outline:none;border-color:var(--accent)}.ticket-hold-reason{font-size:.78rem;color:var(--status-wait-hold);font-style:italic;margin-top:2px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.ticket-client-tag{font-size:.7rem;color:var(--text-muted);font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;min-width:0}.ticket-compact-meta{display:flex;align-items:center;gap:5px;min-width:0}.ticket-status-dot{width:7px;height:7px;border-radius:50%;flex-shrink:0}.ticket-status-label{font-size:.7rem;color:var(--text-muted);white-space:nowrap;flex-shrink:0}.ticket-compact-sep{font-size:.7rem;color:var(--text-muted);flex-shrink:0}.modal-actions{display:flex;justify-content:flex-end;gap:10px;padding-top:4px}.colors-page{max-width:820px;margin:0 auto;padding:0 24px 60px}.colors-sections{display:flex;flex-direction:column;gap:28px;margin-bottom:28px}.colors-section{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-md);padding:20px}.colors-section-title{font-size:.85rem;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--text-secondary);margin-bottom:16px}.colors-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px}.color-field{display:flex;flex-direction:column;gap:6px}.color-label{font-size:.78rem;font-weight:500;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted)}.color-input-row{display:flex;align-items:center;gap:8px}.color-picker{width:40px;height:36px;border:1px solid var(--border);border-radius:var(--radius-sm);background:none;cursor:pointer;padding:2px}.color-picker::-webkit-color-swatch-wrapper{padding:0}.color-picker::-webkit-color-swatch{border:none;border-radius:2px}.color-hex-input{width:90px;padding:7px 8px;background:var(--bg-input);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-primary);font-family:var(--font-mono);font-size:.82rem;text-transform:uppercase}.color-hex-input:focus{outline:none;border-color:var(--accent)}.color-argb-input{width:90px;padding:7px 8px;background:var(--bg-input);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-primary);font-family:var(--font-mono);font-size:.82rem;text-transform:uppercase}.color-argb-input:focus{outline:none;border-color:var(--accent)}.color-preview{width:36px;height:36px;border-radius:var(--radius-sm);border:1px solid var(--border);flex-shrink:0}.colors-actions{display:flex;align-items:center;justify-content:space-between;padding:16px 0;border-top:1px solid var(--border);margin-bottom:28px}.colors-actions-right{display:flex;align-items:center;gap:12px}.colors-saved{font-size:.85rem;color:var(--status-complete);font-weight:500}.colors-preview-section{margin-bottom:40px}.colors-preview-card{border:1px solid var(--border);border-radius:var(--radius-md)}@media (max-width: 768px){.colors-grid{grid-template-columns:1fr}.color-input-row{flex-wrap:wrap}}.app-layout{display:flex;flex-direction:column;min-height:100vh}.app-content{flex:1;overflow-y:auto}.ticket-area-wrap{display:flex;gap:0;align-items:flex-start;overflow:hidden}.ticket-area-wrap.is-compact{border:1px solid var(--border);border-radius:var(--radius-md)}.ticket-area-sidebar{width:100%;overflow:hidden;transition:width .22s ease}.ticket-area-wrap.is-compact .ticket-area-sidebar{width:380px;min-width:280px;flex-shrink:0;border-right:1px solid var(--border)}.ticket-area-wrap.is-compact .ticket-table{border:none;border-radius:0}.ticket-split-panel{flex:1;min-width:0;border-left:1px solid var(--border);animation:panel-slide-in .2s ease}@keyframes panel-slide-in{0%{opacity:0;transform:translate(8px)}to{opacity:1;transform:translate(0)}}.ticket-area-wrap.is-compact .ticket-area-sidebar .pagination-row{grid-template-columns:auto 1fr auto}.ticket-area-wrap.is-compact .ticket-area-sidebar .pagination-center{display:none}.panel-pane-header{display:flex;justify-content:flex-end;align-items:center;padding:0 16px;height:42px;box-sizing:border-box;border-bottom:1px solid var(--border);background:var(--bg-elevated);position:sticky;top:0;z-index:5}.panel-mobile-backdrop{display:none}.panel-close-btn{background:transparent;border:1px solid var(--border);border-radius:var(--radius-md);color:var(--text-secondary);padding:4px 10px;display:flex;align-items:center;gap:6px;cursor:pointer;font-size:.8rem;transition:background .12s,color .12s}.panel-close-btn:hover{background:var(--bg-hover);color:var(--text-primary)}.ticket-col-arrow{display:none}.ticket-table-compact .ticket-row{grid-template-columns:44px 1fr 20px;padding:12px;gap:8px;cursor:pointer}.ticket-table-compact .ticket-col-status,.ticket-table-compact .ticket-col-client,.ticket-table-compact .ticket-col-priority,.ticket-table-compact .ticket-col-owner,.ticket-table-compact .ticket-col-files,.ticket-table-compact .ticket-col-dates{display:none}.ticket-table-compact .ticket-col-arrow{display:flex;align-items:center;justify-content:center;color:var(--text-secondary);font-size:1.1rem}.ticket-row-selected{background:color-mix(in srgb,var(--accent) 10%,var(--bg-card))!important;outline:2px solid var(--accent);outline-offset:-2px;border-radius:2px}@media (max-width: 768px){html.panel-open,body.panel-open,body.panel-open .app-content{overflow:hidden}}@media (max-width: 768px){.panel-mobile-backdrop{display:block;position:fixed;top:0;right:0;bottom:0;left:0;z-index:199;background:#0009;cursor:pointer}.ticket-split-panel{position:fixed;top:0;right:0;bottom:0;left:0;z-index:200;overflow-y:auto;background:var(--bg-root);border-left:none}.ticket-split-panel .panel-pane-header{position:sticky;top:0;z-index:201}.ticket-table-compact .ticket-row{grid-template-columns:auto 1fr auto;grid-template-rows:auto auto auto auto;gap:4px 8px;padding:12px 14px;align-items:start;cursor:pointer}.ticket-table-compact .ticket-col-status,.ticket-table-compact .ticket-col-priority,.ticket-table-compact .ticket-col-owner,.ticket-table-compact .ticket-col-dates{display:flex}.ticket-table-compact .ticket-col-arrow{display:none}}
