:root{color-scheme:light;--bg-primary: #f5f5f5;--bg-secondary: #ffffff;--bg-tertiary: #fafafa;--hover-bg: rgba(0, 0, 0, .03);--text-primary: #333333;--text-secondary: #666666;--text-tertiary: #999999;--border-color: #e0e0e0;--border-light: #f0f0f0;--shadow-sm: rgba(0, 0, 0, .1);--shadow-md: rgba(0, 0, 0, .15);--accent-primary: #667eea;--accent-secondary: #764ba2;--input-bg: #ffffff;--input-border: #ddd;--modal-backdrop: rgba(0, 0, 0, .5);--btn-primary-bg: #3b82f6;--btn-primary-hover: #2563eb;--btn-primary-active: #1d4ed8;--btn-primary-text: #ffffff;--btn-danger-bg: #f87171;--btn-danger-hover: #ef4444;--btn-danger-active: #dc2626;--btn-danger-text: #ffffff;--error-color: #dc2626;--error-bg: #fef2f2;--error-border: #fecaca;--warning-bg: #fef3c7;--warning-border: #f59e0b;--success-color: #10b981;--safe-area-inset-top: env(safe-area-inset-top);--safe-area-inset-right: env(safe-area-inset-right);--safe-area-inset-bottom: env(safe-area-inset-bottom);--safe-area-inset-left: env(safe-area-inset-left)}[data-theme=dark]{color-scheme:dark;--bg-primary: #1a1a1a;--bg-secondary: #2d2d2d;--bg-tertiary: #252525;--hover-bg: rgba(255, 255, 255, .05);--text-primary: #e0e0e0;--text-secondary: #b0b0b0;--text-tertiary: #808080;--border-color: #404040;--border-light: #353535;--shadow-sm: rgba(0, 0, 0, .3);--shadow-md: rgba(0, 0, 0, .5);--accent-primary: #7c8fef;--accent-secondary: #8b5fc7;--input-bg: #2d2d2d;--input-border: #404040;--modal-backdrop: rgba(0, 0, 0, .7);--btn-primary-bg: #3b82f6;--btn-primary-hover: #60a5fa;--btn-primary-active: #2563eb;--btn-primary-text: #ffffff;--btn-danger-bg: #f87171;--btn-danger-hover: #fca5a5;--btn-danger-active: #ef4444;--btn-danger-text: #ffffff;--error-color: #f87171;--error-bg: #3a1a1a;--error-border: #5a2020;--warning-bg: #3a3020;--warning-border: #7a5a0a;--success-color: #34d399}*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,sans-serif;line-height:1.6;color:var(--text-primary);background:var(--bg-primary);transition:background-color .3s ease,color .3s ease;margin:0;padding:0;min-height:100vh;overflow-x:hidden;width:100%;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;-webkit-tap-highlight-color:transparent;touch-action:manipulation;overscroll-behavior-y:none;-webkit-overflow-scrolling:touch}html{overflow-x:hidden;width:100%;margin:0;padding:0}.app{display:flex;flex-direction:column;min-height:100vh}.btn{padding:10px 20px;border:none;border-radius:6px;cursor:pointer;font-size:14px;font-weight:500;transition:all .15s cubic-bezier(.4,0,.2,1);font-family:inherit;touch-action:manipulation;-webkit-tap-highlight-color:transparent;-webkit-user-select:none;user-select:none}.btn-primary{background:var(--btn-primary-bg);color:var(--btn-primary-text)}.btn-primary:hover{background:var(--btn-primary-hover);transform:translateY(-1px)}.btn-primary:active{background:var(--btn-primary-active);transform:scale(.98)}.btn-secondary{background:var(--bg-tertiary);color:var(--text-primary);border:1px solid var(--border-color)}.btn-secondary:hover{background:var(--bg-secondary)}.btn-secondary:active{transform:scale(.98)}.btn-danger{background:var(--btn-danger-bg);color:var(--btn-danger-text);border:none}.btn-danger:hover{background:var(--btn-danger-hover)}.btn-danger:active{background:var(--btn-danger-active);transform:scale(.98)}.btn-icon{background:none;border:none;cursor:pointer;font-size:20px;padding:8px;transition:opacity .15s;touch-action:manipulation;-webkit-tap-highlight-color:transparent}.btn-icon:hover{opacity:.7}.btn-icon:active{opacity:.5;transform:scale(.95)}.form-group{margin-bottom:20px}.form-group label{display:block;margin-bottom:8px;font-weight:500;color:var(--text-primary);font-size:14px}.form-group input,.form-group select,.form-group textarea{width:100%;padding:10px;border:1px solid var(--input-border);border-radius:6px;font-size:14px;background:var(--input-bg);color:var(--text-primary);font-family:inherit;transition:border-color .2s}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:var(--accent-primary)}.error-message{color:#f44336;font-size:14px;margin-top:10px;padding:10px;background:#f443361a;border-radius:6px;border-left:3px solid #f44336}.loading{text-align:center;padding:40px;color:var(--text-secondary)}:root{--status-good: #10b981;--status-upcoming: #f97316;--status-urgent: #ef4444;--status-flagged: #3b82f6}[data-theme=dark]{--status-good: #34d399;--status-upcoming: #fb923c;--status-urgent: #f87171;--status-flagged: #60a5fa}.status-good{border-left-color:var(--status-good)!important}.status-upcoming{border-left-color:var(--status-upcoming)!important}.status-urgent{border-left-color:var(--status-urgent)!important}.status-flagged{border-left-color:var(--status-flagged)!important;background:#3b82f60d}.status-stage-1,.status-stage-2,.status-stage-3{border-left-color:var(--status-good)!important}.status-stage-4{border-left-color:var(--status-upcoming)!important}.status-stage-5,.status-stage-6{border-left-color:var(--status-urgent)!important}@media(max-width:768px){.btn{padding:10px 16px;font-size:14px;min-height:44px}.btn-icon{padding:10px;font-size:20px;min-width:44px;min-height:44px}.form-group input,.form-group select,.form-group textarea{font-size:16px;min-height:44px}.form-group textarea{min-height:100px}}.login-screen{display:flex;align-items:center;justify-content:center;background:var(--bg-primary);min-height:100vh;width:100%}.login-container{background:var(--bg-secondary);padding:40px;border-radius:10px;box-shadow:0 10px 25px #0003;width:100%;max-width:400px;border:1px solid var(--border-color)}.login-container h1{color:var(--btn-primary-bg);margin-bottom:10px;font-size:32px;text-align:center}.login-subtitle{color:var(--text-secondary);text-align:center;margin-bottom:30px;font-size:14px}.login-form{margin-top:20px}.login-divider{display:flex;align-items:center;text-align:center;margin:20px 0;color:var(--text-secondary)}.login-divider:before,.login-divider:after{content:"";flex:1;border-bottom:1px solid var(--border-color)}.login-divider span{padding:0 15px;font-size:14px;text-transform:lowercase}.btn-google{width:100%;display:flex;align-items:center;justify-content:center;gap:10px;padding:12px 20px;background:#fff;color:#333;border:1px solid #ddd;border-radius:6px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s;font-family:inherit}.btn-google:hover{background:#f8f8f8;border-color:#ccc;transform:translateY(-1px);box-shadow:0 2px 8px #0000001a}.google-icon{flex-shrink:0}[data-theme=dark] .btn-google{background:var(--bg-tertiary);color:var(--text-primary);border-color:var(--border-color)}[data-theme=dark] .btn-google:hover{background:var(--bg-secondary);border-color:var(--border-light)}.modal-overlay{position:fixed;inset:0;background:var(--modal-backdrop);display:flex;align-items:center;justify-content:center;z-index:2000;padding:20px}.modal-content{background:var(--bg-secondary);border-radius:8px;box-shadow:0 4px 20px var(--shadow-md);width:100%;max-width:600px;max-height:90vh;overflow:hidden;display:flex;flex-direction:column}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:20px;border-bottom:1px solid var(--border-color)}.modal-header h2{margin:0;color:var(--text-primary);font-size:20px}.modal-close{background:none;border:none;font-size:28px;color:var(--text-secondary);cursor:pointer;padding:0;line-height:1;transition:color .2s;width:32px;height:32px;display:flex;align-items:center;justify-content:center}.modal-close:hover{color:var(--text-primary)}.modal-body{padding:20px;overflow-y:auto;flex:1}@media(max-width:768px){.modal-overlay{padding:0}.modal-content{max-width:100%;max-height:100vh;height:100vh;border-radius:0}.modal-header{padding:15px}.modal-header h2{font-size:18px}.modal-body{padding:15px}.modal-close{width:44px;height:44px}}.icon{display:inline-block;flex-shrink:0;vertical-align:middle}.icon-picker{width:100%}.icon-picker-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(48px,1fr));gap:6px;max-height:300px;overflow-y:auto;padding:8px;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:8px}.icon-picker-item{display:flex;align-items:center;justify-content:center;width:48px;height:48px;border:2px solid var(--border-color);border-radius:8px;background:var(--bg-primary);cursor:pointer;transition:all .2s;color:var(--text-secondary)}.icon-picker-item:hover{background:var(--hover-bg);border-color:var(--accent-primary);transform:scale(1.05)}.icon-picker-item.selected{background:var(--bg-tertiary);border-color:var(--accent-primary);border-width:3px;box-shadow:0 2px 8px #00000026}@media(max-width:1023px){.icon-picker-grid{grid-template-columns:repeat(auto-fill,minmax(52px,1fr));gap:3px;max-height:350px}.icon-picker-item{width:52px;height:52px}}@media(min-width:1024px){.icon-picker-grid{grid-template-columns:repeat(auto-fill,minmax(40px,1fr));gap:6px;max-height:280px}.icon-picker-item{width:40px;height:40px}}.form{display:flex;flex-direction:column;gap:16px}.form-group{display:flex;flex-direction:column;gap:6px}.form-group label{font-size:14px;font-weight:600;color:var(--text-primary)}.form-group small{font-size:12px;color:var(--text-secondary);margin-top:4px}.form-group input,.form-group select,.form-group textarea{padding:10px 12px;border:1px solid var(--border-color);border-radius:6px;font-size:14px;background:var(--bg-primary);color:var(--text-primary);transition:border-color .15s}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:#3b82f6}.form-actions{display:flex;gap:12px;justify-content:flex-end;margin-top:8px;padding-top:16px;border-top:1px solid var(--border-color)}input[type=color]{-webkit-appearance:none;-moz-appearance:none;appearance:none;padding:0;border:none;background:none}input[type=color]::-webkit-color-swatch-wrapper{padding:0;border:none}input[type=color]::-webkit-color-swatch{border:none;border-radius:inherit}input[type=color]::-moz-color-swatch{border:none;border-radius:inherit}.sidebar{width:260px;background:var(--bg-secondary);border-right:1px solid var(--border-color);overflow-y:auto;flex-shrink:0;padding:15px 0;display:flex;flex-direction:column}.sidebar-section{margin-bottom:20px}.sidebar-section-header{display:flex;justify-content:space-between;align-items:center;padding:8px 20px;font-size:12px;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px}.btn-icon-small{background:none;border:none;cursor:pointer;font-size:18px;padding:4px;color:var(--text-secondary);transition:color .2s}.btn-icon-small:hover{color:var(--text-primary)}.sidebar-nav{display:flex;flex-direction:column}.sidebar-item-wrapper{position:relative;display:flex;align-items:center}.sidebar-item{display:flex;align-items:center;gap:10px;padding:8px 20px;border:none;background:none;color:var(--text-primary);cursor:pointer;text-align:left;transition:all .15s cubic-bezier(.4,0,.2,1);font-size:14px;flex:1;border-left:3px solid transparent;text-decoration:none;touch-action:manipulation;-webkit-tap-highlight-color:transparent}.sidebar-item-gear{position:absolute;right:18px;background:none;border:none;padding:2px 6px;cursor:pointer;opacity:0;color:var(--text-secondary);border-radius:4px;display:flex;align-items:center;justify-content:center;transition:opacity .15s,color .15s;touch-action:manipulation;-webkit-tap-highlight-color:transparent}.sidebar-item-gear:hover{color:var(--accent-primary)}.sidebar-item-wrapper:hover .sidebar-item-gear{opacity:1}.sidebar-item-wrapper:hover .sidebar-count{opacity:0}.sidebar-item:hover{background:var(--input-border)}.sidebar-item.active{background:var(--input-border);font-weight:600;border-left-color:var(--accent-primary)}.sidebar-icon{font-size:16px;flex-shrink:0}.sidebar-label{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.sidebar-count{background:var(--bg-tertiary);color:var(--text-secondary);padding:2px 8px;border-radius:12px;font-size:12px;font-weight:600;min-width:24px;text-align:center}.sidebar-item.active .sidebar-count{background:var(--accent-primary);color:#fff}.sidebar-logout{margin-top:auto;margin-bottom:0;border-top:1px solid var(--border-color);padding-top:10px}.sidebar-overlay{display:none}@media(max-width:1023px){.sidebar{position:fixed;transform:translate3d(-280px,0,0);top:0;height:100vh;z-index:1100;transition:transform .3s cubic-bezier(.4,0,.2,1);box-shadow:2px 0 16px #00000026;width:280px;padding-top:20px;will-change:transform;backface-visibility:hidden}.sidebar-logout{margin-bottom:60px}.sidebar-open{transform:translateZ(0)}.sidebar-overlay{display:block;position:fixed;inset:0;background:#0006;z-index:1050;animation:fadeIn .3s cubic-bezier(.4,0,.2,1)}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.sidebar-item{padding:14px 20px;min-height:48px}.sidebar-icon{font-size:20px}.sidebar-section-header{padding:10px 20px;font-size:13px}.sidebar-item-gear{opacity:1;padding:8px;min-width:44px;min-height:44px}.sidebar-item-wrapper:hover .sidebar-count{opacity:1}.sidebar-count{margin-right:40px}}@media(min-width:768px)and (max-width:1023px){.sidebar{width:320px;left:-320px}}.list-card{display:flex;align-items:center;gap:16px;padding:16px;background:var(--bg-secondary);border:1px solid var(--border-color);border-left:4px solid var(--border-color);border-radius:12px;cursor:pointer;transition:all .15s cubic-bezier(.4,0,.2,1);box-shadow:0 1px 3px #0000000f}.list-card:hover{background:var(--hover-bg);border-color:var(--border-color-hover);transform:translateY(-1px);box-shadow:0 2px 8px #00000014}.list-card:active{transform:scale(.99);transition:transform .1s}.list-card-overdue,.list-card-urgent,.list-card.status-urgent{border-left-color:#ef4444}.list-card-today,.list-card-soon,.list-card.status-upcoming{border-left-color:#f97316}.list-card-tomorrow,.list-card-upcoming,.list-card-later,.list-card-good,.list-card.status-good{border-left-color:#10b981}.list-card-content{flex:1;display:flex;flex-direction:column;gap:4px}.list-card-name{font-size:16px;font-weight:600;color:var(--text-primary)}.list-card-details{display:flex;align-items:center;gap:6px;font-size:14px;color:var(--text-secondary)}.list-card-right{font-size:14px;font-weight:500;color:var(--text-tertiary);white-space:nowrap}.list-card-badge{padding:4px 12px;border-radius:6px;font-size:13px;font-weight:600;white-space:nowrap}.list-card-badge-overdue{background:#fee2e2;color:#991b1b}.list-card-badge-soon{background:#fed7aa;color:#9a3412}.list-card-badge-later{background:#d1fae5;color:#065f46}[data-theme=dark] .list-card-badge-overdue{background:#7f1d1d;color:#fca5a5}[data-theme=dark] .list-card-badge-soon{background:#7c2d12;color:#fdba74}[data-theme=dark] .list-card-badge-later{background:#064e3b;color:#6ee7b7}@media(max-width:768px){.list-card{padding:12px}.list-card-name{font-size:15px}.list-card-details,.list-card-right{font-size:13px}.list-card-badge{font-size:12px;padding:3px 10px}}.contact-card-wrapper{position:relative;overflow:hidden;border-radius:12px;margin-bottom:0}.swipe-background{position:absolute;inset:0;display:flex;pointer-events:none;border-radius:12px;overflow:hidden}.swipe-left-bg{width:100%;display:flex;align-items:center;justify-content:flex-start;padding-left:30px;gap:12px;background:#10b981;color:#fff;font-weight:600}.swipe-right-bg{width:100%;display:flex;align-items:center;justify-content:flex-end;padding-right:30px;gap:12px;background:#f59e0b;color:#fff;font-weight:600}.swipe-icon{width:28px;height:28px;stroke-width:2.5}.swipe-text{font-size:16px;font-weight:700;text-transform:uppercase;letter-spacing:.5px}.contact-card{position:relative;z-index:1;touch-action:pan-y;-webkit-user-select:none;user-select:none;-webkit-tap-highlight-color:transparent;contain:layout style paint}.contact-card.animating{opacity:.6;pointer-events:none}.contact-card.selected{background:var(--hover-bg);box-shadow:0 2px 12px #0000001f;border-color:var(--accent-primary)}.desktop-actions{display:none}@media(min-width:1024px){.desktop-actions{display:flex;gap:8px;align-items:center}.desktop-actions .contact-action{min-width:unset;padding:10px;border-radius:8px}.desktop-actions .contact-action .action-label{display:none}}.contact-action{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;padding:12px 16px;background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:8px;cursor:pointer;transition:all .15s cubic-bezier(.4,0,.2,1);flex-shrink:0;min-width:70px;color:var(--text-primary);touch-action:manipulation;-webkit-tap-highlight-color:transparent}.contact-action:hover{background:var(--accent-primary);color:#fff;border-color:var(--accent-primary)}.contact-action:active{transform:scale(.95)}.contact-action:disabled{opacity:.5;cursor:not-allowed;pointer-events:none}.contact-action.flagged{background:#f59e0b26;border-color:#f59e0b4d;color:var(--accent-primary)}.contact-action.flagged:hover{background:#f59e0b40;border-color:#f59e0b80}.contact-action .action-icon{width:20px;height:20px;stroke-width:2;color:var(--text-primary)}.contact-action:hover .action-icon{color:#fff}.action-label{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.snooze-menu{position:fixed;inset:0;background:#00000080;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:flex-end;justify-content:center;z-index:1000;animation:fadeIn .2s ease-out}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.snooze-menu-content{background:var(--bg-secondary);border-radius:20px 20px 0 0;padding:24px;width:100%;max-width:500px;animation:slideUp .3s cubic-bezier(.4,0,.2,1);box-shadow:0 -4px 20px #00000026}@keyframes slideUp{0%{transform:translateY(100%)}to{transform:translateY(0)}}.snooze-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}.snooze-title{margin:0;font-size:20px;font-weight:600;color:var(--text-primary)}.snooze-close{width:32px;height:32px;display:flex;align-items:center;justify-content:center;background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:8px;cursor:pointer;transition:all .2s;padding:0;flex-shrink:0}.snooze-close:hover{background:var(--hover-bg);border-color:var(--text-secondary)}.snooze-close:active{transform:scale(.95)}.snooze-close-icon{width:20px;height:20px;color:var(--text-primary);stroke-width:2}.snooze-options{display:flex;flex-direction:column;gap:12px;margin-bottom:16px}.snooze-option{padding:16px;background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:12px;font-size:16px;font-weight:500;color:var(--text-primary);cursor:pointer;transition:all .2s;text-align:left}.snooze-option:hover{background:var(--accent-primary);color:#fff;border-color:var(--accent-primary);transform:translate(4px)}.snooze-option:active{transform:scale(.98)}.snooze-cancel{width:100%;padding:16px;background:transparent;border:2px solid var(--border-color);border-radius:12px;font-size:16px;font-weight:600;color:var(--text-secondary);cursor:pointer;transition:all .2s}.snooze-cancel:hover{background:var(--bg-tertiary);border-color:var(--text-secondary);color:var(--text-primary)}@media(max-width:1023px){.contact-card{will-change:transform}.contact-action{min-width:75px;padding:14px 18px;min-height:44px}.action-icon{font-size:22px}.action-label{font-size:12px}.contact-action:hover{background:var(--bg-tertiary);color:var(--text-primary);border-color:var(--border-color)}}@media(min-width:1024px){.contact-action{flex-direction:row;gap:6px;padding:10px 14px;min-width:90px}.action-icon{font-size:18px}.action-label{font-size:11px}}.category-filter-pills{display:flex;gap:8px;margin-bottom:20px;flex-wrap:wrap}.category-filter-pills .pill-button{padding:8px 16px;border-radius:20px;border:1px solid var(--border-color);background:var(--bg-secondary);color:var(--text-primary);font-size:14px;font-weight:500;cursor:pointer;transition:all .2s;display:flex;align-items:center;gap:6px}.category-filter-pills .pill-button:hover{background:var(--hover-bg);border-color:var(--category-color, var(--border-color))}.category-filter-pills .pill-button.active{background:var(--category-color, var(--text-primary));color:#fff;border-color:var(--category-color, var(--text-primary));box-shadow:0 2px 8px #00000026}.category-filter-pills .pill-button.active:not([style*=--category-color]){background:var(--text-primary);color:var(--bg-primary)}.category-filter-pills .pill-button.active svg{color:#fff!important}.category-filter-pills .pill-icon{font-size:16px;line-height:1}@media(max-width:1023px){.category-filter-pills{overflow-x:auto;flex-wrap:nowrap;padding-bottom:8px;-webkit-overflow-scrolling:touch}.category-filter-pills .pill-button{flex-shrink:0;padding:10px 18px;font-size:15px}}@media(min-width:1024px){.category-filter-pills{margin-bottom:24px}.category-filter-pills .pill-button{font-size:13px;padding:6px 14px}}.list-view-header{margin-bottom:24px;display:flex;align-items:flex-start;justify-content:space-between;position:relative}.list-view-header-content{flex:1;display:flex;flex-direction:column;gap:8px}.list-view-header-action{flex-shrink:0;margin-top:4px}.list-view-title{font-size:36px;font-weight:700;color:var(--text-primary);margin:0;line-height:1.2}.list-view-subtitle{font-size:17px;color:var(--text-secondary);margin:0;line-height:1.4}@media(min-width:1024px){.list-view-title{font-size:28px}.list-view-subtitle{font-size:15px}}.color-picker{display:flex;gap:8px;flex-wrap:wrap;margin-top:8px}.color-button{width:36px;height:36px;border-radius:8px;cursor:pointer;transition:all .2s;padding:0;border:2px solid transparent;position:relative}.color-button:hover{transform:scale(1.1)}.color-button:active{transform:scale(.95)}.color-button.selected{border-color:var(--text-primary);box-shadow:0 0 0 2px var(--bg-secondary),0 0 0 4px var(--text-primary)}.custom-color-button{background:var(--bg-tertiary);border:2px dashed var(--border-color);display:flex;align-items:center;justify-content:center;color:var(--text-secondary);position:relative;padding:6px}.custom-color-button:hover{background:var(--hover-bg);border-color:var(--text-secondary);color:var(--text-primary)}.custom-color-button input[type=color]{position:absolute;top:0;left:0;width:100%;height:100%;opacity:0;cursor:pointer}.custom-icon{width:20px;height:20px;stroke-width:2.5;pointer-events:none}.labels-container{padding:20px}.labels-description{margin-bottom:24px;color:var(--text-secondary);font-size:14px}.label-form{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:8px;padding:20px;margin-bottom:24px}.form-header h3{margin:0 0 16px;font-size:16px;font-weight:600;color:var(--text-primary)}.form-group{margin-bottom:16px}.form-group label{display:block;margin-bottom:6px;font-size:13px;font-weight:500;color:var(--text-secondary)}.form-group input[type=text]{width:100%;padding:8px 12px;border:1px solid var(--border-color);border-radius:6px;background:var(--bg-primary);color:var(--text-primary);font-size:14px}.form-group input[type=text]:focus{outline:none;border-color:var(--accent-color)}.color-input-group{display:flex;gap:8px;align-items:center}.color-input-group input[type=color]{width:60px;height:38px;border:1px solid var(--border-color);border-radius:6px;cursor:pointer;background:var(--bg-primary)}.color-input-group input[type=text]{flex:1;max-width:120px}.color-preview{width:38px;height:38px;border-radius:6px;border:1px solid var(--border-color)}.form-actions{display:flex;gap:12px;justify-content:flex-end;margin-top:20px}.labels-list{display:flex;flex-direction:column;gap:12px}.label-card{display:flex;justify-content:space-between;align-items:center;padding:12px 16px;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:8px;transition:all .15s}.label-card:hover{border-color:var(--text-tertiary)}@media(prefers-color-scheme:light){.label-card:hover{box-shadow:0 2px 8px #0000000d}}@media(prefers-color-scheme:dark){.label-card:hover{box-shadow:0 2px 8px #0000004d}}.label-info{display:flex;align-items:center;gap:12px}.label-color-dot{width:16px;height:16px;border-radius:50%;flex-shrink:0}@media(prefers-color-scheme:light){.label-color-dot{border:1px solid rgba(0,0,0,.1)}}@media(prefers-color-scheme:dark){.label-color-dot{border:1px solid rgba(255,255,255,.2)}}.label-name{font-size:15px;font-weight:500;color:var(--text-primary)}.label-actions{display:flex;gap:8px}.btn-icon{background:transparent;border:none;cursor:pointer;padding:6px;border-radius:4px;transition:all .15s;display:flex;align-items:center;justify-content:center;color:var(--text-secondary)}.btn-icon:hover{background:var(--bg-tertiary);color:var(--text-primary)}.btn-icon:active{transform:scale(.95)}.no-labels{text-align:center;padding:40px 20px;color:var(--text-secondary)}.settings-container{padding:24px;max-width:800px}.settings-description{color:var(--text-secondary);margin-bottom:32px;font-size:14px;line-height:1.5}.settings-section{background:var(--card-bg);border:1px solid var(--border-color);border-radius:8px;padding:24px;margin-bottom:24px}.section-header{display:flex;align-items:center;gap:12px;margin-bottom:20px}.section-header h3{margin:0;font-size:18px;font-weight:600}.section-description{color:var(--text-secondary);font-size:14px;margin-bottom:20px;line-height:1.5}.setting-item{display:flex;justify-content:space-between;align-items:center;padding:16px 0;border-bottom:1px solid var(--border-color)}.setting-item:last-child{border-bottom:none;padding-bottom:0}.setting-item:first-child{padding-top:0}.setting-info{flex:1}.setting-info label{display:block;font-weight:500;margin-bottom:4px;font-size:15px}.setting-description{color:var(--text-secondary);font-size:13px;margin:0;line-height:1.4}.theme-selector{display:flex;gap:8px}.theme-option{padding:8px 16px;background:var(--bg-primary);border:1px solid var(--border-color);border-radius:6px;cursor:pointer;font-size:14px;color:var(--text-primary);transition:all .2s}.theme-option:hover{background:var(--bg-hover)}.theme-option.active{background:var(--accent-color);color:#fff;border-color:var(--accent-color);font-weight:600}[data-theme=light] .theme-option.active{background:#3b82f6;color:#fff;border-color:#3b82f6}[data-theme=dark] .theme-option.active{background:#60a5fa;color:#000;border-color:#60a5fa}.toggle-switch{position:relative;width:48px;height:28px;background:var(--border-color);border:none;border-radius:14px;cursor:pointer;transition:background-color .3s;flex-shrink:0}.toggle-switch:hover{opacity:.8}.toggle-switch.active{background:var(--accent-color)}.toggle-slider{position:absolute;top:2px;left:2px;width:24px;height:24px;background:#fff;border-radius:50%;transition:transform .3s;box-shadow:0 2px 4px #0003}.toggle-switch.active .toggle-slider{transform:translate(20px)}@media(max-width:768px){.settings-container,.settings-section{padding:16px}.setting-item{flex-direction:column;align-items:flex-start;gap:12px}.theme-selector{width:100%}.theme-option{flex:1}}.list-filters{display:flex;flex-direction:column;gap:8px;margin-bottom:16px}.list-filters-search{position:relative}.list-filters-search input{width:100%;padding:10px 36px 10px 12px;border:1px solid var(--border-color);border-radius:8px;background:var(--bg-secondary);color:var(--text-primary);font-size:15px;outline:none;transition:border-color .2s;box-sizing:border-box}.list-filters-search input:focus{border-color:var(--text-secondary)}.list-filters-search input::placeholder{color:var(--text-secondary)}.list-filters-search .clear-btn{position:absolute;right:8px;top:50%;transform:translateY(-50%);background:none;border:none;cursor:pointer;padding:4px;display:flex;align-items:center;color:var(--text-secondary)}.list-filters-row{display:flex;gap:8px;align-items:center;flex-wrap:wrap}.list-filters-row select{padding:8px 12px;border:1px solid var(--border-color);border-radius:20px;background:var(--bg-secondary);color:var(--text-primary);font-size:14px;font-weight:500;cursor:pointer;outline:none;appearance:auto}.list-filters-row select:focus{border-color:var(--text-secondary)}.list-filters-row select.active{background:var(--text-primary);color:var(--bg-primary);border-color:var(--text-primary)}.miss-you-chip{padding:8px 16px;border-radius:20px;border:1px solid var(--border-color);background:var(--bg-secondary);color:var(--text-primary);font-size:14px;font-weight:500;cursor:pointer;transition:all .2s;white-space:nowrap}.miss-you-chip:hover{background:var(--hover-bg)}.miss-you-chip.active{background:#ef4444;color:#fff;border-color:#ef4444}@media(max-width:1023px){.list-filters-search input{font-size:16px;padding:12px 40px 12px 14px}.list-filters-row select,.miss-you-chip{padding:10px 18px;font-size:15px}}@media(min-width:1024px){.list-filters{margin-bottom:20px}.list-filters-search input{font-size:14px;padding:8px 32px 8px 10px}.list-filters-row select,.miss-you-chip{font-size:13px;padding:6px 14px}}.next-view{flex:1;overflow-y:auto;padding:20px;max-width:100%;background:var(--bg-primary);min-width:0;-webkit-overflow-scrolling:touch;overscroll-behavior-y:contain}.next-section{margin-bottom:48px}.empty-state{text-align:center;padding:60px 20px}.empty-state.compact{padding:24px 20px}.empty-state p{margin:0;font-size:18px;color:var(--text-primary)}.empty-state.compact p{font-size:15px}.empty-subtitle{margin-top:4px!important;font-size:14px!important;color:var(--text-secondary)!important}.empty-state.compact .empty-subtitle{font-size:13px!important}.upcoming-section{margin-bottom:32px}.section-title{font-size:24px;font-weight:700;color:var(--text-primary);margin:0 0 16px}.upcoming-list{display:flex;flex-direction:column;gap:12px}.upcoming-item{display:flex;align-items:center;gap:16px;padding:16px;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:12px;cursor:pointer;transition:all .2s}.upcoming-item:hover{background:var(--hover-bg);box-shadow:0 2px 8px #00000014}.upcoming-icon{width:48px;height:48px;display:flex;align-items:center;justify-content:center;background:var(--bg-tertiary);border-radius:12px;font-size:24px;flex-shrink:0}.upcoming-content{flex:1;min-width:0}.upcoming-name{font-size:16px;font-weight:600;color:var(--text-primary);margin-bottom:4px}.upcoming-type{font-size:14px;color:var(--text-secondary)}.upcoming-date{font-size:14px;font-weight:600;color:var(--accent-primary);white-space:nowrap}@media(max-width:1023px){.next-view{padding:16px;padding-bottom:calc(80px + var(--safe-area-inset-bottom))}.contacts-list{gap:12px}.upcoming-item{padding:18px}.upcoming-icon{width:56px;height:56px;font-size:28px}.upcoming-name{font-size:17px}.upcoming-type,.upcoming-date{font-size:15px}}@media(min-width:1024px){.next-view{padding:24px;width:100%}.contacts-list{gap:8px}.upcoming-item{padding:14px}.upcoming-icon{width:44px;height:44px;font-size:22px}.upcoming-name{font-size:15px}.upcoming-type,.upcoming-date{font-size:13px}}.swipeable-card-wrapper{position:relative;overflow:hidden;touch-action:pan-y}.swipeable-card-content{position:relative;z-index:1}.swipe-background{position:absolute;inset:0;display:flex;align-items:center;justify-content:space-between;z-index:0}.swipe-left-bg{display:flex;align-items:center;gap:12px;padding-left:24px;background:var(--success-bg, #10b981);color:#fff;height:100%;flex:1}.swipe-right-bg{display:flex;align-items:center;gap:12px;padding-right:24px;background:var(--success-bg, #10b981);color:#fff;height:100%;flex:1;justify-content:flex-end}.swipe-text{font-size:14px;font-weight:600}.swipeable-card-content.animating{pointer-events:none;opacity:.5;transition:opacity .3s ease}.swipeable-desktop-actions{display:none;position:absolute;right:12px;top:50%;transform:translateY(-50%);gap:8px;z-index:2}@media(min-width:768px){.swipeable-desktop-actions{display:flex}.swipeable-card-content>.list-card{padding-right:60px}}.swipeable-action{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border:none;background:var(--bg-secondary);color:var(--text-secondary);border-radius:8px;cursor:pointer;transition:all .2s ease}.swipeable-action:hover{background:var(--success-bg, #10b981);color:#fff;transform:scale(1.05)}.swipeable-action:active{transform:scale(.95)}.swipeable-card-content{position:relative}.moments-view{padding:20px;max-width:1200px;margin:0 auto;width:100%;height:100%;overflow-y:auto;-webkit-overflow-scrolling:touch;overscroll-behavior-y:contain}.moments-content{display:flex;flex-direction:column;gap:32px}.moments-section{display:flex;flex-direction:column;gap:12px}.moments-section .section-title{font-size:12px;font-weight:700;letter-spacing:.5px;color:var(--text-secondary);text-transform:uppercase;margin:0}.moments-list{display:flex;flex-direction:column;gap:8px}.moment-card{display:flex;align-items:center;gap:16px;padding:16px;background:var(--bg-secondary);border:1px solid var(--border-color);border-left:4px solid var(--border-color);border-radius:12px;cursor:pointer;transition:all .15s cubic-bezier(.4,0,.2,1);box-shadow:0 1px 3px #0000000f}.moment-card:hover{background:var(--hover-bg);border-color:var(--border-color-hover);transform:translateY(-1px);box-shadow:0 2px 8px #00000014}.moment-card:active{transform:scale(.99);transition:transform .1s}.moment-card-overdue{border-left-color:#ef4444}.moment-card-today{border-left-color:#f97316}.moment-card-tomorrow,.moment-card-upcoming{border-left-color:#10b981}.moment-content{flex:1;display:flex;flex-direction:column;gap:4px}.moment-name{font-size:16px;font-weight:600;color:var(--text-primary)}.moment-event-info{display:flex;align-items:center;gap:6px;font-size:14px;color:var(--text-secondary)}.moment-date{font-size:14px;font-weight:500;color:var(--text-tertiary)}@media(max-width:1023px){.moments-view{padding:16px;padding-bottom:calc(80px + var(--safe-area-inset-bottom))}.moment-card{padding:12px}.moment-name{font-size:15px}.moment-event-info,.moment-date{font-size:13px}}@media(min-width:1024px){.moments-view{padding:24px}}.miss-you-view{padding:20px;max-width:1200px;margin:0 auto;width:100%;height:100%;overflow-y:auto;-webkit-overflow-scrolling:touch;overscroll-behavior-y:contain}.miss-you-content{display:flex;flex-direction:column;gap:32px}.miss-you-section{display:flex;flex-direction:column;gap:12px}.miss-you-section .section-title{font-size:12px;font-weight:700;letter-spacing:.5px;color:var(--text-secondary);text-transform:uppercase;margin:0}.miss-you-list{display:flex;flex-direction:column;gap:8px}.miss-you-card{display:flex;align-items:center;gap:16px;padding:16px;background:var(--bg-secondary);border:1px solid var(--border-color);border-left:4px solid var(--border-color);border-radius:12px;cursor:pointer;transition:all .15s cubic-bezier(.4,0,.2,1);box-shadow:0 1px 3px #0000000f}.miss-you-card:hover{background:var(--hover-bg);border-color:var(--border-color-hover);transform:translateY(-1px);box-shadow:0 2px 8px #00000014}.miss-you-card:active{transform:scale(.99);transition:transform .1s}.miss-you-card-already{border-left-color:#ef4444}.miss-you-card-soon{border-left-color:#f97316}.miss-you-card-later{border-left-color:#10b981}.miss-you-content-area{flex:1;display:flex;flex-direction:column;gap:4px}.miss-you-name{font-size:16px;font-weight:600;color:var(--text-primary)}.miss-you-status-info{display:flex;align-items:center;gap:6px;font-size:14px;color:var(--text-secondary)}.miss-you-badge{padding:4px 12px;border-radius:6px;font-size:13px;font-weight:600;white-space:nowrap}.miss-you-badge-overdue{background:#fee2e2;color:#991b1b}.miss-you-badge-soon{background:#fed7aa;color:#9a3412}.miss-you-badge-later{background:#d1fae5;color:#065f46}[data-theme=dark] .miss-you-badge-overdue{background:#7f1d1d;color:#fca5a5}[data-theme=dark] .miss-you-badge-soon{background:#7c2d12;color:#fdba74}[data-theme=dark] .miss-you-badge-later{background:#064e3b;color:#6ee7b7}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:64px 24px;gap:12px}.empty-state p{font-size:16px;color:var(--text-secondary);margin:0}.empty-subtitle{font-size:14px!important;color:var(--text-tertiary)!important}.loading{display:flex;align-items:center;justify-content:center;padding:64px 24px;font-size:16px;color:var(--text-secondary)}@media(max-width:1023px){.miss-you-view{padding:16px;padding-bottom:calc(80px + var(--safe-area-inset-bottom))}.miss-you-card{padding:12px}.miss-you-name{font-size:15px}.miss-you-status-info{font-size:13px}.miss-you-badge{font-size:12px;padding:3px 10px}}@media(min-width:1024px){.miss-you-view{padding:24px}}.main-content{flex:1;overflow-y:auto;padding:20px;background:var(--bg-primary);min-width:0;-webkit-overflow-scrolling:touch;overscroll-behavior-y:contain}.view-header-gear{background:transparent;border:none;cursor:pointer;padding:6px;border-radius:4px;transition:all .15s;display:flex;align-items:center;justify-content:center;color:var(--text-tertiary);flex-shrink:0;margin-top:4px}.view-header-gear:hover{background:var(--bg-tertiary);color:var(--text-secondary)}.view-header-gear.active,.view-header-gear.active:hover{color:var(--accent-primary)}.view-header-gear:active{transform:scale(.95)}.desktop-only{display:none}@media(min-width:1024px){.desktop-only{display:flex}}.contacts-list{display:flex;flex-direction:column;gap:8px}.contacts-list p{color:var(--text-secondary);text-align:center;padding:20px}@media(max-width:1023px){.main-content{padding:16px;padding-bottom:calc(80px + var(--safe-area-inset-bottom));-webkit-overflow-scrolling:touch;overscroll-behavior-y:contain}body.detail-view-open .main-content{overflow:hidden;touch-action:none}.contacts-list{gap:12px}}@media(min-width:1024px){.main-content{padding:24px 32px}.contacts-list{gap:8px}}.events-list{display:flex;flex-direction:column;gap:8px}.event-item{display:flex;align-items:center;gap:12px;padding:12px;background:var(--bg-tertiary);border-radius:8px}.event-icon{font-size:20px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.event-details{flex:1;min-width:0}.event-name{font-weight:600;color:var(--text-primary);font-size:15px}.event-date{font-size:13px;color:var(--text-secondary);margin-top:2px}.event-countdown{color:var(--text-secondary)}.event-actions{display:flex;gap:8px;align-items:center;flex-shrink:0}.event-skip-btn{background:var(--bg-secondary);border:1px solid var(--border-color);color:var(--text-secondary);cursor:pointer;font-size:13px;font-weight:500;padding:6px 12px;border-radius:6px;transition:all .2s;white-space:nowrap}.event-skip-btn:hover{background:var(--bg-tertiary);border-color:var(--text-secondary);color:var(--text-primary)}.event-skip-btn:active{transform:scale(.95)}.event-skip-btn:disabled{opacity:.5;cursor:not-allowed;background:var(--bg-tertiary);border-color:var(--border-color);color:var(--text-tertiary)}.event-delete-btn{background:none;border:none;color:var(--text-secondary);cursor:pointer;font-size:20px;padding:4px;line-height:1;flex-shrink:0;width:24px;height:24px;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:all .2s}.event-delete-btn:hover{background:var(--bg-tertiary);color:var(--text-primary)}.event-delete-btn:active{transform:scale(.95)}.event-date-editable{display:flex;flex-direction:column;gap:4px}.event-date-input{padding:6px 10px;font-size:14px;font-family:inherit;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:6px;color:var(--text-primary);outline:none;transition:border-color .2s}.event-date-input:focus{border-color:var(--primary-color)}.event-countdown-hint{font-size:12px;color:var(--text-secondary)}.interaction-picker-form{margin-top:16px;padding:16px;background:#3b82f614;border:1px solid rgba(59,130,246,.2);border-radius:12px}.interaction-picker-form .form-group{margin-bottom:16px}.interaction-picker-form .form-group:last-of-type{margin-bottom:0}.interaction-picker-form label{display:block;margin-bottom:8px;font-size:14px;font-weight:600;color:var(--text-primary)}.interaction-picker-form input[type=datetime-local],.interaction-picker-form select{width:100%;padding:10px;border:1px solid var(--border-color);border-radius:8px;background:var(--bg-primary);color:var(--text-primary);font-size:14px;font-family:inherit}.interaction-picker-form input[type=datetime-local]:focus,.interaction-picker-form select:focus{outline:none;border-color:var(--accent-primary);box-shadow:0 0 0 3px #3b82f61a}.interaction-picker-form .picker-actions{display:flex;gap:12px;justify-content:flex-end;margin-top:16px}.interaction-picker-form .picker-actions .btn{flex:1;max-width:120px}.month-day-picker{display:flex;gap:6px;align-items:center}.month-day-picker-select{padding:8px;font-size:14px;font-family:inherit;background:var(--input-bg, #fff);border:1px solid var(--border-color, #ddd);border-radius:4px;color:var(--text-primary, #000);cursor:pointer;min-width:0}.month-day-picker .month-day-picker-select:nth-child(1){width:87px}.month-day-picker .month-day-picker-select:nth-child(2){width:71px}.month-day-picker .month-day-picker-select:nth-child(3){width:140px}.month-day-picker-select:disabled{opacity:.5;cursor:not-allowed;background:var(--bg-tertiary, #f5f5f5)}.month-day-picker-select:focus{outline:none;border-color:var(--btn-primary-bg, #007bff);box-shadow:0 0 0 3px #007bff1a}.month-day-picker-clear{padding:8px;font-size:20px;line-height:1;background:var(--btn-secondary-bg, #6c757d);color:var(--btn-secondary-text, #fff);border:none;border-radius:4px;cursor:pointer;transition:background .2s,opacity .2s}.month-day-picker-clear:hover:not(:disabled){background:var(--btn-secondary-hover, #5a6268)}.month-day-picker-clear:focus{outline:none;box-shadow:0 0 0 3px #6c757d4d}.month-day-picker-clear:disabled{opacity:.4;cursor:not-allowed}.contact-edit-form{flex:1;overflow-y:auto;padding:24px}.edit-section label{display:block;font-weight:600;color:var(--text-primary);margin-bottom:8px;font-size:14px}.edit-select{width:100%;padding:12px;border:1px solid var(--border-color);border-radius:8px;background:var(--bg-primary);color:var(--text-primary);font-size:14px;font-family:inherit}.edit-select:focus{outline:none;border-color:var(--accent-primary)}.edit-hint{margin-top:6px;font-size:12px;color:var(--text-secondary)}.edit-field-display{padding:12px;background:var(--bg-tertiary);border-radius:8px;color:var(--text-secondary);font-size:14px}.edit-event-field{margin-bottom:12px}.btn-icon{display:flex;align-items:center;justify-content:center;background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:8px;cursor:pointer;transition:all .2s;color:var(--text-secondary)}.btn-icon:hover{background:var(--hover-bg);border-color:var(--accent-primary);color:var(--accent-primary)}.btn-secondary{width:100%;padding:14px;background:transparent;border:2px solid var(--border-color);border-radius:8px;color:var(--text-primary);font-weight:600;font-size:14px;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center;gap:8px;margin-bottom:12px}.btn-secondary:hover:not(:disabled){background:var(--bg-tertiary);border-color:var(--accent-primary);color:var(--accent-primary)}.btn-secondary:disabled{opacity:.5;cursor:not-allowed}.btn-danger{width:100%;padding:14px;background:transparent;border:2px solid #ef4444;border-radius:8px;color:#ef4444;font-weight:600;font-size:14px;cursor:pointer;transition:all .2s}.btn-danger:hover{background:#ef4444;color:#fff}.detail-panel{display:flex;flex-direction:column;height:100%;background:var(--bg-primary);overflow:hidden}@media(max-width:1023px){.detail-panel:before{content:"";position:fixed;inset:56px 0 0;background:var(--bg-primary);z-index:-1}.detail-panel{position:fixed;inset:56px 0 0;padding-bottom:calc(80px + env(safe-area-inset-bottom));z-index:1000;transform:translate(100%);transition:transform .3s ease-in-out;width:100%;overflow-y:auto;overflow-x:hidden;-webkit-overflow-scrolling:touch;overscroll-behavior:contain;box-sizing:border-box}.detail-panel:not(.detail-panel-empty-state){transform:translate(0)}.detail-panel-empty-state{display:none}}@media(min-width:1024px){.detail-panel{flex:0 0 400px;width:400px;max-width:400px;border-left:1px solid var(--border-color)}}.detail-panel-empty{display:flex;align-items:center;justify-content:center;height:100%;color:var(--text-secondary);font-size:15px;padding:20px;text-align:center}.detail-wrapper{display:flex;flex-direction:column;padding:20px;width:100%}@media(min-width:1024px){.detail-wrapper{height:100%}}@media(max-width:1023px){.detail-wrapper{min-height:100%;height:auto}}.detail-loading{padding:40px 20px;text-align:center}.detail-header{margin-bottom:16px;padding-bottom:12px;border-bottom:1px solid var(--border-color)}.detail-header-top{display:flex;justify-content:space-between;align-items:flex-start}.detail-name{font-size:24px;font-weight:700;color:var(--text-primary);margin:0;flex:1}.detail-actions{display:flex;align-items:center;gap:8px}.detail-overflow-wrapper{position:relative}.btn-overflow{background:none;border:none;color:var(--text-secondary);cursor:pointer;padding:4px 8px;border-radius:4px;transition:all .2s;display:flex;align-items:center;justify-content:center;width:32px;height:32px}.btn-overflow:hover{background:var(--hover-bg);color:var(--text-primary)}.detail-overflow-dropdown{position:absolute;top:100%;right:0;min-width:160px;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:10px;box-shadow:0 4px 16px #0000001f;z-index:100;padding:4px;animation:dropdownFadeIn .15s ease-out}@keyframes dropdownFadeIn{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.detail-overflow-item{display:flex;align-items:center;gap:10px;width:100%;padding:10px 12px;border:none;background:none;border-radius:6px;font-size:14px;font-weight:500;color:var(--text-primary);cursor:pointer;transition:background .15s;text-align:left}.detail-overflow-item:hover{background:var(--hover-bg)}.detail-overflow-item.danger{color:#ef4444}.detail-overflow-item.danger:hover{background:#ef44441a}.btn-close{background:none;border:none;color:var(--text-secondary);font-size:24px;cursor:pointer;padding:4px 8px;border-radius:4px;transition:all .2s;line-height:1;display:flex;align-items:center;justify-content:center;width:32px;height:32px}.btn-close:hover{background:var(--hover-bg);color:var(--text-primary)}.detail-status{text-align:center;padding:8px 0 20px}.status-line{display:flex;align-items:center;justify-content:center;gap:8px;margin-bottom:4px}.status-dot{width:10px;height:10px;border-radius:50%;display:inline-block;flex-shrink:0}.status-label{font-size:16px;font-weight:600;color:var(--text-primary)}.status-secondary{font-size:14px;color:var(--text-secondary);margin-top:2px}.status-notes{font-size:14px;color:var(--text-tertiary);font-style:italic;margin-top:6px}.quick-actions-section{margin-bottom:24px}.quick-actions-row{display:flex;gap:10px;margin-bottom:10px}.btn-connected{flex:1;display:flex;align-items:center;justify-content:center;gap:8px;padding:12px 16px;background:#4caf50;color:#fff;border:none;border-radius:10px;font-size:15px;font-weight:600;cursor:pointer;transition:all .2s}.btn-connected:hover{background:#43a047}.btn-connected:active{transform:scale(.98)}.btn-log-custom{flex:1;display:flex;align-items:center;justify-content:center;gap:8px;padding:12px 16px;background:transparent;color:var(--text-primary);border:1.5px solid var(--border-color);border-radius:10px;font-size:15px;font-weight:600;cursor:pointer;transition:all .2s}.btn-log-custom:hover{border-color:var(--text-tertiary);background:var(--hover-bg)}.btn-log-custom:active{transform:scale(.98)}.btn-snooze-full{width:100%;display:flex;align-items:center;justify-content:center;gap:8px;padding:12px 16px;background:transparent;color:#f59e0b;border:1.5px solid rgba(245,158,11,.3);border-radius:10px;font-size:15px;font-weight:600;cursor:pointer;transition:all .2s}.btn-snooze-full:hover:not(:disabled){border-color:#f59e0b80;background:#f59e0b0f}.btn-snooze-full:disabled{opacity:.5;cursor:not-allowed}.btn-snooze-full:active:not(:disabled){transform:scale(.98)}.btn-snooze-full.snoozed{color:#3b82f6;border-color:#3b82f64d}.btn-snooze-full.snoozed:hover{border-color:#3b82f680;background:#3b82f60f}.detail-edit-content{flex:1;overflow-y:auto;-webkit-overflow-scrolling:touch}.edit-section{margin-bottom:24px}.edit-section label{display:block;font-size:14px;font-weight:600;color:var(--text-primary);margin-bottom:8px}.edit-select{width:100%;padding:12px;border:1px solid var(--border-color);border-radius:8px;font-size:15px;background:var(--bg-tertiary);color:var(--text-primary);font-family:inherit}.edit-hint{margin-top:6px;font-size:13px;color:var(--text-secondary)}.edit-field-display{padding:12px;background:var(--bg-tertiary);border-radius:8px;font-size:15px;color:var(--text-primary)}.labels-list{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:12px;max-width:max-content}.label-badge{padding:6px 12px;border-radius:16px;color:#fff;font-size:13px;font-weight:500;display:inline-flex;align-items:center;gap:6px}.label-remove{background:none;border:none;color:#fff;cursor:pointer;padding:0;font-size:18px;font-weight:700;opacity:.8;line-height:1}.label-remove:hover{opacity:1}.labels-empty{font-size:13px;color:var(--text-secondary)}.label-pills-grid{display:flex;flex-wrap:wrap;gap:8px;margin-top:8px}.label-pill{padding:4px 12px;border-radius:20px;font-size:13px;font-weight:500;cursor:pointer;transition:all .2s ease;border:1.5px solid var(--border-color);background:var(--bg-tertiary);color:var(--text-secondary)}.label-pill:hover{border-color:var(--text-tertiary);transform:translateY(-1px);box-shadow:0 2px 4px #0000001a}.label-pill:active{transform:translateY(0)}.label-pill.selected{font-weight:600;border-width:1.5px;box-shadow:0 2px 6px #00000026}.label-pill.selected:hover{transform:translateY(-1px);box-shadow:0 3px 8px #0003}@media(prefers-color-scheme:dark){.label-pill{background:var(--bg-secondary);border-color:var(--border-color)}.label-pill:hover{border-color:var(--text-tertiary);box-shadow:0 2px 4px #0000004d}.label-pill.selected{box-shadow:0 2px 6px #0006}.label-pill.selected:hover{box-shadow:0 3px 8px #00000080}.detail-overflow-dropdown{box-shadow:0 4px 16px #0000004d}}.detail-content{flex:1;overflow-y:auto;-webkit-overflow-scrolling:touch}.section-title{font-size:20px;font-weight:700;color:var(--text-primary);margin:0 0 16px}.events-section,.labels-section,.history-section{margin-bottom:24px}.section-header{display:flex;justify-content:space-between;align-items:center;margin:12px 0}.see-all-link{background:none;border:none;color:var(--accent-primary);font-size:15px;font-weight:600;cursor:pointer;padding:4px 8px}.see-all-link:hover{opacity:.8}.history-list{margin-bottom:20px}.history-item{display:flex;align-items:center;gap:12px;padding:12px;background:var(--bg-tertiary);border-radius:10px;margin-bottom:8px;transition:background .2s}.history-item:hover{background:var(--hover-bg)}.history-item:hover .history-delete-btn{opacity:1}.history-icon{width:40px;height:40px;display:flex;align-items:center;justify-content:center;background:var(--bg-secondary);border-radius:8px;font-size:20px;flex-shrink:0}.history-content{flex:1;min-width:0}.history-title{font-size:15px;font-weight:600;color:var(--text-primary);margin-bottom:2px}.history-title-editable{cursor:pointer;display:inline-flex;align-items:center;gap:6px;padding:2px 6px;border-radius:4px;transition:background .2s}.history-title-editable:hover{background:var(--hover-bg)}.history-title-editable .edit-icon{opacity:0;transition:opacity .2s}.history-title-editable:hover .edit-icon{opacity:.6}.history-edit-form{display:flex;flex-direction:column;gap:8px;width:100%}.history-date-input{width:100%;padding:8px 10px;border:1px solid var(--border-color);border-radius:6px;background:var(--bg-primary);color:var(--text-primary);font-size:14px;font-family:inherit}.history-edit-actions{display:flex;gap:8px}.history-edit-actions .btn-save,.history-edit-actions .btn-cancel{flex:1;padding:6px 12px;border:none;border-radius:6px;cursor:pointer;font-size:14px;font-weight:500;transition:all .2s;display:flex;align-items:center;justify-content:center;gap:4px}.history-edit-actions .btn-save{background:var(--btn-primary-bg);color:#fff}.history-edit-actions .btn-save:hover:not(:disabled){background:var(--btn-primary-hover-bg)}.history-edit-actions .btn-save:disabled{opacity:.5;cursor:not-allowed}.history-edit-actions .btn-cancel{background:var(--bg-tertiary);color:var(--text-primary)}.history-edit-actions .btn-cancel:hover{background:var(--hover-bg)}.history-type{font-size:14px;color:var(--text-secondary)}.history-delete-btn{background:none;border:none;color:var(--text-tertiary);cursor:pointer;padding:8px;border-radius:6px;opacity:0;transition:all .2s;display:flex;align-items:center;justify-content:center}.history-delete-btn:hover{background:#ef44441a;color:#ef4444}@media(max-width:1023px){.history-delete-btn{opacity:1}}.history-empty{text-align:center;padding:32px 16px;color:var(--text-secondary);font-size:15px}.picker-actions{display:flex;gap:12px;justify-content:flex-end}.picker-actions .btn{flex:1;max-width:120px}.no-events-message{font-size:13px;color:var(--text-secondary);margin-bottom:12px;padding:12px;background:var(--bg-tertiary);border-radius:8px}.quick-actions-section .snooze-menu{position:fixed;inset:0;background:#00000080;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:flex-end;justify-content:center;z-index:1000;animation:snoozePickerFadeIn .2s ease-out}@keyframes snoozePickerFadeIn{0%{opacity:0}to{opacity:1}}.quick-actions-section .snooze-menu-content{background:var(--bg-secondary);border-radius:20px 20px 0 0;padding:24px;width:100%;max-width:500px;animation:snoozePickerSlideUp .3s cubic-bezier(.4,0,.2,1);box-shadow:0 -4px 20px #00000026}@keyframes snoozePickerSlideUp{0%{transform:translateY(100%)}to{transform:translateY(0)}}.quick-actions-section .snooze-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}.quick-actions-section .snooze-title{margin:0;font-size:18px;font-weight:600;color:var(--text-primary)}.quick-actions-section .snooze-close{width:28px;height:28px;display:flex;align-items:center;justify-content:center;background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:6px;cursor:pointer;padding:0}.quick-actions-section .snooze-close:hover{background:var(--hover-bg)}.quick-actions-section .snooze-options{display:flex;flex-direction:column;gap:8px;margin-bottom:12px}.quick-actions-section .snooze-option{padding:12px 16px;background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:10px;font-size:15px;font-weight:500;color:var(--text-primary);cursor:pointer;transition:all .2s;text-align:left;display:flex;align-items:center;gap:8px}.quick-actions-section .snooze-option:hover{background:var(--accent-primary);color:#fff;border-color:var(--accent-primary)}.snooze-option-detail{font-size:12px;font-weight:400;color:var(--text-secondary);margin-left:auto}.snooze-option:hover .snooze-option-detail{color:#ffffffb3}.quick-actions-section .snooze-cancel{width:100%;padding:12px;background:transparent;border:2px solid var(--border-color);border-radius:10px;font-size:15px;font-weight:600;color:var(--text-secondary);cursor:pointer}.quick-actions-section .snooze-cancel:hover{background:var(--bg-tertiary)}@media(max-width:1023px){.detail-wrapper{padding:16px}.detail-name{font-size:26px}.section-title{font-size:22px}.detail-edit-content,.detail-content{overflow-y:visible;overflow-x:visible}}@media(min-width:1024px){.detail-wrapper{padding:24px}.detail-name{font-size:22px}.section-title{font-size:18px}.history-item{padding:10px 12px}.history-icon{width:36px;height:36px;font-size:18px}.history-title{font-size:14px}.history-type{font-size:13px}}.sync-indicator-container{position:relative}.sync-indicator{display:flex;align-items:center;gap:6px;padding:6px 12px;border:none;border-radius:6px;background:var(--bg-secondary);color:var(--text-secondary);font-size:13px;cursor:pointer;transition:all .2s;-webkit-user-select:none;user-select:none;min-width:170px;justify-content:center}.sync-indicator:hover:not(:disabled){background:var(--bg-tertiary);color:var(--text-primary)}.sync-indicator:disabled{cursor:not-allowed;opacity:.6}.sync-indicator:active:not(:disabled),.sync-indicator:focus:not(:disabled){outline:none}.sync-indicator.syncing:active:not(:disabled),.sync-indicator.syncing:focus:not(:disabled){color:#3b82f6}.sync-indicator.synced:active:not(:disabled),.sync-indicator.synced:focus:not(:disabled){color:#10b981}.sync-indicator.http-only:active:not(:disabled),.sync-indicator.http-only:focus:not(:disabled){color:#f59e0b}.sync-indicator.offline:active:not(:disabled),.sync-indicator.offline:focus:not(:disabled){color:#6b7280}.sync-indicator.error:active:not(:disabled),.sync-indicator.error:focus:not(:disabled){color:#ef4444}.sync-icon{font-size:16px;line-height:1;display:inline-block}.sync-indicator.spinning .sync-icon{animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.sync-indicator.syncing{color:#3b82f6}.sync-indicator.synced{color:#10b981}.sync-indicator.http-only{color:#f59e0b}.sync-indicator.offline{color:#6b7280}.sync-indicator.error{color:#ef4444}.sync-detail-tooltip{position:absolute;top:calc(100% + 8px);right:0;z-index:1000;animation:fadeIn .2s ease-in}@keyframes fadeIn{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.sync-status-detail{padding:12px;background:var(--bg-primary);border-radius:8px;box-shadow:0 4px 12px #00000026;min-width:240px;font-size:13px}.sync-status-section{display:flex;justify-content:space-between;align-items:center;padding:8px 0;border-bottom:1px solid var(--border-color)}.sync-status-section:last-child{border-bottom:none}.sync-status-section.error{border-bottom:none}.sync-status-section.warning{background:#f59e0b1a;margin:4px -8px 0;padding:8px;border-radius:4px;border-bottom:none}.sync-status-label{color:var(--text-secondary);font-weight:500}.sync-status-value{display:flex;align-items:center;gap:6px;color:var(--text-primary)}.sync-status-value.connected{color:#10b981}.sync-status-value.disconnected{color:#6b7280}.sync-status-value.error-message{color:#ef4444;font-size:12px;max-width:150px;text-align:center;word-wrap:break-word;padding:2px;border-left:1px solid;border-radius:0}.status-icon{font-size:14px;font-weight:700}.sync-status-version{text-align:center;padding-top:12px;color:var(--text-tertiary);font-size:11px;font-weight:400;opacity:.6}@media(max-width:768px){.sync-text{display:none}.sync-indicator{padding:6px 10px;min-width:44px}.sync-detail-tooltip{right:auto;left:50%;transform:translate(-50%)}}.quick-search-overlay{position:fixed;top:60px;left:50%;transform:translate(-50%);z-index:1000;animation:fadeIn .2s ease-out}@keyframes fadeIn{0%{opacity:0;transform:translate(-50%) translateY(-10px)}to{opacity:1;transform:translate(-50%) translateY(0)}}.quick-search-dropdown{background:var(--bg-primary);border:2px solid var(--border-color);border-radius:12px;box-shadow:0 10px 40px var(--shadow-lg),0 4px 12px var(--shadow-md);width:700px;max-height:600px;margin:20px 0;display:flex;flex-direction:column}.quick-search-input-container{padding:20px;border-bottom:2px solid var(--border-color)}.quick-search-input{width:100%;padding:14px 16px;border:2px solid var(--border-color);border-radius:8px;background:var(--bg-secondary);color:var(--text-primary);font-size:16px;font-weight:500;outline:none;transition:all .2s}.quick-search-input::placeholder{color:var(--text-secondary);opacity:.7}.quick-search-input:focus{border-color:var(--btn-primary-bg);box-shadow:0 0 0 3px var(--btn-primary-shadow)}.quick-search-results{flex:1;overflow-y:auto;max-height:500px}.quick-search-list{list-style:none;padding:0;margin:0}.quick-search-item{display:flex;align-items:center;justify-content:space-between;padding:10px 20px;cursor:pointer;border-bottom:1px solid var(--border-color);transition:all .15s;gap:16px}.quick-search-item:hover{background-color:var(--bg-hover)}.quick-search-item.selected{background-color:var(--bg-tertiary);border-left:2px solid var(--accent-primary);padding-left:18px}.quick-search-item:last-child{border-bottom:none}.quick-search-item-content{flex:1;min-width:0}.quick-search-item-name{font-weight:600;font-size:16px;color:var(--text-primary);margin-bottom:6px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.quick-search-item-details{display:flex;gap:16px;font-size:14px;color:var(--text-secondary)}.quick-search-item-details span{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.quick-search-item-arrow{background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:6px;padding:6px;cursor:pointer;transition:all .15s cubic-bezier(.4,0,.2,1);flex-shrink:0;display:flex;align-items:center;justify-content:center}.quick-search-item-arrow:hover{background:var(--accent-primary);border-color:var(--accent-primary)}.quick-search-item-arrow:hover .quick-search-arrow-icon{color:#fff}.quick-search-arrow-icon{width:20px;height:20px;color:var(--text-primary);stroke-width:2}.quick-search-loading,.quick-search-empty,.quick-search-hint{padding:24px 16px;text-align:center;color:var(--text-secondary);font-size:14px}.quick-search-hint{padding:16px;font-style:italic;color:var(--text-secondary);opacity:.7}@media(max-width:1023px){.quick-search-overlay{top:56px;left:16px;right:16px;transform:none}@keyframes fadeIn{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.quick-search-dropdown{width:auto;margin:10px 0;max-height:calc(100vh - 76px)}.quick-search-results{max-height:calc(100vh - 160px)}}@media(max-width:480px){.quick-search-overlay{left:12px;right:12px}.quick-search-dropdown{margin:8px 0}.quick-search-input-container{padding:16px}.quick-search-input{padding:12px 14px;font-size:15px}.quick-search-item{padding:12px 16px}.quick-search-item:hover,.quick-search-item.selected{padding-left:13px}.quick-search-item-details{flex-direction:column;gap:2px}}.header{display:flex;justify-content:space-between;align-items:center;padding:15px 30px;background:var(--bg-secondary);border-bottom:1px solid var(--border-color);box-shadow:0 2px 4px var(--shadow-sm);height:60px;position:sticky;top:0;z-index:1001;padding-top:calc(15px + env(safe-area-inset-top));padding-left:max(30px,env(safe-area-inset-left));padding-right:max(30px,env(safe-area-inset-right))}.header-left{display:flex;align-items:center;gap:15px}.hamburger-btn{display:none;background:none;border:none;font-size:24px;color:var(--text-primary);cursor:pointer;padding:8px;line-height:1;transition:opacity .2s}.hamburger-btn:hover{opacity:.7}.header-left .logo{font-size:24px;font-weight:700;color:var(--btn-primary-bg);margin:0;cursor:pointer;transition:opacity .2s}.header-left .logo:hover{opacity:.8}.header-right{display:flex;align-items:center;gap:15px}.username{color:var(--text-secondary);font-size:14px}.btn-icon-svg{width:18px;height:18px;display:inline-block;vertical-align:text-bottom;margin-right:2px}.server-unavailable-icon{display:inline-flex;align-items:center}@media(max-width:1023px){.header{padding:12px 16px;height:56px;padding-top:calc(12px + env(safe-area-inset-top));padding-left:max(16px,env(safe-area-inset-left));padding-right:max(16px,env(safe-area-inset-right))}.hamburger-btn{display:block}.header-left .logo{font-size:20px}.header-left{gap:12px}.header-right{gap:10px}.header-right .btn-primary{padding:10px 16px;font-size:14px;min-height:40px}.username{display:none}.header-right .btn-secondary{padding:10px 14px;font-size:14px;min-height:40px}.btn-icon{min-height:40px;min-width:40px}}@media(max-width:480px){.header{padding:10px 12px}.header-right .btn-primary .btn-text,.header-right .btn-secondary .btn-text{display:none}.header-right .btn-secondary{font-size:13px}.header-right{gap:8px}}.bottom-tab-bar{position:fixed;bottom:0;left:0;right:0;display:flex;background-color:var(--bg-secondary);border-top:1px solid var(--border-color);padding-bottom:env(safe-area-inset-bottom);padding-left:env(safe-area-inset-left);padding-right:env(safe-area-inset-right);z-index:1200;box-shadow:0 -2px 10px #0000000d}.tab-button{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;padding:8px 12px;background:none;border:none;cursor:pointer;color:var(--text-secondary);transition:color .2s ease;min-height:60px;font-size:12px;font-weight:500}.tab-button:hover{color:var(--text-primary);background-color:var(--bg-tertiary)}.tab-button.active{color:var(--accent-primary)}.tab-button.active .tab-icon svg{stroke-width:2.5}.tab-icon{display:flex;align-items:center;justify-content:center;width:28px;height:28px}.tab-icon svg{width:24px;height:24px}.tab-label{font-size:11px;font-weight:500;letter-spacing:.01em}.tab-count{background:var(--bg-tertiary);color:var(--text-secondary);padding:2px 6px;border-radius:10px;font-size:10px;font-weight:600;min-width:20px;text-align:center;margin-top:-2px}.tab-button.active .tab-count{background:var(--accent-primary);color:#fff}@media(min-width:1024px){.bottom-tab-bar{display:none}}@media(max-width:1023px){.main-content{padding-bottom:80px}}.app-layout{display:flex;height:calc(100vh - 60px);overflow:hidden;position:relative}@media(max-width:1023px){.app-layout{height:calc(100vh - 56px)}}@media(min-width:1024px){.app-layout{height:calc(100vh - 60px)}}.onboarding-container{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--bg-primary);padding:24px;position:relative}.onboarding-close{position:fixed;top:24px;right:24px;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:50%;width:40px;height:40px;display:flex;align-items:center;justify-content:center;cursor:pointer;color:var(--text-secondary);transition:all .15s;z-index:100;box-shadow:0 2px 8px #0000001a}.onboarding-close:hover{background:var(--hover-bg);color:var(--text-primary);transform:scale(1.05)}.onboarding-close:active{transform:scale(.95)}.onboarding-card{max-width:600px;width:100%;background:var(--bg-secondary);border-radius:10px;box-shadow:0 10px 25px #0003;padding:40px;border:1px solid var(--border-color)}.onboarding-card-narrow{max-width:400px}.onboarding-icon-wrapper{display:flex;justify-content:center;margin-bottom:24px}.onboarding-icon-bg{padding:16px;background:#3b82f61a;border-radius:50%}.onboarding-icon{width:64px;height:64px;color:var(--btn-primary-bg)}.onboarding-title{font-size:32px;font-weight:700;color:var(--btn-primary-bg);margin-bottom:10px;text-align:center}.onboarding-subtitle{font-size:14px;color:var(--text-secondary);margin-bottom:30px;text-align:center}.onboarding-features{display:flex;flex-direction:column;gap:12px;margin-bottom:30px}.onboarding-feature{display:flex;align-items:flex-start}.onboarding-feature-number{flex-shrink:0;width:24px;height:24px;background:#3b82f61a;border-radius:50%;display:flex;align-items:center;justify-content:center;margin-right:12px;margin-top:2px}.onboarding-feature-number span{color:var(--btn-primary-bg);font-size:12px;font-weight:600}.onboarding-feature p{color:var(--text-secondary);margin:0;font-size:14px}.onboarding-button{width:100%;background:var(--btn-primary-bg);color:var(--btn-primary-text);font-weight:500;padding:10px 20px;border-radius:6px;border:none;cursor:pointer;font-size:14px;transition:all .15s cubic-bezier(.4,0,.2,1);font-family:inherit;touch-action:manipulation;-webkit-tap-highlight-color:transparent;-webkit-user-select:none;user-select:none}.onboarding-button:hover{background:var(--btn-primary-hover);transform:translateY(-1px)}.onboarding-button:active{background:var(--btn-primary-active);transform:scale(.98)}.onboarding-button:disabled{opacity:.5;cursor:not-allowed}.onboarding-button-secondary{background:var(--bg-tertiary);color:var(--text-primary);border:1px solid var(--border-color)}.onboarding-button-secondary:hover{background:var(--bg-secondary);transform:translateY(0)}.onboarding-button-secondary:active{transform:scale(.98)}.onboarding-privacy{margin-top:20px;text-align:center;font-size:14px;color:var(--text-tertiary)}.contact-list{max-height:256px;overflow-y:auto;margin-bottom:20px;display:flex;flex-direction:column;gap:8px}.contact-item{display:flex;align-items:center;justify-content:space-between;background:var(--bg-tertiary);padding:10px 12px;border-radius:6px;border:1px solid var(--border-light)}.contact-item span{color:var(--text-primary);font-size:14px}.contact-remove{background:none;border:none;color:var(--text-tertiary);cursor:pointer;padding:4px;transition:color .15s}.contact-remove:hover{color:var(--btn-danger-bg)}.contact-input-wrapper{display:flex;gap:8px;margin-bottom:20px}.contact-input-wrapper input{flex:1;padding:10px;border:1px solid var(--input-border);border-radius:6px;font-size:14px;background:var(--input-bg);color:var(--text-primary);font-family:inherit;transition:border-color .2s}.contact-input-wrapper input:focus{outline:none;border-color:var(--accent-primary)}.contact-add-button{padding:10px 16px;background:#3b82f61a;color:var(--btn-primary-bg);border:none;border-radius:6px;cursor:pointer;transition:background .15s}.contact-add-button:hover{background:#3b82f633}.contact-add-button:disabled{opacity:.5;cursor:not-allowed}.contact-count{text-align:center;margin-bottom:20px;color:var(--text-secondary);font-size:14px}.button-group{display:flex;gap:12px}.button-group button{flex:1}.progress-bar-wrapper{margin-bottom:20px}.progress-bar-bg{background:var(--bg-tertiary);border-radius:999px;height:8px;overflow:hidden;border:1px solid var(--border-light)}.progress-bar-fill{background:var(--btn-primary-bg);height:100%;transition:width .3s ease;border-radius:999px}.progress-text{text-align:center;margin-top:8px;font-size:14px;color:var(--text-tertiary)}.swipe-container{min-height:100vh;display:flex;flex-direction:column;background:var(--bg-primary);padding:24px}.swipe-header{max-width:800px;width:100%;margin:0 auto 24px}.swipe-back-button{background:none;border:none;color:var(--text-secondary);cursor:pointer;font-size:14px;margin-bottom:16px;padding:8px;transition:color .15s;font-family:inherit}.swipe-back-button:hover{color:var(--text-primary)}.swipe-title{font-size:28px;font-weight:700;color:var(--text-primary);margin-bottom:8px}.swipe-subtitle{color:var(--text-secondary);margin-bottom:16px;font-size:14px}.swipe-card-area{flex:1;display:flex;align-items:center;justify-content:center;margin-bottom:24px}.swipe-card{position:relative;width:100%;max-width:400px;background:var(--bg-secondary);border-radius:10px;box-shadow:0 10px 25px #0003;border:1px solid var(--border-color);padding:32px 24px;display:flex;flex-direction:column;align-items:center;justify-content:center;-webkit-user-select:none;user-select:none;transition:transform .3s ease}.swipe-card:active{cursor:grabbing}.swipe-card.swipe-up{transform:translateY(-100vh) rotate(-20deg)}.swipe-card.swipe-right{transform:translate(100vw) rotate(20deg)}.swipe-card.swipe-left{transform:translate(-100vw) rotate(-20deg)}.swipe-card.swipe-down{transform:translateY(100vh) rotate(20deg)}.contact-avatar{width:64px;height:64px;background:linear-gradient(135deg,var(--accent-primary) 0%,var(--accent-secondary) 100%);border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;font-size:28px;font-weight:700;margin-bottom:16px}.contact-name{font-size:22px;font-weight:700;color:var(--text-primary);margin-bottom:6px;text-align:center}.swipe-instruction{color:var(--text-secondary);margin-bottom:20px;text-align:center;font-size:13px}.swipe-directions{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-top:30px;width:100%}.swipe-direction{display:flex;flex-direction:column;align-items:center;font-size:11px;color:var(--text-tertiary)}.swipe-direction svg{width:18px;height:18px;margin-bottom:3px}.swipe-card-controls{width:100%;display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-top:4px}.tier-button{padding:12px 16px;border:none;border-radius:6px;color:#fff;font-weight:500;cursor:pointer;display:flex;flex-direction:column;align-items:center;gap:4px;transition:all .15s cubic-bezier(.4,0,.2,1);font-family:inherit;font-size:13px}.tier-button:hover{transform:translateY(-1px);box-shadow:0 4px 12px #0003}.tier-button:active{transform:scale(.97)}.tier-button svg{width:18px;height:18px}.tier-button-info{font-size:10px;opacity:.85}.tier-weekly{background:#3b82f6}.tier-monthly{background:#8b5cf6}.tier-quarterly{background:#06b6d4}.tier-annual{background:#6b7280}.spinner{display:inline-block;width:64px;height:64px;border:4px solid var(--border-color);border-top-color:var(--btn-primary-bg);border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.icon-sm{width:20px;height:20px}.icon-md{width:24px;height:24px}.icon-lg{width:48px;height:48px}.icon-xl{width:80px;height:80px}.icon-success{color:var(--status-good)}.icon-error{color:var(--status-urgent)}.modal-overlay{position:fixed;inset:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px}.modal-content{background:var(--bg-primary);border-radius:12px;padding:32px;width:100%;max-width:600px;max-height:90vh;overflow-y:auto;box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a}.icon-button{background:none;border:none;cursor:pointer;color:var(--text-secondary);transition:color .2s ease}.icon-button:hover{color:var(--text-primary)}#root{width:100%;height:100vh;margin:0;padding:0;overflow-x:hidden}.app{width:100%;height:100vh;display:flex;flex-direction:column;overflow-x:hidden}
