*,*:before,*:after{margin:0;padding:0;box-sizing:border-box;-webkit-tap-highlight-color:transparent}:root{--bg-app: #f4f7fc;--bg-card: #ffffff;--bg-card-hover: #f9fbff;--bg-input: #f8f9fa;--bg-header: #ffffff;--text-primary: #1a1a2e;--text-secondary: #5a5a75;--text-muted: #8c8c9c;--accent: #4c4ce6;--accent-glow: rgba(76, 76, 230, .08);--green: #27ae60;--green-bg: #f0fff4;--red: #eb4d4b;--red-bg: #fff5f5;--blue: #3498db;--yellow: #f1c40f;--border: rgba(0, 0, 0, .07);--border-hover: rgba(0, 0, 0, .12);--shadow-sm: 0 2px 8px rgba(0, 0, 0, .04);--shadow-md: 0 6px 16px rgba(0, 0, 0, .06);--shadow-card: 0 8px 24px rgba(0, 0, 0, .05);--shadow-elevated: 0 12px 32px rgba(0, 0, 0, .1);--radius: 14px;--radius-md: 10px;--radius-sm: 8px}body{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background-color:var(--bg-app);color:var(--text-primary);line-height:1.5;overflow-x:hidden}.app{display:flex;flex-direction:column;height:100vh;width:100%;background:var(--bg-app);position:relative}.app-header{height:56px;background:var(--bg-header);display:flex;align-items:center;justify-content:space-between;padding:0 20px;border-bottom:1px solid var(--border);position:sticky;top:0;z-index:100}.app-title{font-size:18px;font-weight:900;letter-spacing:-.5px;color:var(--accent)}.status-dot{width:7px;height:7px;border-radius:50%}.status-dot.connected{background:var(--green);box-shadow:0 0 6px var(--green)}.status-dot.disconnected{background:var(--red)}.status-dot.connecting{background:var(--yellow);animation:pulse 1s infinite}@keyframes pulse{0%{opacity:.4}50%{opacity:1}to{opacity:.4}}.app-content{flex:1;overflow-y:auto;padding:16px 16px 90px}.gift-card{background:var(--bg-card);border-radius:var(--radius-md);padding:14px 16px;margin-bottom:12px;border:1px solid var(--border);box-shadow:var(--shadow-sm);transition:all .2s;position:relative;animation:slideUp .3s ease}@keyframes slideUp{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.gift-header-row{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}.gift-serial{font-size:12px;font-weight:800;color:var(--accent);background:var(--accent-glow);padding:1px 8px;border-radius:20px}.gift-timer{display:flex;align-items:center;gap:4px;font-size:13px;font-family:JetBrains Mono,monospace;font-weight:700;color:var(--accent)}.gift-field{display:flex;gap:10px;margin-bottom:8px}.gift-field-icon{flex-shrink:0;color:var(--text-muted);padding-top:2px}.gift-field-label{font-size:10px;font-weight:800;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;margin-bottom:0}.gift-field-value{font-size:14px;font-weight:600;color:var(--text-primary);word-break:break-word}.gift-raw{font-size:12px;color:var(--text-secondary);background:var(--bg-input);padding:10px;border-radius:var(--radius-sm);border:1px solid var(--border);margin-bottom:12px;line-height:1.4}.gift-who{font-size:11px;color:var(--text-muted);margin-bottom:2px;font-style:italic}.gift-time{font-size:10px;color:var(--text-muted)}.gift-actions{display:flex;flex-direction:column;gap:8px;margin-top:16px}.gift-btn{width:100%;padding:10px;border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--bg-card);color:var(--text-primary);font-size:13px;font-weight:700;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:8px;transition:all .2s}.gift-btn:hover{background:var(--bg-card-hover);transform:translateY(-1px);box-shadow:var(--shadow-sm);border-color:var(--border-hover)}.gift-btn.copy{background:var(--accent);color:#fff;border-color:var(--accent)}.gift-btn.approve{background:var(--green-bg);color:var(--green);border-color:#27ae6026}.gift-btn.cancel{background:var(--red-bg);color:var(--red);border-color:#eb4d4b26}.edit-form{display:flex;flex-direction:column;gap:12px;background:var(--bg-input);padding:16px;border-radius:var(--radius-md);margin-bottom:16px}.edit-input,.settings-textarea,.date-input,.group-search{width:100%;padding:12px 14px;background:#fff;border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-primary);font-size:14px;outline:none;transition:all .2s}.edit-input:focus,.settings-textarea:focus,.group-search:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-glow)}.bottom-tabs{height:72px;background:#fff;display:flex;border-top:1px solid var(--border);position:fixed;bottom:0;left:0;right:0;padding:0 12px;z-index:1000}.tab{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;background:none;border:none;cursor:pointer;color:var(--text-muted);transition:all .2s;position:relative;padding-top:8px}.tab.active{color:var(--accent)}.tab-icon{margin-bottom:4px}.tab-label{font-size:10px;font-weight:800;text-transform:uppercase;letter-spacing:.5px}.tab.active:after{content:"";position:absolute;top:-1px;left:20%;right:20%;height:4px;background:var(--accent);border-radius:0 0 4px 4px}.tab-badge{position:absolute;top:12px;right:18%;background:var(--red);color:#fff;font-size:9px;font-weight:900;padding:2px 5px;border-radius:10px;min-width:16px}.reports-container{max-width:800px;margin:0 auto;display:flex;flex-direction:column;gap:20px;animation:fadeIn .3s ease}.reports-header{background:#fff;padding:16px;border-radius:var(--radius);border:1px solid var(--border);margin-bottom:20px;display:flex;flex-direction:column;gap:12px}.reports-filters{display:flex;align-items:center;gap:12px}.today-btn{padding:8px 16px;background:var(--accent);color:#fff;border:none;border-radius:var(--radius-sm);font-weight:600;cursor:pointer}.reports-summary{display:grid;grid-template-columns:repeat(2,1fr);gap:16px}.summary-card{background:#fff;padding:24px;border-radius:var(--radius);border:1px solid var(--border);box-shadow:var(--shadow-sm);text-align:center}.summary-value{font-size:36px;font-weight:900;color:var(--accent);line-height:1;margin-bottom:6px}.summary-label{font-size:13px;font-weight:700;color:var(--text-secondary);text-transform:uppercase}.send-report-btn{width:100%;padding:16px;background:#fff;border:1.5px solid var(--accent);color:var(--accent);border-radius:var(--radius-md);font-weight:800;display:flex;align-items:center;justify-content:center;gap:12px;cursor:pointer;transition:all .2s}.send-report-btn:hover{background:var(--accent);color:#fff}.archive-item{background:#fff;padding:14px 18px;border-radius:var(--radius-md);border:1px solid var(--border);margin-bottom:10px;display:flex;align-items:center;justify-content:space-between;transition:transform .2s}.archive-item:active{transform:scale(.98)}.archive-item-primary{font-size:14px;font-weight:700;color:var(--text-primary)}.archive-item-time{font-size:11px;color:var(--text-muted)}.revert-btn{padding:8px 16px;background:var(--bg-app);color:var(--accent);border:none;border-radius:20px;font-size:12px;font-weight:800;cursor:pointer}.toast{position:fixed;top:80px;left:50%;transform:translate(-50%);background:#fff;padding:14px 24px;border-radius:40px;box-shadow:var(--shadow-elevated);z-index:9999;font-weight:700;font-size:14px;border:1px solid var(--border);animation:toastIn .3s ease forwards}.toast-approve{color:var(--green);border-color:var(--green)}.toast-cancel{color:var(--red);border-color:var(--red)}.toast-info{color:var(--accent);border-color:var(--accent)}@keyframes toastIn{0%{opacity:0;transform:translate(-50%,-20px)}to{opacity:1;transform:translate(-50%)}}.qr-auth{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;gap:24px;text-align:center;padding:40px 20px}.qr-auth h2{font-size:22px;font-weight:600}.qr-auth p{color:var(--text-secondary);font-size:14px;max-width:320px;line-height:1.6}.qr-box{padding:16px;background:#fff;border-radius:var(--radius);box-shadow:var(--shadow-elevated);display:inline-block}.qr-box img{display:block;width:240px;height:240px}.qr-spinner{width:48px;height:48px;border:3px solid var(--border);border-top-color:var(--accent);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.group-picker{max-width:480px;margin:0 auto}.group-picker h2{font-size:20px;font-weight:600;margin-bottom:16px}.group-list{display:flex;flex-direction:column;gap:6px;max-height:60vh;overflow-y:auto}.group-item{display:flex;align-items:center;justify-content:space-between;padding:14px 16px;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition);color:var(--text-primary);font-size:14px}.group-item:hover{background:var(--bg-card-hover);border-color:var(--border-hover);transform:translateY(-1px)}.group-item-name{font-weight:500}.group-item-count{font-size:12px;color:var(--text-muted)}.group-load-btn{width:100%;padding:14px;background:var(--accent);color:#fff;border:none;border-radius:var(--radius-md);font-size:14px;font-weight:600;cursor:pointer;transition:all var(--transition);margin-bottom:16px}.group-load-btn:hover{opacity:.9;transform:translateY(-1px)}.queue-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}.queue-title{font-size:16px;font-weight:600}.queue-count{color:var(--text-secondary);font-weight:400;font-size:14px}.view-toggle{display:flex;gap:4px;background:var(--bg-input);padding:3px;border-radius:var(--radius-sm);border:1px solid var(--border)}.view-toggle-btn{padding:6px 10px;background:none;border:none;color:var(--text-muted);cursor:pointer;border-radius:6px;font-size:14px;transition:all var(--transition)}.view-toggle-btn.active{background:var(--bg-card-hover);color:var(--text-primary)}.gifts-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:12px}.gifts-list{display:flex;flex-direction:column;gap:6px}.gift-list-item{display:flex;align-items:center;gap:12px;padding:12px 16px;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-md);transition:all var(--transition);animation:cardIn .3s ease}.gift-list-item:hover{border-color:var(--border-hover);background:var(--bg-card-hover)}.gift-list-info{flex:1;min-width:0;display:flex;flex-direction:column;gap:2px}.gift-list-primary{font-size:13px;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.gift-list-secondary{font-size:12px;color:var(--text-secondary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.gift-list-actions{display:flex;gap:6px;flex-shrink:0}.gift-list-btn{width:34px;height:34px;border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--bg-input);color:var(--text-secondary);font-size:14px;cursor:pointer;transition:all var(--transition);display:flex;align-items:center;justify-content:center}.gift-list-btn:hover{border-color:var(--border-hover);color:var(--text-primary)}.gift-list-btn.approve:hover{border-color:var(--green);color:var(--green)}.gift-list-btn.cancel:hover{border-color:var(--red);color:var(--red)}.gift-list-btn.copy:hover{border-color:var(--blue);color:var(--blue)}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 20px;text-align:center;gap:12px}.empty-state-icon{font-size:48px;opacity:.3}.empty-state-text{font-size:14px;color:var(--text-muted);max-width:260px;line-height:1.6}.archive-header{display:flex;align-items:center;gap:10px;margin-bottom:16px}.archive-title{font-size:16px;font-weight:600}.archive-item-info{flex:1;min-width:0}.settings-page{max-width:480px;margin:0 auto}.settings-page h2{font-size:20px;font-weight:600;margin-bottom:24px}.settings-section{margin-bottom:24px}.settings-label{font-size:13px;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;margin-bottom:8px}.settings-sublabel{font-size:12px;color:var(--text-muted);margin-bottom:8px;line-height:1.5}.settings-chips{display:flex;flex-wrap:wrap;gap:6px;margin-top:8px}.settings-chip{padding:4px 10px;font-size:12px;font-family:SF Mono,Fira Code,monospace;background:var(--bg-input);border:1px solid var(--border);border-radius:6px;color:var(--accent);cursor:pointer;transition:all var(--transition)}.settings-chip:hover{border-color:var(--accent);background:var(--accent-glow)}.settings-preview{padding:12px 14px;background:var(--bg-input);border:1px solid var(--border);border-radius:var(--radius-md);font-size:13px;color:var(--text-secondary);word-break:break-word;line-height:1.5;margin-top:8px}.settings-preview-label{font-size:11px;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;margin-bottom:4px;font-weight:600}.settings-save-btn{padding:12px 32px;background:var(--accent);color:#fff;border:none;border-radius:var(--radius-md);font-size:14px;font-weight:600;cursor:pointer;transition:all var(--transition);margin-top:8px}.settings-save-btn:hover{opacity:.9;transform:translateY(-1px)}.settings-group-reset{padding:10px 20px;background:transparent;color:var(--text-secondary);border:1px solid var(--border);border-radius:var(--radius-md);font-size:13px;cursor:pointer;transition:all var(--transition)}.settings-group-reset:hover{border-color:var(--red);color:var(--red)}@media print{.bottom-tabs,.app-header,.reports-header,.send-report-btn,.revert-btn,.today-btn,.date-input,.toast{display:none!important}.app{height:auto!important;overflow:visible!important;display:block!important}.app-content{padding:0!important;margin:0!important;height:auto!important;overflow:visible!important;display:block!important}body{background:#fff!important;height:auto!important;overflow:visible!important}.summary-card,.archive-item{border:1px solid #ddd!important;box-shadow:none!important;page-break-inside:avoid;margin-bottom:20px}.reports-container{max-width:none!important;padding:20px!important}}.empty-state{padding:80px 20px;text-align:center;color:var(--text-muted)}.empty-state-text{font-size:15px;font-weight:500}@media(max-width:600px){.app-header{padding:10px 14px}.app-content{padding:12px}.gifts-grid{grid-template-columns:1fr}.gift-card{padding:14px}.tab{padding:8px 10px}.tab-label{font-size:10px}}@media(max-width:380px){.gift-actions{flex-wrap:wrap}.gift-btn{flex:none;width:100%}}.login-screen{display:flex;align-items:center;justify-content:center;min-height:100vh;background:var(--bg-app)}.login-card{background:var(--bg-card);padding:32px;border-radius:12px;min-width:320px;display:flex;flex-direction:column;gap:12px;box-shadow:0 8px 40px #00000026}.login-card h1{margin:0;font-size:28px;color:var(--text-primary)}.login-sub{margin:0 0 8px;color:var(--text-muted);font-size:14px}.login-card input{padding:12px;border-radius:8px;border:1px solid #ddd;background:var(--bg-input);color:var(--text-primary);font-size:15px}.login-card button{padding:12px;border-radius:8px;border:0;cursor:pointer;background:#2a6;color:#fff;font-weight:600}.login-card button:disabled{opacity:.5;cursor:not-allowed}.login-err{color:#e55;font-size:13px}.logout-btn{background:transparent;border:1px solid #ddd;color:var(--text-secondary);font-size:16px;padding:4px 10px;border-radius:6px;cursor:pointer}.logout-btn:hover{background:#f0f0f0}.session-warn{position:fixed;bottom:80px;right:16px;background:#fffbea;color:#734d00;padding:10px 14px;border-radius:8px;border:1px solid #f7d97a;font-size:13px;display:flex;align-items:center;gap:10px;z-index:9999}.session-warn button{padding:4px 10px;border-radius:4px;border:0;background:#f7d97a;cursor:pointer;font-weight:600}.repl-table{width:100%;border-collapse:collapse;margin-bottom:8px}.repl-table th,.repl-table td{padding:6px 4px;text-align:left;font-size:12px;color:var(--text-secondary)}.repl-table input[type=text],.repl-table input:not([type]){width:100%;padding:6px 8px;background:var(--bg-input);border:1px solid #ddd;color:var(--text-primary);border-radius:4px}.repl-mini{padding:2px 6px;margin-right:2px;border-radius:4px;border:1px solid #ddd;background:var(--bg-card);cursor:pointer;font-size:12px}.repl-mini:disabled{opacity:.4;cursor:not-allowed}.repl-mini.danger{color:var(--red);border-color:var(--red)}.settings-add{margin-top:8px;padding:8px 14px;border-radius:6px;border:0;background:#2a6;color:#fff;cursor:pointer;font-weight:600}.emoji-row{display:flex;align-items:center;gap:12px;margin:8px 0;font-size:13px;color:var(--text-secondary)}.emoji-btn{font-size:22px;background:var(--bg-input);border:1px solid #ddd;padding:4px 10px;border-radius:6px;cursor:pointer}.chips{display:flex;flex-wrap:wrap;gap:6px;align-items:center}.chip{background:var(--bg-input);border-radius:12px;padding:4px 10px;display:inline-flex;align-items:center;gap:4px;font-size:14px}.chip button{background:transparent;border:0;color:var(--text-muted);cursor:pointer;font-size:12px;padding:0 2px}.chip-input{width:70px;padding:4px 8px;background:var(--bg-input);border:1px solid #ddd;border-radius:12px;font-size:14px}.danger-btn{color:var(--red)}
