@import"https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800&family=Outfit:wght@400;500;600;700;800&display=swap";*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--brand: #6161ff;--brand-hover: #4f4fe8;--brand-light: #ebebff;--brand-mid: #c9c9ff;--bg: #f5f6f8;--surface: #ffffff;--surface2: #f5f6f8;--surface3: #ecedf0;--border: #e6e9ef;--border2: #d0d4de;--text: #1f1f3d;--text2: #676879;--text3: #9699a6;--green: #00c875;--green-light: #e6faf3;--red: #e44258;--red-light: #fdedf0;--orange: #fdab3d;--orange-light: #fff5e6;--blue: #0086c0;--blue-light: #e5f4fb;--radius: 6px;--radius2: 8px;--radius3: 4px;--shadow: 0 1px 4px rgba(0, 0, 0, .08), 0 4px 16px rgba(0, 0, 0, .04);--shadow2: 0 2px 8px rgba(0, 0, 0, .1), 0 8px 24px rgba(0, 0, 0, .06);--font-body: "Inter", sans-serif;--font-display: "Outfit", sans-serif;--sidebar-w: 224px;--transition: .14s ease}[data-theme=dark-gray]{--bg: #212121;--surface: #2d2d2d;--surface2: #212121;--surface3: #3d3d3d;--border: #3d3d3d;--border2: #4d4d4d;--text: #eeeeee;--text2: #bbbbbb;--text3: #888888;--brand: #818cf8;--brand-hover: #a5b4fc;--brand-light: rgba(129, 140, 248, .18);--shadow: 0 4px 12px rgba(0, 0, 0, .3)}[data-theme=dark-deep]{--bg: #0f172a;--surface: #1e293b;--surface2: #0f172a;--surface3: #334155;--border: #334155;--border2: #475569;--text: #f8fafc;--text2: #94a3b8;--text3: #64748b;--brand: #60a5fa;--brand-hover: #93c5fd;--brand-light: rgba(96, 165, 250, .22);--shadow: 0 4px 20px rgba(0, 0, 0, .5)}[data-theme=warm]{--bg: #fdf8f0;--surface: #fffcf7;--surface2: #f6efe3;--surface3: #ecddd0;--border: #e4d5c0;--border2: #d2bfa4;--text: #2d1f0e;--text2: #7a6040;--text3: #a89070;--brand: #6161ff;--brand-hover: #4f4fe8;--brand-light: #ebebff;--brand-mid: #c9c9ff;--shadow: 0 1px 4px rgba(80, 40, 0, .08), 0 4px 16px rgba(80, 40, 0, .04)}html,body,#root{height:100%;background:var(--bg);color:var(--text);font-family:var(--font-body);font-size:16px;-webkit-font-smoothing:antialiased}a{color:var(--brand);text-decoration:none}a:hover{text-decoration:underline}button{cursor:pointer;font-family:var(--font-body)}input,textarea,select{font-family:var(--font-body)}h1,h2,h3,h4,h5,h6,.logo-text,.panel-header h2{font-family:var(--font-display)}.theme-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:6px;margin-top:8px}.theme-preview-btn{display:flex;flex-direction:column;gap:6px;padding:10px 12px;border-radius:var(--radius2);border:2px solid transparent;cursor:pointer;transition:all var(--transition);text-align:left;position:relative;overflow:hidden}.theme-preview-btn:hover{transform:translateY(-2px);box-shadow:var(--shadow)}.theme-preview-name{font-weight:600;font-size:11px;font-family:var(--font-display)}.theme-preview-dot{width:10px;height:10px;border-radius:50%;background:var(--btn-accent)}.theme-preview-light{--btn-bg: #ffffff;--btn-text: #1f1f3d;--btn-accent: #6161ff;--btn-border: #e6e9ef}.theme-preview-gray{--btn-bg: #212121;--btn-text: #eeeeee;--btn-accent: #6161ff;--btn-border: #3d3d3d}.theme-preview-deep{--btn-bg: #0f172a;--btn-text: #f8fafc;--btn-accent: #38bdf8;--btn-border: #334155}.theme-preview-warm{--btn-bg: #fffcf7;--btn-text: #2d1f0e;--btn-accent: #6161ff;--btn-border: #e4d5c0}.theme-preview-btn{background:var(--btn-bg);color:var(--btn-text);border-color:var(--btn-border)}.theme-preview-btn.active{border-color:#6161ff;box-shadow:0 0 0 2px #6161ff}.dashboard{display:flex;height:100vh;overflow:hidden}.sidebar{width:var(--sidebar-w);flex-shrink:0;background:var(--surface);border-right:1px solid var(--border);display:flex;flex-direction:column;overflow:hidden}.sidebar-top{padding:20px 16px 14px;border-bottom:1px solid var(--border)}.sidebar-logo{display:flex;align-items:center;gap:9px;margin-bottom:6px}.logo-icon{width:28px;height:28px;background:var(--brand);border-radius:8px;display:flex;align-items:center;justify-content:center;color:#fff;font-size:14px;flex-shrink:0}.logo-text{font-weight:700;font-size:15px;color:var(--text);letter-spacing:-.01em}.sidebar-date-row{display:flex;align-items:center;justify-content:space-between;gap:8px}.sidebar-date{font-size:11px;color:var(--text3)}.sidebar-inbox-btn{position:relative;background:none;border:none;cursor:pointer;width:36px;height:36px;border-radius:8px;display:flex;align-items:center;justify-content:center;transition:background var(--transition);flex-shrink:0;color:var(--text2)}.sidebar-inbox-btn:hover{background:var(--surface3);color:var(--text)}.sidebar-inbox-btn.active{background:var(--brand-light);color:var(--brand)}.sidebar-inbox-badge{position:absolute;top:-4px;right:-4px;background:var(--brand);color:#fff;border-radius:8px;padding:1px 4px;font-size:9px;font-weight:700;min-width:14px;text-align:center;line-height:1.5;pointer-events:none}.sidebar-nav{flex:1;padding:10px 8px;display:flex;flex-direction:column;gap:2px;overflow-y:auto}.nav-item{display:flex;align-items:center;gap:10px;padding:9px 12px;border-radius:var(--radius3);border:none;background:transparent;color:var(--text2);font-size:13.5px;font-weight:500;width:100%;text-align:left;transition:background var(--transition),color var(--transition);position:relative}.nav-item:hover{background:var(--surface2);color:var(--text)}.nav-item.active{background:var(--brand-light);color:var(--brand);font-weight:600}.nav-icon{font-size:16px;flex-shrink:0}.nav-label{flex:1}.nav-badge{background:var(--brand);color:#fff;font-size:10px;font-weight:700;padding:1px 6px;border-radius:999px;min-width:18px;text-align:center}.sidebar-bottom{padding:12px 16px;border-top:1px solid var(--border);display:flex;flex-direction:column;gap:10px}.sidebar-user{display:flex;align-items:center;gap:10px;padding:8px 4px;border-bottom:1px solid var(--border);margin-bottom:4px}.sidebar-settings-btn{margin-left:auto;background:none;border:none;cursor:pointer;width:30px;height:30px;border-radius:8px;display:flex;align-items:center;justify-content:center;color:var(--text3);transition:background var(--transition),color var(--transition);flex-shrink:0}.sidebar-settings-btn:hover{background:var(--surface3);color:var(--text)}.sidebar-settings-btn.active{background:var(--brand-light);color:var(--brand)}.sidebar-user-info{display:flex;flex-direction:column;gap:1px;min-width:0}.sidebar-user-name{font-size:13px;font-weight:600;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sidebar-user-role{font-size:11px;color:var(--text3);text-transform:capitalize}.btn-logout{background:transparent;border:1px solid var(--border2);color:var(--text2);border-radius:var(--radius3);padding:7px 12px;font-size:12.5px;font-weight:500;transition:all var(--transition);width:100%}.btn-logout:hover{border-color:var(--red);color:var(--red);background:var(--red-light)}.main-content{flex:1;overflow-y:auto;padding:28px 32px;background:var(--bg)}.main-content.full-bleed{padding:0;overflow:hidden}.panel{width:100%}.panel-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px;gap:12px}.panel-header h2{font-size:22px;font-weight:700;letter-spacing:-.02em;color:var(--text)}.panel-actions{display:flex;align-items:center;gap:10px}.btn-primary{background:var(--brand);color:#fff;border:none;border-radius:var(--radius3);padding:8px 18px;font-size:13.5px;font-weight:600;transition:background var(--transition),box-shadow var(--transition);white-space:nowrap}.btn-primary:hover{background:var(--brand-hover);box-shadow:0 2px 8px rgba(97,97,255,.3)}.btn-primary:disabled{opacity:.5;cursor:not-allowed;box-shadow:none}.btn-secondary{background:var(--surface);color:var(--text2);border:1px solid var(--border2);border-radius:var(--radius3);padding:7px 14px;font-size:13px;font-weight:500;transition:all var(--transition)}.btn-secondary:hover{color:var(--text);border-color:var(--text3);background:var(--surface2)}.btn-save{background:var(--surface);color:var(--text2);border:1px solid var(--border2);border-radius:var(--radius3);padding:7px 14px;font-size:12.5px;font-weight:500;transition:all var(--transition);white-space:nowrap}.btn-save:hover{background:var(--brand);color:#fff;border-color:var(--brand)}.btn-save:disabled{opacity:.4}.btn-saved{background:var(--green-light);color:var(--green);border-color:var(--green)}.btn-icon{width:30px;height:30px;border:none;border-radius:var(--radius3);font-size:13px;display:flex;align-items:center;justify-content:center;transition:all var(--transition);flex-shrink:0;background:transparent;color:var(--text3)}.btn-done:hover{background:var(--green-light);color:var(--green)}.btn-edit:hover{background:var(--brand-light);color:var(--brand)}.btn-delete:hover{background:var(--red-light);color:var(--red)}.btn-comment:hover{background:var(--blue-light);color:var(--blue)}.btn-hold:hover{background:var(--orange-light);color:var(--orange)}.add-form{display:flex;flex-direction:column;gap:10px;margin-bottom:20px;padding:16px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius2);box-shadow:var(--shadow)}.form-row{display:flex;gap:10px}.form-input{background:var(--surface2);border:1.5px solid var(--border);border-radius:var(--radius3);color:var(--text);padding:9px 12px;font-size:13.5px;width:100%;outline:none;transition:border-color var(--transition),box-shadow var(--transition)}.form-input:focus{border-color:var(--brand);box-shadow:0 0 0 3px rgba(97,97,255,.12);background:var(--surface)}.form-input::placeholder{color:var(--text3)}.form-textarea{resize:vertical;min-height:80px;line-height:1.5}.filter-select{background:var(--surface);border:1.5px solid var(--border);border-radius:var(--radius3);color:var(--text2);padding:7px 10px;font-size:13px;font-family:var(--font);outline:none;cursor:pointer}.search-input{background:var(--surface);border:1.5px solid var(--border);border-radius:var(--radius3);color:var(--text);padding:8px 12px;font-size:13px;outline:none;width:220px;transition:border-color var(--transition),box-shadow var(--transition)}.search-input:focus{border-color:var(--brand);box-shadow:0 0 0 3px rgba(97,97,255,.12)}.search-input::placeholder{color:var(--text3)}.edit-actions{display:flex;gap:8px}.item-list{list-style:none;display:flex;flex-direction:column;gap:6px}.item{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:13px 16px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);transition:box-shadow var(--transition),border-color var(--transition)}.item:hover{box-shadow:var(--shadow);border-color:var(--border2)}.item.overdue{border-left:3px solid var(--orange);background:#fffdf8}.item.done{opacity:.5}.item-main{display:flex;align-items:flex-start;gap:10px;flex:1;min-width:0}.item-body{display:flex;flex-direction:column;gap:4px;min-width:0;width:100%}.item-title{font-size:14px;font-weight:500;color:var(--text);word-break:break-word;line-height:1.4}.item.done .item-title{text-decoration:line-through;color:var(--text3)}.item-meta{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.item-due{font-size:12px;color:var(--text3)}.overdue-text{color:var(--orange)!important;font-weight:600}.item-url{font-size:12px;color:var(--brand);font-weight:500}.item-buttons{display:flex;gap:4px;flex-shrink:0;opacity:0;transition:opacity var(--transition)}.item:hover .item-buttons{opacity:1}.tag{font-size:11px;background:var(--brand-light);color:var(--brand);border:1px solid var(--brand-mid);padding:2px 8px;border-radius:999px;font-weight:500;white-space:nowrap}.tag-admin{background:rgba(253,171,61,.15);color:#b06800;border-color:rgba(253,171,61,.4)}.task-item{flex-direction:row!important;align-items:center!important;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius2);padding:14px 16px;cursor:pointer;transition:all var(--transition);margin-bottom:8px}.task-item:hover{border-color:var(--brand);transform:translateY(-1px);box-shadow:var(--shadow)}.task-item.on_hold,.item.on_hold{opacity:.65;filter:grayscale(.8)}.task-item.done{opacity:.6;filter:grayscale(1)}.task-item.overdue{border-left:4px solid var(--red)}.task-title-row{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.item-main{flex:1;min-width:0}.task-person-chip{display:inline-flex;align-items:center;gap:4px;font-size:11px;color:var(--text2);background:var(--surface2);border:1px solid var(--border);border-radius:999px;padding:2px 7px 2px 3px;font-weight:500}.task-person-assigned{background:var(--brand-light);border-color:var(--brand-mid);color:var(--brand)}.comment-count{font-size:11px;color:var(--blue);cursor:pointer;font-weight:500;padding:2px 6px;border-radius:999px;background:var(--blue-light)}.task-summary-header{padding:24px 24px 16px;border-bottom:1px solid var(--border);background:var(--surface2);display:flex;flex-direction:column;align-items:center;text-align:center}.priority-indicator{width:12px;height:12px;border-radius:50%;margin-bottom:8px}.task-modal-body{padding:24px;display:flex;flex-direction:column;gap:16px;overflow-y:auto;-webkit-overflow-scrolling:touch;max-height:60vh}.task-comments{width:100%;margin-top:12px;padding-top:12px;border-top:1px solid var(--border)}.comments-list{display:flex;flex-direction:column;gap:10px;margin-bottom:12px}.comment{display:flex;align-items:flex-start;gap:10px}.comment-body{flex:1;background:var(--surface2);border-radius:var(--radius);padding:10px 12px}.comment-author{font-size:12px;font-weight:600;color:var(--text);margin-right:8px}.comment-time{font-size:11px;color:var(--text3)}.comment-text{font-size:13px;color:var(--text);margin-top:4px;line-height:1.5}.comment-edited{font-size:10.5px;color:var(--text3);font-style:italic;margin-left:6px}.comment-edit-btn{background:none;border:none;padding:2px 6px;font-size:11px;color:var(--text3);cursor:pointer;border-radius:var(--radius3);margin-left:4px;opacity:0;transition:opacity var(--transition),color var(--transition)}.comment:hover .comment-edit-btn{opacity:1}.comment-edit-btn:hover{color:var(--brand);background:var(--brand-light)}.comment-edit-area{display:flex;flex-direction:column;gap:6px;margin-top:4px}.comment-edit-area textarea{width:100%;font-size:13px;font-family:var(--font-body);padding:6px 8px;border-radius:var(--radius3);border:1px solid var(--border2);background:var(--surface);color:var(--text);resize:vertical;min-height:50px}.comment-edit-actions{display:flex;gap:6px;justify-content:flex-end}.comment-empty{font-size:12px;color:var(--text3);text-align:center;padding:8px 0}.comment-input-row{display:flex;align-items:center;gap:8px}.comment-input{flex:1}.comment-send{padding:8px 14px;font-size:12px}.note-item{align-items:flex-start}.note-body{font-size:13.5px;color:var(--text);line-height:1.6;white-space:pre-wrap;word-break:break-word}.note-ts{font-size:11px;color:var(--text3)}.home-greeting{margin-bottom:24px}.home-greeting h1{font-size:26px;font-weight:800;letter-spacing:-.02em;color:var(--text);margin-bottom:4px}.home-greeting p{font-size:13px;color:var(--text3)}.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin-bottom:28px}.stat-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius2);padding:16px;display:flex;align-items:center;gap:14px;transition:box-shadow var(--transition)}.stat-card:hover{box-shadow:var(--shadow)}.stat-icon{width:44px;height:44px;border-radius:var(--radius);display:flex;align-items:center;justify-content:center;font-size:20px;flex-shrink:0}.stat-number{font-size:28px;font-weight:800;line-height:1;color:var(--text)}.stat-label{font-size:12px;color:var(--text3);margin-top:2px;font-weight:500}.home-section{margin-bottom:28px}.home-section-title{font-size:13px;font-weight:700;color:var(--text2);text-transform:uppercase;letter-spacing:.06em;margin-bottom:12px}.quick-actions{display:flex;gap:10px;flex-wrap:wrap}.quick-action-btn{display:flex;align-items:center;gap:8px;background:var(--surface);border:1.5px solid var(--border);border-radius:var(--radius2);padding:10px 16px;font-size:13.5px;font-weight:500;color:var(--text2);transition:all var(--transition)}.quick-action-btn:hover{border-color:var(--brand);color:var(--brand);background:var(--brand-light)}.activity-list{list-style:none;display:flex;flex-direction:column;gap:8px}.activity-item{display:flex;align-items:center;gap:10px;padding:10px 14px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius)}.activity-body{flex:1;display:flex;flex-direction:column;gap:2px}.activity-text{font-size:13px;color:var(--text)}.activity-time{font-size:11px;color:var(--text3)}.activity-icon{font-size:14px}.search-bar{margin-bottom:20px}.search-big{font-size:15px;padding:12px 16px}.search-section{margin-bottom:20px}.search-section-title{font-size:12px;font-weight:700;color:var(--text3);text-transform:uppercase;letter-spacing:.06em;margin-bottom:8px}.settings-list{display:flex;flex-direction:column;gap:6px}.setting-row{display:flex;gap:16px;padding:10px 14px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);align-items:flex-start;transition:box-shadow var(--transition)}.setting-row:hover{box-shadow:var(--shadow)}.setting-info{width:220px;flex-shrink:0;display:flex;flex-direction:column;gap:4px}.setting-key{font-size:13.5px;font-weight:600;color:var(--text)}.setting-desc{font-size:11.5px;color:var(--text3);line-height:1.4}.setting-edit{flex:1;display:flex;gap:10px;align-items:flex-start}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--bg);padding:24px}.login-card{width:100%;max-width:400px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius2);padding:44px 40px;box-shadow:var(--shadow2)}.login-logo{display:flex;align-items:center;gap:12px;margin-bottom:8px}.login-logo .logo-icon{width:36px;height:36px;font-size:18px;border-radius:10px}.login-logo .logo-text{font-size:24px;font-weight:800;letter-spacing:-.02em}.login-sub{color:var(--text3);font-size:13px;margin-bottom:32px}.login-form{display:flex;flex-direction:column;gap:16px}.field{display:flex;flex-direction:column;gap:6px}.field label{font-size:12.5px;font-weight:600;color:var(--text2);letter-spacing:.02em}.field input{background:var(--surface2);border:1.5px solid var(--border);border-radius:var(--radius3);color:var(--text);padding:11px 14px;font-size:14px;outline:none;width:100%;transition:border-color var(--transition),box-shadow var(--transition);font-family:var(--font)}.field input:focus{border-color:var(--brand);box-shadow:0 0 0 3px rgba(97,97,255,.12);background:var(--surface)}.field input::placeholder{color:var(--text3)}.login-error{background:var(--red-light);border:1px solid rgba(228,66,88,.25);color:var(--red);border-radius:var(--radius3);padding:10px 14px;font-size:13px;font-weight:500}.btn-login{background:var(--brand);color:#fff;border:none;border-radius:var(--radius3);padding:12px;font-size:14px;font-weight:700;font-family:var(--font);width:100%;transition:background var(--transition),box-shadow var(--transition);margin-top:4px}.btn-login:hover{background:var(--brand-hover);box-shadow:0 4px 12px rgba(97,97,255,.35)}.btn-login:disabled{opacity:.5;cursor:not-allowed;box-shadow:none}.btn-link{background:none;border:none;color:var(--text3);font-size:13px;cursor:pointer;padding:0;text-decoration:underline;width:100%;text-align:center}.btn-link:hover{color:var(--text)}.dp-wrapper{position:relative;width:100%}.dp-trigger{display:flex;align-items:center;justify-content:space-between;cursor:pointer;text-align:left}.dp-placeholder{color:var(--text3)}.dp-icon{font-size:14px;flex-shrink:0;margin-left:8px}.dp-popup{position:absolute;top:calc(100% + 6px);left:0;z-index:999;background:var(--surface);border:1.5px solid var(--border2);border-radius:var(--radius2);box-shadow:var(--shadow2);padding:12px;min-width:240px;max-width:calc(100vw - 16px);max-height:85vh;overflow-y:auto;overflow-x:hidden;animation:dp-in .12s ease}@media (max-width: 600px){.dp-popup{position:fixed!important;top:auto!important;bottom:0!important;left:0!important;width:100%!important;max-width:100vw!important;border-radius:24px 24px 0 0;box-shadow:0 -10px 40px rgba(0,0,0,.2);min-width:0;padding:24px 20px;z-index:999999!important;transform:none;animation:dp-slide-up .2s cubic-bezier(.1,.9,.2,1)}@keyframes dp-slide-up{0%{opacity:0;transform:translateY(100%)}to{opacity:1;transform:translateY(0)}}}@keyframes dp-in{0%{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:translateY(0)}}.dp-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px}.dp-month{font-size:13px;font-weight:700;color:var(--text)}.dp-nav{background:none;border:none;font-size:15px;color:var(--text2);cursor:pointer;padding:2px 6px;border-radius:var(--radius3);transition:background var(--transition);line-height:1}.dp-nav:hover{background:var(--surface2);color:var(--text)}.dp-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:1px;margin-bottom:8px}.dp-day-name{text-align:center;font-size:10px;font-weight:600;color:var(--text3);padding:2px 0;text-transform:uppercase}.dp-day{aspect-ratio:1;border:none;border-radius:6px;background:none;cursor:pointer;font-size:12px;font-weight:500;color:var(--text);transition:background var(--transition),color var(--transition);display:flex;align-items:center;justify-content:center;font-family:var(--font)}.dp-day:hover{background:var(--brand-light);color:var(--brand)}.dp-other-month{color:var(--text3);opacity:.4}.dp-today{border:1.5px solid var(--brand);color:var(--brand);font-weight:700}.dp-selected{background:var(--brand)!important;color:#fff!important;font-weight:700}.dp-clock{border-top:1px solid var(--border);padding-top:8px;margin-bottom:8px}.dp-clock-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px}.dp-clock-label{font-size:11px;font-weight:600;color:var(--text2)}.dp-clock-display{display:flex;align-items:center;gap:2px;background:var(--surface2);border-radius:var(--radius3);padding:3px}.dp-clock-segment{background:none;border:none;font-size:13px;font-weight:700;font-family:var(--font);color:var(--text3);padding:2px 6px;border-radius:4px;cursor:pointer;transition:all .12s ease;min-width:28px;text-align:center}.dp-clock-segment.active{background:var(--brand);color:#fff;box-shadow:0 2px 6px rgba(97,97,255,.3)}.dp-clock-segment:hover:not(.active){background:var(--surface3);color:var(--text)}.dp-clock-sep{font-size:13px;font-weight:700;color:var(--text3)}.dp-clock-ampm-seg{font-size:11px;letter-spacing:.04em;margin-left:2px}.dp-clock-grid{display:grid;gap:2px;animation:dp-in .1s ease}.dp-clock-hours,.dp-clock-minutes{grid-template-columns:repeat(4,1fr)}.dp-clock-ampm-grid{grid-template-columns:repeat(2,1fr);max-width:200px;margin:0 auto}.dp-clock-cell{border:1.5px solid var(--border);border-radius:6px;background:var(--surface);color:var(--text);font-size:12px;font-weight:600;font-family:var(--font);padding:4px 2px;cursor:pointer;transition:all .12s ease;text-align:center}.dp-clock-cell:hover{background:var(--brand-light);border-color:var(--brand);color:var(--brand)}.dp-clock-active{background:var(--brand)!important;border-color:var(--brand)!important;color:#fff!important;box-shadow:0 2px 8px rgba(97,97,255,.3)}.dp-clock-ampm-cell{padding:12px 4px;font-size:16px;font-weight:700;letter-spacing:.05em}.dp-actions{display:flex;justify-content:flex-end;gap:8px}.dp-clear{background:none;border:1px solid var(--border2);border-radius:var(--radius3);color:var(--text2);padding:7px 14px;font-size:13px;font-weight:500;font-family:var(--font);cursor:pointer;transition:all var(--transition)}.dp-clear:hover{color:var(--red);border-color:var(--red);background:var(--red-light)}.dp-apply{background:var(--brand);border:none;border-radius:var(--radius3);color:#fff;padding:7px 18px;font-size:13px;font-weight:600;font-family:var(--font);cursor:pointer;transition:background var(--transition)}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:rgba(0,0,0,.5);z-index:1000;display:flex;align-items:center;justify-content:center;animation:modal-fade .15s ease}@keyframes modal-fade{0%{opacity:0}to{opacity:1}}.modal-box{background:var(--surface);border-radius:var(--radius2);box-shadow:0 8px 40px rgba(0,0,0,.18);padding:32px 32px 28px;max-width:400px;width:90%;text-align:center;animation:modal-up .15s ease}@keyframes modal-up{0%{opacity:0;transform:scale(.95) translateY(8px)}to{opacity:1;transform:scale(1) translateY(0)}}.modal-icon{font-size:32px;margin-bottom:12px}.modal-title{font-size:18px;font-weight:700;color:var(--text);margin-bottom:8px}.modal-message{font-size:13.5px;color:var(--text2);line-height:1.5;margin-bottom:24px}.modal-actions{display:flex;gap:10px;justify-content:center}.modal-btn-cancel{background:var(--surface2);border:1.5px solid var(--border2);border-radius:var(--radius3);color:var(--text2);padding:9px 24px;font-size:14px;font-weight:600;font-family:var(--font);cursor:pointer;transition:all var(--transition)}.modal-btn-cancel:hover{background:var(--surface3);color:var(--text)}.modal-btn-confirm{background:var(--red);border:none;border-radius:var(--radius3);color:#fff;padding:9px 24px;font-size:14px;font-weight:600;font-family:var(--font);cursor:pointer;transition:background var(--transition),box-shadow var(--transition)}.modal-btn-confirm:hover{background:#c8293e;box-shadow:0 4px 12px rgba(228,66,88,.3)}.chat-panel{display:flex;flex-direction:column;height:calc(100vh - 56px);max-width:760px}.chat-messages{flex:1;overflow-y:auto;display:flex;flex-direction:column;gap:16px;padding:8px 0 16px;-webkit-overflow-scrolling:touch}.chat-bubble-row{display:flex;align-items:flex-end;gap:10px;animation:bubble-in .18s ease}@keyframes bubble-in{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.chat-user{flex-direction:row-reverse}.chat-avatar{width:30px;height:30px;border-radius:50%;background:var(--brand);color:#fff;display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:700;flex-shrink:0}.chat-avatar-user{background:var(--surface3);color:var(--text2);font-size:9px}.chat-bubble{max-width:75%;padding:12px 16px;border-radius:18px;font-size:14px;line-height:1.55;word-break:break-word}.chat-bubble-ai{background:var(--surface);border:1px solid var(--border);color:var(--text);border-bottom-left-radius:4px}.chat-bubble-user{background:var(--brand);color:#fff;border-bottom-right-radius:4px}.chat-typing{display:flex;align-items:center;gap:5px;padding:14px 18px}.chat-typing span{width:7px;height:7px;background:var(--text3);border-radius:50%;display:inline-block;animation:typing 1.2s infinite}.chat-typing span:nth-child(2){animation-delay:.2s}.chat-typing span:nth-child(3){animation-delay:.4s}@keyframes typing{0%,60%,to{transform:translateY(0);opacity:.4}30%{transform:translateY(-6px);opacity:1}}.chat-suggestions{display:flex;flex-wrap:wrap;gap:8px;padding:12px 0}.chat-suggestion{background:var(--surface);border:1.5px solid var(--border);border-radius:20px;color:var(--text2);font-size:12.5px;font-weight:500;padding:7px 14px;font-family:var(--font);cursor:pointer;transition:all var(--transition);text-align:left}.chat-suggestion:hover{border-color:var(--brand);color:var(--brand);background:var(--brand-light)}.chat-input-row{display:flex;gap:10px;align-items:flex-end;padding:12px 0 4px;border-top:1px solid var(--border)}.chat-input{flex:1;background:var(--surface2);border:1.5px solid var(--border);border-radius:22px;color:var(--text);padding:11px 18px;font-size:14px;font-family:var(--font);outline:none;resize:none;line-height:1.4;max-height:120px;overflow-y:auto;transition:border-color var(--transition),box-shadow var(--transition)}.chat-input:focus{border-color:var(--brand);box-shadow:0 0 0 3px rgba(97,97,255,.12);background:var(--surface)}.chat-input::placeholder{color:var(--text3)}.chat-send{width:42px;height:42px;border-radius:50%;background:var(--brand);border:none;color:#fff;font-size:18px;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:background var(--transition),box-shadow var(--transition),transform var(--transition)}.chat-send:hover:not(:disabled){background:var(--brand-hover);box-shadow:0 4px 12px rgba(97,97,255,.35);transform:scale(1.05)}.chat-send:disabled{opacity:.4;cursor:not-allowed}.chat-hint{font-size:11px;color:var(--text3);text-align:center;padding:4px 0 0}.loading{color:var(--text3);font-size:13px;padding:32px 0}.empty{color:var(--text3);font-size:13.5px;padding:48px 0;text-align:center}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--border2);border-radius:999px}::-webkit-scrollbar-thumb:hover{background:var(--text3)}.sidebar{padding-bottom:env(safe-area-inset-bottom)}.main-content{padding-bottom:calc(16px + env(safe-area-inset-bottom))}button,a{-webkit-tap-highlight-color:transparent}@media (max-width:1024px){.stats-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width:600px){:root{--sidebar-w: 56px }.dashboard{flex-direction:column}.sidebar{width:100%;height:auto;border-right:none;border-top:1px solid var(--border);order:2;flex-shrink:0}.sidebar-top,.sidebar-bottom,.sidebar-date,.sidebar-date-row{display:none}.sidebar-nav{flex-direction:row;padding:6px 8px;gap:0;overflow-x:auto;justify-content:space-around;padding-bottom:calc(6px + env(safe-area-inset-bottom))}.nav-item{flex-direction:column;gap:3px;padding:8px 4px;flex:1;justify-content:center;align-items:center;border-radius:var(--radius);min-width:44px}.nav-label{font-size:10px;font-weight:600}.nav-icon{font-size:20px}.nav-badge{position:absolute;top:4px;right:8px;font-size:9px;padding:1px 4px}.main-content{flex:1;order:1;overflow-y:auto;padding:16px 14px 12px}.main-content.full-bleed{padding:0;overflow:hidden}.panel-header h2{font-size:18px}.panel-header{flex-wrap:wrap;gap:8px}.panel-actions{flex-wrap:wrap;gap:6px;width:100%}.panel-actions .filter-select{font-size:12px;padding:5px 8px;flex:1;min-width:0}.add-form{padding:12px}.form-row{flex-direction:column}.item{padding:12px}.item-buttons{opacity:1}.item-main,.item-body{min-width:0}.task-title-row{flex-wrap:wrap}.item-title{word-break:break-word}.stats-grid{grid-template-columns:repeat(2,1fr);gap:8px}.quick-actions{gap:8px}.chat-panel{height:calc(100vh - 120px)}.chat-bubble{max-width:88%}.chat-hint{display:none}.dp-popup{position:fixed;bottom:0;left:0;right:0;top:auto;border-radius:var(--radius2) var(--radius2) 0 0;border-bottom:none;padding-bottom:calc(20px + env(safe-area-inset-bottom));min-width:unset;width:100%}.setting-row{flex-direction:column}.setting-info{width:100%}}.dp-apply:hover{background:var(--brand-hover)}.dp-ampm{background:var(--surface2);border:1.5px solid var(--border);border-radius:var(--radius3);color:var(--brand);font-size:12px;font-weight:700;padding:4px 8px;cursor:pointer;font-family:var(--font);transition:all var(--transition);margin-left:4px}.dp-ampm:hover{background:var(--brand);color:#fff;border-color:var(--brand)}.push-card{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:18px 20px;background:var(--brand-light);border:1.5px solid var(--brand-mid);border-radius:var(--radius2);margin-bottom:24px}.push-card-info h3{font-size:15px;font-weight:700;color:var(--text);margin-bottom:4px}.push-card-info p{font-size:12.5px;color:var(--text2);line-height:1.4}.btn-success{background:var(--green)!important}.tab-drag-list{display:flex;flex-direction:column;gap:8px;user-select:none;margin-top:12px}.tab-drag-item{display:flex;align-items:center;gap:12px;padding:12px 16px;background:var(--surface2);border-radius:var(--radius3);border:1px solid var(--border);transition:all .2s ease;position:relative;cursor:default}.tab-drag-item:hover{border-color:var(--brand);background:var(--surface1)}.tab-drag-item.dragging{opacity:.4;background:var(--surface3);border-style:dashed;z-index:100;transform:scale(.98)}.tab-drag-handle{display:flex;align-items:center;justify-content:center;color:var(--text3);cursor:grab;padding:6px;margin-left:-8px;border-radius:4px;transition:all .2s}.tab-drag-handle:active{cursor:grabbing}.tab-drag-handle:hover{background:var(--surface3);color:var(--brand)}.tab-drag-icon{font-size:1.2rem;width:24px;text-align:center}.tab-drag-label{flex:1;font-weight:500;font-size:.95rem;color:var(--text)}.tab-mobile-badge{font-size:10px;color:var(--brand);font-weight:600;padding:2px 8px;background:var(--brand-light, rgba(0, 134, 192, .1));border-radius:12px;margin-left:8px}.tab-visibility-btn{padding:6px 14px;border-radius:20px;font-size:12px;font-weight:600;cursor:pointer;border:none;transition:all .2s;min-width:80px}.tab-visibility-btn.visible{background:rgba(0,200,117,.1);color:#00c875}.tab-visibility-btn.visible:hover{background:rgba(0,200,117,.2)}.tab-visibility-btn.hidden{background:rgba(228,66,88,.1);color:#e44258}.tab-visibility-btn.hidden:hover{background:rgba(228,66,88,.2)}.logo-img{width:28px;height:28px;border-radius:6px;object-fit:cover;flex-shrink:0}.inbox-item-row{position:relative}.inbox-delete-btn{position:absolute;top:50%;transform:translateY(-50%);right:10px;background:none;border:none;cursor:pointer;font-size:13px;color:var(--text3);width:26px;height:26px;border-radius:50%;display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .15s,background .15s;flex-shrink:0}.inbox-item-row:hover .inbox-delete-btn{opacity:1}.inbox-delete-btn:hover{background:var(--surface3);color:var(--text)}@media (max-width: 1024px){.inbox-delete-btn{opacity:.5}}.cb-fab{position:fixed;bottom:24px;right:24px;z-index:900;width:56px;height:56px;border-radius:50%;background:var(--brand);color:#fff;border:none;font-size:22px;cursor:pointer;box-shadow:0 4px 20px rgba(97,97,255,.4);transition:transform var(--transition),box-shadow var(--transition),background var(--transition);display:flex;align-items:center;justify-content:center}.cb-fab:hover{transform:scale(1.08);box-shadow:0 6px 24px rgba(97,97,255,.5)}.cb-fab-badge{position:absolute;top:-4px;right:-4px;background:#ef4444;color:#fff;border-radius:10px;padding:2px 5px;font-size:11px;font-weight:700;min-width:18px;text-align:center;line-height:1.4;pointer-events:none}@keyframes cb-badge-pulse{0%,to{transform:scale(1)}50%{transform:scale(1.25)}}.cb-fab-badge-pulse{animation:cb-badge-pulse 1.4s ease-in-out infinite}.cb-fab-open{background:var(--text2);box-shadow:0 4px 20px rgba(0,0,0,.2)}.cb-window{position:fixed;bottom:92px;right:24px;z-index:899;width:500px;height:560px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius2);box-shadow:var(--shadow2);display:flex;flex-direction:column;animation:cb-in .2s ease}@keyframes cb-in{0%{opacity:0;transform:translateY(16px) scale(.97)}to{opacity:1;transform:translateY(0) scale(1)}}.cb-header{display:flex;align-items:center;justify-content:space-between;padding:12px 14px;border-bottom:1px solid var(--border);background:var(--brand);border-radius:var(--radius2) var(--radius2) 0 0}.cb-header-info{display:flex;align-items:center;gap:10px}.cb-header-avatar{width:32px;height:32px;border-radius:50%;background:rgba(255,255,255,.25);color:#fff;display:flex;align-items:center;justify-content:center;font-size:16px;font-weight:700}.cb-header-name{font-size:13px;font-weight:700;color:#fff}.cb-header-status{font-size:11px;color:rgba(255,255,255,.75)}.cb-header-actions{display:flex;gap:6px}.cb-clear,.cb-close{background:rgba(255,255,255,.15);border:none;color:#fff;width:28px;height:28px;border-radius:6px;cursor:pointer;font-size:13px;display:flex;align-items:center;justify-content:center;transition:background var(--transition)}.cb-clear:hover,.cb-close:hover{background:rgba(255,255,255,.3)}.cb-messages{flex:1;overflow-y:auto;padding:12px;display:flex;flex-direction:column;gap:10px;-webkit-overflow-scrolling:touch}.cb-row{display:flex;align-items:flex-end;gap:8px;animation:bubble-in .18s ease}.cb-user{flex-direction:row-reverse}.cb-avatar{width:26px;height:26px;border-radius:50%;background:var(--brand);color:#fff;font-size:11px;font-weight:700;flex-shrink:0;display:flex;align-items:center;justify-content:center}.cb-bubble{max-width:85%;padding:9px 13px;border-radius:16px;font-size:13px;line-height:1.5;word-break:break-word}.cb-bubble-ai{background:var(--surface2);border:1px solid var(--border);color:var(--text);border-bottom-left-radius:4px}.cb-bubble-user{background:var(--brand);color:#fff;border-bottom-right-radius:4px}.cb-typing{display:flex;align-items:center;gap:4px;padding:12px 14px}.cb-typing span{width:6px;height:6px;background:var(--text3);border-radius:50%;animation:typing 1.2s infinite}.cb-typing span:nth-child(2){animation-delay:.2s}.cb-typing span:nth-child(3){animation-delay:.4s}.cb-suggestions{display:flex;flex-direction:column;gap:6px;margin-top:4px}.cb-suggestion{background:var(--surface);border:1px solid var(--border);border-radius:12px;color:var(--text2);font-size:12px;font-weight:500;padding:6px 12px;text-align:left;cursor:pointer;transition:all var(--transition);font-family:var(--font)}.cb-suggestion:hover{border-color:var(--brand);color:var(--brand);background:var(--brand-light)}.cb-input-row{display:flex;gap:8px;padding:10px 12px;border-top:1px solid var(--border)}.cb-input{flex:1;min-width:0;background:var(--surface2);border:1.5px solid var(--border);border-radius:20px;color:var(--text);padding:8px 14px;font-size:13px;font-family:var(--font);outline:none;resize:none;line-height:1.4;max-height:120px;overflow-y:auto;transition:border-color var(--transition)}.cb-input:focus{border-color:var(--brand)}.cb-input::placeholder{color:var(--text3)}.cb-send{width:36px;height:36px;border-radius:50%;background:var(--brand);border:none;color:#fff;font-size:16px;cursor:pointer;flex-shrink:0;display:flex;align-items:center;justify-content:center;transition:background var(--transition),transform var(--transition)}.cb-send:hover:not(:disabled){background:var(--brand-hover);transform:scale(1.05)}.cb-send:disabled{opacity:.4;cursor:not-allowed}@media (max-width: 600px){.cb-window{width:calc(100vw - 24px);right:12px;bottom:80px;height:420px}.cb-fab{bottom:16px;right:16px;width:50px;height:50px}}.role-tabs{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:16px}.role-tab{display:flex;align-items:center;gap:6px;padding:7px 14px;border-radius:999px;border:1.5px solid var(--border);background:var(--surface);font-size:13px;font-weight:500;color:var(--text2);cursor:pointer;transition:all var(--transition);font-family:var(--font)}.role-tab:hover{border-color:var(--role-color);color:var(--role-color)}.role-tab.active{background:var(--role-color);border-color:var(--role-color);color:#fff}.role-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.role-tab.active .role-dot{background:rgba(255,255,255,.7)}.perm-note{font-size:12px;color:var(--text3);margin-bottom:16px;padding:8px 12px;background:var(--surface2);border-radius:var(--radius3)}.perm-grid{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden}.perm-grid-header{display:grid;grid-template-columns:1fr repeat(4,80px);padding:10px 16px;background:var(--surface2);border-bottom:1px solid var(--border);font-size:11px;font-weight:700;color:var(--text3);text-transform:uppercase;letter-spacing:.05em}.perm-row{display:grid;grid-template-columns:1fr repeat(4,80px);padding:12px 16px;border-bottom:1px solid var(--border);align-items:center;transition:background var(--transition)}.perm-row:last-child{border-bottom:none}.perm-row:hover{background:var(--surface2)}.perm-module-col{display:flex;align-items:center;gap:8px;font-size:13.5px;font-weight:500;color:var(--text)}.perm-action-col{display:flex;align-items:center;justify-content:center}.perm-on{background:var(--green-light);border-color:var(--green);color:var(--green)}.perm-on:hover{background:var(--green);color:#fff}.perm-off{background:var(--red-light);border-color:var(--red);color:var(--red)}.perm-off:hover{background:var(--red);color:#fff}.perm-section-header{display:flex;align-items:center;gap:8px;width:100%;padding:8px 16px;background:var(--surface2);border:none;border-bottom:1px solid var(--border);cursor:pointer;text-align:left;font:inherit;color:inherit;transition:background .12s}.perm-section-header:hover{background:var(--surface3, var(--surface2))}.perm-section-chevron{display:inline-block;font-size:10px;color:var(--text3);width:12px;transition:transform .15s}.perm-section-header[aria-expanded=true] .perm-section-chevron{transform:rotate(90deg)}.perm-section-label{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--text3)}.perm-row-sub{background:var(--surface2)}.perm-row-sub:hover{background:var(--surface3, var(--surface2))}.perm-row-locked{opacity:.75}.perm-sub-indent{width:16px;display:inline-block;flex-shrink:0}.perm-badge{font-size:11px;font-weight:600;padding:3px 8px;border-radius:20px;white-space:nowrap}.perm-badge-admin{background:var(--green-light);color:var(--green)}.perm-badge-locked{background:var(--surface2);color:var(--text3)}.perm-toggle{min-width:32px;width:auto;padding:0 6px;height:28px;border-radius:6px;border:1.5px solid;font-size:11px;font-weight:600;cursor:pointer;transition:all var(--transition);display:flex;align-items:center;justify-content:center;font-family:var(--font);white-space:nowrap}.perm-field-visibility-section{margin-top:24px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden}.perm-fv-heading{border-bottom:1px solid var(--border)}@media (max-width: 600px){.perm-grid-header,.perm-row{grid-template-columns:1fr repeat(4,56px)}.perm-grid-header{font-size:9px}}.home-tabs{display:flex;gap:8px;margin-bottom:16px;border-bottom:1px solid var(--border);padding-bottom:0}.home-tab{display:flex;align-items:center;gap:6px;padding:8px 16px;border:none;background:none;font-size:13.5px;font-weight:500;color:var(--text2);cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-1px;transition:all var(--transition);font-family:var(--font);position:relative}.home-tab:hover{color:var(--text)}.home-tab.active{color:var(--brand);border-bottom-color:var(--brand);font-weight:600}.home-tab-badge{background:var(--red);color:#fff;font-size:10px;font-weight:700;padding:1px 5px;border-radius:999px;min-width:16px;text-align:center}.home-group{margin-bottom:20px}.home-group-title{font-size:12px;font-weight:700;color:var(--text3);text-transform:uppercase;letter-spacing:.06em;margin-bottom:8px;padding:0 2px}.overdue-title{color:var(--red)}.item-more{padding:10px 16px;text-align:center;font-size:13px;color:var(--brand);font-weight:500;cursor:pointer;background:var(--brand-light);border-radius:var(--radius);border:1px dashed var(--brand-mid);transition:all var(--transition)}.item-more:hover{background:var(--brand);color:#fff}@media (max-width: 600px){.cb-fab{bottom:calc(72px + env(safe-area-inset-bottom));right:16px;width:50px;height:50px}.cb-window{position:fixed;top:0;left:0;right:0;bottom:0;width:100%;height:100%;border-radius:0;border:none;z-index:1000}.cb-header{border-radius:0;padding-top:calc(20px + env(safe-area-inset-top,44px))}.cb-input-row{padding-bottom:calc(10px + env(safe-area-inset-bottom))}}.mobile-nav{display:none}@media (max-width: 1024px){.sidebar{display:none}.main-content{padding:20px 16px;padding-top:calc(28px + env(safe-area-inset-top,44px));padding-bottom:calc(92px + env(safe-area-inset-bottom))}.mobile-nav{display:flex;position:fixed;bottom:0;left:0;right:0;background:var(--surface);border-top:1px solid var(--border);padding-bottom:env(safe-area-inset-bottom);z-index:800;height:calc(72px + env(safe-area-inset-bottom));align-items:stretch}.mobile-nav-item{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;border:none;background:transparent;color:var(--text3);cursor:pointer;padding:8px 2px;transition:color var(--transition);position:relative;font-family:var(--font);min-width:0}.mobile-nav-item.active{color:var(--brand)}.mobile-nav-icon{font-size:22px;line-height:1;font-weight:700}.mobile-nav-label{font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.03em;white-space:nowrap}.mobile-badge{position:absolute;top:4px;right:8px;font-size:8px;padding:1px 4px}.mobile-more-wrapper{position:relative;flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center}.mobile-more-drawer{position:absolute;bottom:100%;right:0;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius2);box-shadow:var(--shadow2);padding:8px;min-width:180px;animation:cb-in .15s ease;margin-bottom:4px}.mobile-more-item{display:flex;align-items:center;gap:10px;width:100%;padding:10px 14px;border:none;background:transparent;color:var(--text2);font-size:16px;font-weight:500;cursor:pointer;border-radius:var(--radius3);text-align:left;font-family:var(--font);transition:all var(--transition)}.mobile-more-item:hover{background:var(--surface2);color:var(--text)}.mobile-more-item.active{color:var(--brand);background:var(--brand-light)}.mobile-more-logout{color:var(--red);margin-top:4px;border-top:1px solid var(--border);border-radius:0 0 var(--radius3) var(--radius3)}.mobile-more-logout:hover{background:var(--red-light)}.cb-fab{bottom:calc(68px + env(safe-area-inset-bottom));right:14px;width:48px;height:48px;font-size:20px}.cb-window{position:fixed;top:0;left:0;right:0;height:100dvh;width:100%;border-radius:0;border:none;z-index:1000;display:flex;flex-direction:column;overflow:hidden}.cb-header{border-radius:0;flex-shrink:0;padding-top:calc(20px + env(safe-area-inset-top,44px))}.cb-messages{flex:1;min-height:0;overflow-y:auto;-webkit-overflow-scrolling:touch}.cb-input-row{flex-shrink:0;padding-bottom:calc(8px + env(safe-area-inset-bottom));background:var(--surface);border-top:1px solid var(--border)}}.cb-home{flex:1;overflow-y:auto;padding:16px 14px 20px;display:flex;flex-direction:column;align-items:center;gap:16px}.cb-home-greeting{text-align:center}.cb-home-avatar{width:52px;height:52px;border-radius:50%;background:var(--brand);color:#fff;font-size:22px;font-weight:700;margin:0 auto 10px;display:flex;align-items:center;justify-content:center}.cb-home-greeting h3{font-size:16px;font-weight:700;color:var(--text);margin-bottom:4px}.cb-home-greeting p{font-size:13px;color:var(--text2)}.cb-quick-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px;width:100%}.cb-quick-btn{display:flex;align-items:center;gap:10px;padding:11px 14px;background:var(--surface2);border:1.5px solid var(--border);border-radius:var(--radius);cursor:pointer;transition:all var(--transition);font-family:var(--font);text-align:left}.cb-quick-btn:hover{border-color:var(--brand);background:var(--brand-light)}.cb-quick-icon{font-size:18px;flex-shrink:0}.cb-quick-label{font-size:12.5px;font-weight:600;color:var(--text2);line-height:1.3}.cb-quick-btn:hover .cb-quick-label{color:var(--brand)}.cb-chat-free{width:100%;padding:11px;background:transparent;border:1.5px dashed var(--border2);border-radius:var(--radius);color:var(--text3);font-size:13px;font-weight:500;cursor:pointer;transition:all var(--transition);font-family:var(--font)}.cb-chat-free:hover{border-color:var(--brand);color:var(--brand);background:var(--brand-light)}.cb-bubble-wrapper{display:flex;flex-direction:column;gap:6px;max-width:85%}.cb-choices{display:flex;flex-direction:column;gap:6px}.cb-choice-btn{background:var(--surface);border:1.5px solid var(--brand-mid);border-radius:var(--radius);padding:9px 14px;color:var(--brand);font-size:13px;font-weight:500;cursor:pointer;text-align:left;transition:all var(--transition);font-family:var(--font)}.cb-choice-btn:hover{background:var(--brand);color:#fff;border-color:var(--brand)}.cb-form{background:var(--surface2);border:1.5px solid var(--border);border-radius:var(--radius2);padding:14px;margin:4px 0;display:flex;flex-direction:column;gap:8px}.cb-form-title{font-size:13px;font-weight:700;color:var(--text);margin-bottom:2px}.cb-form-input{background:var(--surface);border:1.5px solid var(--border);border-radius:var(--radius3);color:var(--text);padding:8px 10px;font-size:13px;font-family:var(--font);outline:none;width:100%;transition:border-color var(--transition)}.cb-form-input:focus{border-color:var(--brand)}.cb-form-textarea{resize:none}.cb-form-select{background:var(--surface);border:1.5px solid var(--border);border-radius:var(--radius3);color:var(--text);padding:8px 10px;font-size:13px;font-family:var(--font);outline:none;width:100%}.cb-form-actions{display:flex;gap:8px}.cb-form-submit{flex:1;background:var(--brand);border:none;border-radius:var(--radius3);color:#fff;padding:9px;font-size:13px;font-weight:600;cursor:pointer;font-family:var(--font);transition:background var(--transition)}.cb-form-submit:hover{background:var(--brand-hover)}.cb-form-submit:disabled{opacity:.5;cursor:not-allowed}.cb-form-cancel{width:36px;background:var(--surface);border:1.5px solid var(--border2);border-radius:var(--radius3);color:var(--text3);cursor:pointer;font-size:16px;transition:all var(--transition)}.cb-form-cancel:hover{color:var(--red);border-color:var(--red);background:var(--red-light)}.cb-add-btn{width:36px;height:36px;border-radius:50%;border:1.5px solid var(--border2);background:var(--surface2);color:var(--text2);font-size:20px;font-weight:300;cursor:pointer;flex-shrink:0;transition:all var(--transition);display:flex;align-items:center;justify-content:center}.cb-add-btn:hover{border-color:var(--brand);color:var(--brand);background:var(--brand-light)}.language-card{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius2);margin-bottom:16px}.language-card-info h3{font-size:16px;font-weight:700;color:var(--text);margin-bottom:3px}.language-card-info p{font-size:12px;color:var(--text2)}.language-btns{display:flex;gap:8px}.lang-btn{padding:8px 18px;border-radius:var(--radius3);border:1.5px solid var(--border2);background:var(--surface2);color:var(--text2);font-size:13px;font-weight:600;cursor:pointer;transition:all var(--transition);font-family:var(--font)}.lang-btn.active{background:var(--brand);border-color:var(--brand);color:#fff}.lang-btn:hover:not(.active){border-color:var(--brand);color:var(--brand)}@media (max-width: 600px){.cb-bubble{max-width:95%!important;font-size:14px!important}.cb-bubble-wrapper{max-width:95%!important}.cb-messages{padding:10px}}.cb-input{min-width:0!important;overflow-x:hidden!important;text-overflow:ellipsis}.cb-input-row{min-width:0}.store-tabs{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:16px;padding-bottom:12px;border-bottom:1px solid var(--border)}.store-tab{padding:6px 14px;border-radius:999px;border:1.5px solid var(--border2);background:var(--surface);color:var(--text2);font-size:12.5px;font-weight:600;cursor:pointer;transition:all var(--transition);font-family:var(--font)}.store-tab:hover{border-color:var(--brand);color:var(--brand)}.store-tab.active{background:var(--brand);border-color:var(--brand);color:#fff}.store-groups{display:flex;flex-direction:column;gap:20px}.store-group-header{display:flex;align-items:center;gap:8px;margin-bottom:8px;padding:0 2px}.store-group-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}.store-group-name{font-size:13px;font-weight:700;color:var(--text2);text-transform:uppercase;letter-spacing:.04em;flex:1}.store-group-count{font-size:11px;color:var(--text3);background:var(--surface2);border:1px solid var(--border);border-radius:999px;padding:1px 7px}.store-selector{width:100%}.cb-mic-btn{width:36px;height:36px;border-radius:50%;border:1.5px solid var(--border2);background:var(--surface2);font-size:16px;cursor:pointer;flex-shrink:0;display:flex;align-items:center;justify-content:center;transition:all var(--transition)}.cb-mic-btn:hover{border-color:var(--brand);background:var(--brand-light)}.cb-mic-active{background:var(--red-light)!important;border-color:var(--red)!important;animation:mic-pulse 1s ease infinite}@keyframes mic-pulse{0%,to{box-shadow:0 0 rgba(228,66,88,.4)}50%{box-shadow:0 0 0 6px rgba(228,66,88,0)}}.crm-panel{display:flex;flex-direction:column;height:100vh;overflow:hidden;background:var(--bg)}.crm-stats-bar{display:flex;align-items:center;gap:6px;flex-wrap:wrap;padding:10px 16px;background:var(--surface);border-bottom:1px solid var(--border);flex-shrink:0}.crm-stat-total{display:flex;flex-direction:column;align-items:center;padding:4px 12px;cursor:pointer;border-radius:var(--radius3);background:var(--surface2);border:1px solid var(--border);transition:all var(--transition)}.crm-stat-total:hover{border-color:var(--brand)}.crm-stat-pill{display:flex;flex-direction:column;align-items:center;padding:4px 10px;cursor:pointer;border-radius:var(--radius3);border:1px solid var(--border);background:var(--surface2);transition:all var(--transition);font-size:11px}.crm-stat-pill:hover{border-color:var(--brand)}.crm-stat-pill.active{font-weight:600}.crm-stat-num{font-size:16px;font-weight:700;color:var(--text);line-height:1}.crm-stat-lbl{font-size:10px;color:var(--text3);white-space:nowrap}.crm-scrape-btn{margin-left:auto;white-space:nowrap;font-size:12px;padding:6px 14px;position:relative;overflow:hidden;transition:all .3s ease}.crm-scrape-btn:hover{background:var(--brand-hover);box-shadow:0 0 15px rgba(97,97,255,.6);transform:translateY(-1px)}.crm-scrape-btn:active{transform:translateY(0)}.crm-toolbar{display:flex;align-items:center;gap:10px;flex-wrap:wrap;padding:10px 16px;background:var(--surface);border-bottom:1px solid var(--border);flex-shrink:0}.crm-search{background:var(--surface2);border:1.5px solid var(--border);border-radius:var(--radius3);color:var(--text);padding:7px 12px;font-size:13px;font-family:var(--font);outline:none;min-width:200px;transition:border-color var(--transition)}.crm-search:focus{border-color:var(--brand)}.crm-filter-group{display:flex;gap:4px}.crm-filter-btn{padding:5px 12px;border-radius:999px;border:1.5px solid var(--border);background:var(--surface2);color:var(--text2);font-size:12px;font-weight:500;cursor:pointer;transition:all var(--transition);font-family:var(--font)}.crm-filter-btn:hover{border-color:var(--brand);color:var(--brand)}.crm-filter-btn.active{background:var(--brand);border-color:var(--brand);color:#fff}.crm-tabs{display:flex;align-items:center;gap:2px;padding:0 16px;background:var(--surface);border-bottom:1px solid var(--border);flex-shrink:0}.crm-tab{padding:10px 16px;border:none;background:none;color:var(--text2);font-size:13px;font-weight:500;cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-1px;transition:all var(--transition);font-family:var(--font)}.crm-tab:hover{color:var(--text)}.crm-tab.active{color:var(--brand);border-bottom-color:var(--brand);font-weight:600}.crm-export-btn{margin-left:auto;padding:6px 14px;font-size:12px}.crm-main{display:flex;flex:1;min-height:0;overflow:hidden;position:relative}.crm-sidebar{width:280px;flex-shrink:0;overflow-y:auto;border-right:1px solid var(--border);background:var(--surface);transition:width .3s cubic-bezier(.4,0,.2,1),opacity .2s ease,padding .3s ease;position:relative}.crm-sidebar.collapsed{width:0;padding:0;border-right:none;opacity:0;pointer-events:none}.crm-side-toggle{position:absolute;top:50%;left:268px;transform:translateY(-50%);width:24px;height:48px;background:var(--surface);border:1px solid var(--border);border-radius:6px;display:flex;align-items:center;justify-content:center;cursor:pointer;z-index:1100;box-shadow:var(--shadow);color:var(--text3);transition:all .3s cubic-bezier(.4,0,.2,1)}.crm-side-toggle:hover{color:var(--brand);border-color:var(--brand);background:var(--brand-light)}.crm-side-toggle.collapsed{left:0;transform:translateY(-50%)}@media (max-width: 768px){.crm-side-toggle,.crm-side-toggle.collapsed{display:none!important}}.crm-project-card{display:flex;gap:10px;padding:10px 12px;border-bottom:1px solid var(--border);cursor:pointer;transition:background var(--transition)}.crm-project-card:hover{background:var(--surface2)}.crm-project-card.active{background:var(--brand-light);border-left:3px solid var(--brand)}.crm-card-thumb{width:44px;height:44px;object-fit:cover;border-radius:var(--radius3);flex-shrink:0}.crm-thumb-placeholder{width:44px;height:44px;border-radius:var(--radius3);background:var(--surface2);display:flex;align-items:center;justify-content:center;font-size:18px;flex-shrink:0}.crm-card-body{flex:1;min-width:0}.crm-card-title{font-size:12.5px;font-weight:600;color:var(--text);line-height:1.3;margin-bottom:3px}.crm-card-addr{font-size:11px;color:var(--text3);margin-bottom:2px}.crm-card-prom{font-size:11px;color:var(--text3);margin-bottom:4px}.crm-card-badges{display:flex;gap:4px;flex-wrap:wrap}.crm-view-area{flex:1;display:flex;flex-direction:column;min-width:0;overflow:hidden}.crm-map{flex:1;width:100%;min-height:400px}.crm-map-legend{position:absolute;bottom:30px;right:10px;z-index:1000;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius2);padding:10px 14px;box-shadow:var(--shadow2);font-size:12px}.crm-legend-title{font-weight:700;margin-bottom:6px;color:var(--text)}.crm-legend-item{display:flex;align-items:center;gap:6px;margin-bottom:4px;color:var(--text2)}.crm-legend-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}.crm-table-wrap{flex:1;overflow:auto}.crm-table{width:100%;border-collapse:collapse;font-size:12.5px}.crm-table thead{position:sticky;top:0;background:var(--surface);z-index:10}.crm-table th{padding:10px 12px;text-align:left;font-weight:600;color:var(--text2);border-bottom:1px solid var(--border);white-space:nowrap;cursor:pointer}.crm-column-filter{width:100%;background:var(--surface)!important;border:1px solid var(--border)!important;border-radius:4px;padding:4px 6px!important;font-size:11px!important;color:var(--text)!important;outline:none;transition:border-color var(--transition)}.crm-column-filter:focus{border-color:var(--brand)!important}.crm-table th:hover{color:var(--text)}.crm-table td{padding:8px 12px;border-bottom:1px solid var(--border);color:var(--text)}.crm-table tr:hover td{background:var(--surface2)}.crm-row-active td{background:var(--brand-light)!important}.crm-kanban{display:flex;gap:12px;padding:16px;overflow-x:auto;flex:1;align-items:flex-start}.crm-kanban-col{min-width:220px;width:220px;background:var(--surface2);border-radius:var(--radius2);border:1px solid var(--border);display:flex;flex-direction:column;max-height:100%;transition:background var(--transition)}.crm-kanban-col.drag-over{background:var(--brand-light);border-color:var(--brand)}.crm-kanban-header{padding:10px 12px;font-size:12px;font-weight:700;color:var(--text2);display:flex;justify-content:space-between;border-bottom:1px solid var(--border);flex-shrink:0}.crm-kb-count{background:var(--surface);border:1px solid var(--border);border-radius:999px;padding:1px 7px;font-size:11px}.crm-kanban-card{margin:6px;padding:10px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius3);cursor:grab;transition:all var(--transition)}.crm-kanban-card:hover{border-color:var(--brand);box-shadow:var(--shadow)}.crm-kanban-card.dragging{opacity:.5}.crm-kb-title{font-size:12px;font-weight:600;color:var(--text);margin-bottom:4px;line-height:1.3}.crm-kb-prom{font-size:11px;color:var(--text3);margin-bottom:6px}.crm-kb-foot{display:flex;justify-content:space-between;font-size:11px;color:var(--text3)}.crm-contacts-wrap{flex:1;display:flex;flex-direction:column;overflow:hidden}.crm-contacts-toolbar{display:flex;align-items:center;gap:12px;padding:12px 16px;border-bottom:1px solid var(--border);flex-shrink:0}.crm-detail-panel{width:360px;flex-shrink:0;border-left:1px solid var(--border);background:var(--surface);overflow-y:auto;position:relative}.crm-panel-overlay .crm-detail-panel{width:100%;max-width:100%;border-left:none;height:100%;overflow-y:visible}.crm-detail-close{position:sticky;top:0;float:right;background:var(--surface);border:none;color:var(--text2);font-size:16px;cursor:pointer;padding:12px 16px;z-index:10}.crm-detail-close:hover{color:var(--text)}.crm-detail-header{padding:12px 16px;clear:both}.crm-detail-img{width:100%;height:140px;object-fit:cover;border-radius:var(--radius2);margin-bottom:10px}.crm-detail-title{font-size:16px;font-weight:700;color:var(--text);margin:6px 0 4px;line-height:1.3}.crm-detail-addr{font-size:12px;color:var(--text3);margin-bottom:4px;text-decoration:none;display:inline-block}.crm-maps-link{color:var(--brand);font-size:12px;text-decoration:none;display:inline-flex;align-items:center;gap:4px;margin-bottom:4px;padding:3px 8px;border-radius:6px;background:var(--brand-light);border:1px solid var(--brand-mid);transition:opacity .15s}.crm-maps-link:hover{opacity:.8}.crm-detail-link{font-size:12px;color:var(--brand);text-decoration:none}.crm-badge{display:inline-block;font-size:10px;font-weight:700;padding:2px 8px;border-radius:999px;text-transform:uppercase;letter-spacing:.04em}.crm-badge-construction{background:rgba(0,200,117,.133);color:#00c875}.crm-badge-planification{background:rgba(253,171,61,.133);color:#fdab3d}.crm-info-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px;padding:0 16px 12px}.crm-info-card{background:var(--surface2);border:1px solid var(--border);border-radius:var(--radius3);padding:8px 10px}.crm-info-highlight{border-color:var(--brand-mid);background:var(--brand-light)}.crm-info-label{font-size:10px;font-weight:600;color:var(--text3);text-transform:uppercase;margin-bottom:3px}.crm-info-value{font-size:12.5px;font-weight:600;color:var(--text)}.crm-enquete-btn{width:100%;padding:9px;background:linear-gradient(135deg,#6161ff,#a25ddc);color:#fff;border:none;border-radius:var(--radius3);font-weight:600;font-size:13px;cursor:pointer;font-family:var(--font)}.crm-enquete{margin:0 16px 12px;background:var(--surface2);border:1px solid var(--border);border-radius:var(--radius2);padding:12px}.crm-enquete-title{font-size:12px;font-weight:700;color:var(--text);margin-bottom:8px}.crm-enquete-links{display:flex;flex-wrap:wrap;gap:6px}.crm-enq-btn{padding:6px 12px;border-radius:var(--radius3);border:1px solid var(--border);background:var(--surface);color:var(--text2);font-size:11.5px;font-weight:500;cursor:pointer;font-family:var(--font);text-decoration:none;display:inline-block;transition:all var(--transition)}.crm-enq-btn:hover{border-color:var(--brand);color:var(--brand)}.crm-enq-ai{background:var(--brand);color:#fff;border-color:var(--brand)}.crm-enq-ai:hover{background:var(--brand-hover);color:#fff}.crm-divider{height:1px;background:var(--border);margin:4px 0}.crm-section{padding:12px 16px;border-bottom:1px solid var(--border)}.crm-section-title{font-size:12px;font-weight:700;color:var(--text2);text-transform:uppercase;letter-spacing:.05em;margin-bottom:10px}.crm-form-row{margin-bottom:10px}.crm-form-label{display:block;font-size:11px;font-weight:600;color:var(--text3);margin-bottom:4px}.crm-form-input,.crm-form-select,.crm-form-textarea{width:100%;background:var(--surface2);border:1.5px solid var(--border);border-radius:var(--radius3);color:var(--text);padding:7px 10px;font-size:12.5px;font-family:var(--font);outline:none;transition:border-color var(--transition)}.crm-form-input:focus,.crm-form-select:focus,.crm-form-textarea:focus{border-color:var(--brand)}.crm-form-textarea{resize:vertical}.crm-two-col{display:grid;grid-template-columns:1fr 1fr;gap:8px}.crm-mobile-list{flex:1;overflow-y:auto;padding:8px;display:flex;flex-direction:column;gap:8px}@media (min-width: 641px){.crm-tab-mobile-only{display:none}}.crm-inline-edit{width:100%;background:var(--surface);border:1.5px solid var(--brand);border-radius:4px;color:var(--text);padding:3px 6px;font-size:12px;font-family:var(--font);outline:none;box-shadow:0 0 0 2px var(--brand-light)}.crm-log-entry{background:var(--surface2);border:1px solid var(--border);border-radius:var(--radius3);padding:8px 10px;margin-bottom:6px}.crm-log-header{display:flex;justify-content:space-between;margin-bottom:4px}.crm-log-result{font-size:12px;font-weight:600;color:var(--text)}.crm-log-date{font-size:11px;color:var(--text3)}.crm-log-notes{font-size:12px;color:var(--text2)}.crm-source-link{display:block;font-size:11.5px;color:var(--brand);margin-bottom:4px;word-break:break-all}@media (max-width: 600px){.crm-sidebar{display:none}.crm-detail-panel{width:100%;border-left:none}.crm-stats-bar{gap:4px;padding:8px}.crm-stat-pill{padding:3px 7px}.crm-stat-num{font-size:13px}}[data-theme=dark]{--bg: #0f1117;--surface: #1a1d27;--surface2: #22263a;--text: #e8eaf0;--text2: #9699b0;--text3: #5a5d75;--border: #2a2d40;--border2: #3a3d55;--brand-light: #6161ff18;--brand-mid: #6161ff44;--red-light: #e4425818}.settings-section{margin-bottom:14px}.settings-section-title{font-size:10px;font-weight:700;color:var(--text3);text-transform:uppercase;letter-spacing:.08em;margin-bottom:6px;display:flex;align-items:center}.settings-card{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:8px 12px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius2);margin-bottom:4px}.settings-card-info{flex:1;min-width:0}.settings-card-label{font-size:13px;font-weight:600;color:var(--text);margin-bottom:1px}.settings-card-desc{font-size:11px;color:var(--text3);line-height:1.3}.settings-toggle-group{display:flex;gap:6px;flex-shrink:0}.settings-toggle-btn{padding:7px 16px;border-radius:var(--radius3);border:1.5px solid var(--border2);background:var(--surface2);color:var(--text2);font-size:13px;font-weight:500;cursor:pointer;transition:all var(--transition);font-family:var(--font);white-space:nowrap}.settings-toggle-btn:hover:not(.active){border-color:var(--brand);color:var(--brand)}.settings-toggle-btn.active{background:var(--brand);border-color:var(--brand);color:#fff}.settings-toggle-btn:disabled{opacity:.5;cursor:not-allowed}.accent-swatches{display:flex;gap:8px;align-items:center;flex-wrap:wrap}.accent-swatch{width:22px;height:22px;border-radius:50%;border:none;cursor:pointer;transition:all var(--transition);padding:0;flex-shrink:0}.accent-swatch:hover{transform:scale(1.15)}.accent-swatch.active{outline:2.5px solid var(--text);outline-offset:2px}.note-edit-modal{width:min(700px,95vw);height:min(80vh,600px);display:flex;flex-direction:column}.note-edit-textarea{flex:1;resize:none;min-height:300px;font-size:15px;line-height:1.7}@media (max-width: 600px){.note-edit-modal{width:100vw;height:100dvh;border-radius:0;margin:0;position:fixed;top:0;left:0}}.modal{position:fixed;z-index:1001;top:50%;left:50%;transform:translate(-50%,-50%);background:var(--surface);border:1px solid var(--border);border-radius:var(--radius2);box-shadow:0 8px 40px rgba(0,0,0,.25);width:min(520px,95vw);max-height:90vh;display:flex;flex-direction:column;animation:modal-up .15s ease}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid var(--border);flex-shrink:0}.modal-header h3{font-size:15px;font-weight:700;color:var(--text);margin:0}.modal-close{background:none;border:none;color:var(--text3);font-size:16px;cursor:pointer;padding:4px 8px;border-radius:var(--radius3);transition:all var(--transition)}.modal-close:hover{color:var(--text);background:var(--surface2)}.modal-body{padding:20px;overflow-y:auto;flex:1}.modal-footer{display:flex;justify-content:flex-end;gap:8px;padding:14px 20px;border-top:1px solid var(--border);flex-shrink:0}.note-edit-modal{width:min(680px,95vw)}.note-edit-textarea{width:100%;min-height:320px;resize:vertical;font-size:15px;line-height:1.7}@media (max-width: 600px){.modal{position:fixed;top:0;left:0;right:0;width:100%;max-width:100%;max-height:100dvh;transform:none;border-radius:0 0 16px 16px;overflow-y:auto;-webkit-overflow-scrolling:touch}.note-edit-textarea{min-height:200px}.note-modal-textarea{max-height:40dvh;overflow-y:auto!important;min-height:0}}.project-detail{display:flex;flex-direction:column;height:100%;background:var(--bg)}.project-detail-header{display:flex;align-items:center;gap:14px;padding:16px 24px;background:var(--surface);border-bottom:1px solid var(--border);flex-shrink:0;flex-wrap:wrap}.project-detail-title-area{flex:1;min-width:0}.project-job-number{font-size:11px;font-weight:700;color:var(--brand);font-family:monospace;letter-spacing:.05em;background:var(--brand-light);padding:2px 8px;border-radius:999px;border:1px solid var(--brand-mid)}.project-detail-name{font-size:18px;font-weight:700;color:var(--text);margin:4px 0 2px;line-height:1.3}.project-detail-location{font-size:12px;color:var(--text3)}.project-detail-body{flex:1;overflow-y:auto;padding:24px}.project-section-title{font-size:11px;font-weight:700;color:var(--text3);text-transform:uppercase;letter-spacing:.07em;margin-bottom:12px}.project-info-grid{display:flex;flex-direction:column;gap:8px}.project-info-row{display:flex;gap:12px;align-items:flex-start;padding:8px 0;border-bottom:1px solid var(--border);font-size:13px}.project-info-label{font-weight:600;color:var(--text3);min-width:90px;flex-shrink:0}.project-status-row{display:flex;align-items:center;gap:12px;padding:8px 0;border-bottom:1px solid var(--border)}.project-status-row .project-info-label{flex:1}.sp-browser{background:var(--surface2);border:1px solid var(--border);border-radius:var(--radius2);margin-bottom:8px;overflow:hidden}.sp-browser-header{display:flex;align-items:center;gap:8px;padding:8px 12px;background:var(--surface);border-bottom:1px solid var(--border);font-size:13px;font-weight:600;color:var(--text)}.sp-items{max-height:240px;overflow-y:auto}.sp-item{display:flex;align-items:center;gap:10px;padding:8px 12px;border-bottom:1px solid var(--border);cursor:pointer;font-size:13px;color:var(--text2);transition:background var(--transition)}.sp-item:hover{background:var(--surface);color:var(--text)}.teams-section{margin-top:32px}.team-card{display:flex;align-items:center;gap:12px;padding:12px 16px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius2);margin-bottom:8px}.team-color-dot{width:12px;height:12px;border-radius:50%;flex-shrink:0}.team-card-name{font-weight:600;color:var(--text);font-size:14px;flex:1}.team-members-list{font-size:12px;color:var(--text3)}@media (max-width: 1024px){.project-detail-header{padding:12px 16px;gap:10px}.project-detail-body{padding:16px}.project-detail{height:auto;min-height:100%}}@media (max-width: 768px){.crm-stats-bar,.crm-toolbar,.crm-tabs{flex-wrap:nowrap;overflow-x:auto;scrollbar-width:none;-ms-overflow-style:none;-webkit-overflow-scrolling:touch}.crm-stats-bar::-webkit-scrollbar,.crm-toolbar::-webkit-scrollbar,.crm-tabs::-webkit-scrollbar{display:none}.crm-stats-bar,.crm-toolbar{padding:8px 12px}.crm-search{min-width:140px;padding:6px 10px}.crm-stat-total,.crm-stat-pill,.crm-filter-btn,.crm-filter-group{flex-shrink:0}.crm-stat-pill{padding:4px 8px}.crm-stat-num{font-size:14px}.crm-stat-lbl{font-size:9px}}.btn-back{background:none;border:1px solid var(--border);border-radius:var(--radius);padding:6px 12px;font-size:13px;color:var(--text2);cursor:pointer;transition:background .15s}.btn-back:hover{background:var(--surface2)}.tab-btn{background:none;border:none;border-bottom:2px solid transparent;padding:8px 16px;font-size:13px;font-weight:500;color:var(--text2);cursor:pointer;transition:color .15s,border-color .15s}.tab-btn.active{color:var(--accent);border-bottom-color:var(--accent)}.tab-btn:hover:not(.active){color:var(--text)}.tabs{display:flex;overflow-x:auto;border-bottom:1px solid var(--border);margin-bottom:20px;gap:4px;scrollbar-width:none;-ms-overflow-style:none;-webkit-overflow-scrolling:touch}.tabs::-webkit-scrollbar{display:none}.tabs .tab-btn{white-space:nowrap}.tab-content{padding:4px 0}.detail-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:12px;margin-bottom:16px}.detail-field{display:flex;flex-direction:column;gap:4px}.detail-field-span{grid-column:1 / -1}.detail-label{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.04em;color:var(--text3)}.detail-value{font-size:14px;color:var(--text)}.detail-value input,.detail-value select,.detail-value textarea{width:100%}.form-actions{display:flex;gap:8px;margin-top:16px}.form-row{display:flex;flex-direction:column;gap:4px;margin-bottom:12px}.form-row label{font-size:12px;font-weight:600;color:var(--text2)}.form-row-2col{display:grid;grid-template-columns:1fr 1fr;gap:12px}.watcher-list{display:flex;flex-direction:column;gap:8px}.watcher-row{display:flex;align-items:center;gap:12px;padding:8px 12px;background:var(--surface2);border-radius:var(--radius);font-size:14px}.watcher-row span:last-of-type{margin-left:auto}.btn-icon-danger{background:none;border:none;color:var(--danger, #e44258);cursor:pointer;font-size:14px;padding:2px 6px;border-radius:4px;transition:background .15s}.btn-icon-danger:hover{background:rgba(228,66,88,.133)}.row-inactive{opacity:.55}.addr-auto-wrapper{position:relative;width:100%}.addr-auto-dropdown{position:absolute;top:calc(100% + 4px);left:0;right:0;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:0 4px 16px rgba(0,0,0,.18);z-index:200;max-height:240px;overflow-y:auto}.addr-auto-item{display:block;width:100%;text-align:left;background:none;border:none;padding:10px 14px;font-size:13px;color:var(--text);cursor:pointer;line-height:1.4;border-bottom:1px solid var(--border);transition:background .12s}.addr-auto-item:last-child{border-bottom:none}.addr-auto-item:hover{background:var(--surface2)}.home-greeting{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;flex-wrap:wrap;margin-bottom:14px}.home-greeting-text{flex:1;min-width:0}.home-edit-btn{display:inline-flex;align-items:center;gap:6px;padding:7px 12px;border-radius:var(--radius3);border:1px solid var(--border);background:var(--surface);color:var(--text2);font-size:12.5px;font-weight:500;cursor:pointer;transition:background var(--transition),color var(--transition)}.home-edit-btn:hover{background:var(--surface2);color:var(--brand)}.link-btn{background:none;border:none;color:var(--brand);cursor:pointer;font-weight:500;padding:0}.link-btn:hover{text-decoration:underline}.quick-actions-header{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:14px;padding:8px 10px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius3)}.quick-action-chip{display:inline-flex;align-items:center;gap:6px;padding:6px 12px;border-radius:999px;border:1px solid var(--border);background:var(--surface);color:var(--text);font-size:12.5px;font-weight:500;cursor:pointer;transition:background var(--transition),color var(--transition),border-color var(--transition)}.quick-action-chip:hover{background:var(--brand-light);border-color:var(--brand-mid);color:var(--brand)}.widget-grid{display:grid;grid-template-columns:repeat(12,1fr);gap:16px;margin-top:6px}.widget-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius2);padding:14px 16px 12px;display:flex;flex-direction:column;gap:10px;min-height:80px;min-width:0}.widget-card[data-size=small]{grid-column:span 4}.widget-card[data-size=medium]{grid-column:span 8}.widget-card[data-size=large]{grid-column:span 12}.widget-card-head{display:flex;align-items:center;justify-content:space-between;gap:8px}.widget-card-title{display:flex;align-items:center;gap:8px;font-weight:600;font-size:14px;color:var(--text)}.widget-card-icon{color:var(--brand);flex-shrink:0}.widget-card-action{display:flex;align-items:center;gap:6px}.widget-card-body{display:flex;flex-direction:column;gap:8px;min-width:0}.widget-badge{display:inline-flex;align-items:center;justify-content:center;gap:4px;min-width:20px;height:20px;padding:0 8px;border-radius:10px;background:var(--surface3);color:var(--text2);font-size:11px;font-weight:600}.widget-badge-red{background:rgba(228,66,88,.133);color:#e44258}.widget-badge-blue{background:var(--blue-light);color:var(--blue)}.widget-badge-green{background:var(--green-light);color:var(--green)}@media (max-width:1100px){.widget-grid{grid-template-columns:repeat(8,1fr)}.widget-card[data-size=small]{grid-column:span 4}.widget-card[data-size=medium],.widget-card[data-size=large]{grid-column:span 8}}@media (max-width:700px){.widget-grid{grid-template-columns:1fr;gap:12px}.widget-card[data-size]{grid-column:span 1}}.cal-nav{display:flex;align-items:center;gap:4px}.cal-nav-btn{display:inline-flex;align-items:center;justify-content:center;gap:4px;padding:4px 10px;border-radius:var(--radius3);border:1px solid var(--border);background:var(--surface);color:var(--text2);font-size:12px;cursor:pointer;line-height:1}.cal-nav-btn:hover{background:var(--surface2);color:var(--brand)}.cal-nav-today{font-weight:600}.cal-weekdays{display:grid;grid-template-columns:repeat(5,1fr);gap:4px;margin-top:4px}.cal-weekday{text-align:center;font-size:11px;font-weight:600;color:var(--text3);padding:4px 0;text-transform:uppercase;letter-spacing:.4px}.cal-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:4px;transition:opacity .2s}.cal-grid.cal-loading{opacity:.5}.cal-cell{min-height:96px;border:1px solid var(--border);border-radius:var(--radius3);padding:5px 6px;display:flex;flex-direction:column;gap:3px;cursor:pointer;background:var(--surface);transition:background var(--transition),border-color var(--transition);overflow:hidden}.cal-cell:hover{background:var(--surface2);border-color:var(--border2)}.cal-cell-out{background:var(--surface2);color:var(--text3);opacity:.55}.cal-cell-today{border-color:var(--brand);background:var(--brand-light)}.cal-cell-sel{box-shadow:0 0 0 2px var(--brand) inset}.cal-cell-wet{background:linear-gradient(180deg,#e5f4fb 0%,var(--surface) 60%)}.cal-cell-today.cal-cell-wet{background:linear-gradient(180deg,#cfe9f7 0%,var(--brand-light) 60%)}.cal-cell-head{display:flex;justify-content:space-between;align-items:flex-start;gap:4px;font-size:12px}.cal-cell-num{font-weight:600;color:var(--text)}.cal-cell-out .cal-cell-num{color:var(--text3)}.cal-cell-wx{display:inline-flex;align-items:center;gap:3px;font-size:11px;color:var(--text2)}.cal-cell-wx-temp{font-weight:500}.cal-cell-precip{display:inline-flex;align-items:center;gap:3px;font-size:10px;color:var(--blue);font-weight:600}.cal-cell-events{display:flex;flex-direction:column;gap:2px;margin-top:auto;min-width:0}.cal-event-chip{font-size:10.5px;line-height:1.25;padding:2px 5px;border-left:3px solid var(--brand);background:var(--surface2);color:var(--text);border-radius:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.cal-event-more{font-size:10px;color:var(--text3);padding-left:5px}.cal-day-detail{margin-top:10px;padding-top:10px;border-top:1px solid var(--border);display:flex;flex-direction:column;gap:10px}.cal-day-detail-head{display:flex;justify-content:space-between;align-items:center;font-weight:600;font-size:13px;color:var(--text)}.cal-day-section-title{display:inline-flex;align-items:center;gap:6px;font-size:11.5px;font-weight:600;color:var(--text3);text-transform:uppercase;letter-spacing:.3px;margin:4px 0}.cal-day-weather{background:var(--surface2);border:1px solid var(--border);border-radius:var(--radius3);padding:10px 12px;display:flex;flex-direction:column;gap:8px}.cal-day-weather-main{display:flex;align-items:center;gap:10px;color:var(--text)}.cal-day-weather-label{font-size:12px;color:var(--text2);font-weight:500}.cal-day-weather-temp{font-size:20px;font-weight:700;line-height:1}.cal-day-weather-stats{display:flex;flex-wrap:wrap;gap:12px}.cal-wx-stat{display:inline-flex;align-items:center;gap:4px;font-size:12px;color:var(--text2);font-weight:500}.cal-wx-sub{color:var(--text3);font-weight:400}.cal-day-weather-warn{display:inline-flex;align-items:center;gap:6px;font-size:11.5px;color:var(--orange);background:var(--orange-light);border-radius:var(--radius3);padding:5px 8px}.cal-hint{display:inline-flex;align-items:center;gap:6px;margin-top:6px;font-size:11.5px;color:var(--text3);background:var(--surface2);border-radius:var(--radius3);padding:6px 10px}@media (max-width:700px){.cal-cell{min-height:64px;padding:3px 4px}.cal-cell-head{font-size:11px}.cal-cell-wx-temp{display:none}.cal-event-chip{font-size:9.5px;padding:1px 3px}}.home-editor{display:flex;flex-direction:column;max-height:90vh;overflow:hidden}.home-editor-head{display:flex;justify-content:space-between;align-items:center;padding:16px 20px;border-bottom:1px solid var(--border)}.home-editor-section{padding:14px 20px;border-bottom:1px solid var(--border);overflow-y:auto}.home-editor-section:last-of-type{flex:1;border-bottom:none}.home-editor-section-title{font-size:11.5px;font-weight:600;color:var(--text3);text-transform:uppercase;letter-spacing:.4px;margin-bottom:10px}.home-editor-presets{display:grid;grid-template-columns:repeat(auto-fit,minmax(80px,1fr));gap:8px}.home-editor-preset{display:flex;flex-direction:column;align-items:center;gap:4px;padding:10px 6px;border:1px solid var(--border);border-radius:var(--radius3);background:var(--surface);color:var(--text);font-size:12px;font-weight:500;cursor:pointer;transition:background var(--transition),border-color var(--transition)}.home-editor-preset:hover{background:var(--brand-light);border-color:var(--brand-mid)}.home-editor-preset:disabled{opacity:.5;cursor:wait}.home-editor-hint{font-size:11.5px;color:var(--text3);margin-top:8px}.home-editor-list{display:flex;flex-direction:column;gap:6px}.home-editor-row{display:flex;align-items:center;gap:10px;padding:10px 12px;border:1px solid var(--border);border-radius:var(--radius3);background:var(--surface);transition:background var(--transition),opacity var(--transition)}.home-editor-row:hover{background:var(--surface2)}.home-editor-row-hidden{opacity:.55}.home-editor-row-drag{background:var(--brand-light);border-color:var(--brand-mid)}.home-editor-grip{color:var(--text3);cursor:grab;display:flex}.home-editor-icon{display:flex;align-items:center;justify-content:center;width:24px;color:var(--brand)}.home-editor-meta{flex:1;min-width:0}.home-editor-row-title{font-weight:600;font-size:13px;color:var(--text)}.home-editor-row-desc{font-size:11.5px;color:var(--text3);margin-top:1px}.home-editor-row-controls{margin-top:6px;display:flex;gap:6px;flex-wrap:wrap}.home-editor-foot{display:flex;justify-content:flex-end;gap:8px;padding:12px 20px;border-top:1px solid var(--border)}.seg-control{display:inline-flex;border:1px solid var(--border);border-radius:var(--radius3);overflow:hidden;background:var(--surface)}.seg-btn{padding:4px 10px;border:none;background:transparent;color:var(--text2);font-size:11.5px;font-weight:500;cursor:pointer;line-height:1;border-right:1px solid var(--border)}.seg-btn:last-child{border-right:none}.seg-btn:hover{background:var(--surface2);color:var(--brand)}.seg-btn.active{background:var(--brand);color:#fff}.seg-btn.active:hover{background:var(--brand-hover);color:#fff}@keyframes update-banner-in{0%{transform:translateY(-100%);opacity:0}to{transform:translateY(0);opacity:1}}.update-banner{position:fixed;top:0;left:0;right:0;z-index:9000;display:flex;align-items:center;justify-content:space-between;gap:12px;padding:10px 16px;background:var(--brand);color:#fff;box-shadow:var(--shadow2);font-size:13px;animation:update-banner-in .25s ease-out}.update-banner-text{display:flex;flex-direction:column;gap:2px;line-height:1.3}.update-banner-text strong{font-size:13.5px;font-weight:700}.update-banner-text span{opacity:.9;font-size:12px}.update-banner-actions{display:flex;align-items:center;gap:6px;flex-shrink:0}.update-banner-refresh{display:inline-flex;align-items:center;gap:6px;padding:6px 12px;border:none;border-radius:var(--radius2);background:rgba(255,255,255,.18);color:#fff;font-size:12.5px;font-weight:600;cursor:pointer;transition:background var(--transition)}.update-banner-refresh:hover{background:rgba(255,255,255,.3)}.update-banner-dismiss{display:inline-flex;align-items:center;justify-content:center;width:28px;height:28px;border:none;border-radius:var(--radius2);background:transparent;color:#fff;cursor:pointer;opacity:.8;transition:background var(--transition),opacity var(--transition)}.update-banner-dismiss:hover{background:rgba(255,255,255,.18);opacity:1}@media (max-width: 1024px){.update-banner{padding:8px 12px;font-size:12.5px}.update-banner-text strong{font-size:12.5px}.update-banner-text span{font-size:11.5px}}@keyframes toast-in{0%{transform:translate(110%);opacity:0}to{transform:translate(0);opacity:1}}.toast-stack{position:fixed;top:16px;right:16px;z-index:9001;display:flex;flex-direction:column;gap:10px;max-width:360px;pointer-events:none}.toast-item{pointer-events:auto;display:flex;align-items:stretch;background:var(--surface);color:var(--text);border:1px solid var(--border);border-left:3px solid var(--brand);border-radius:var(--radius2);box-shadow:var(--shadow2);overflow:hidden;animation:toast-in .22s ease-out}.toast-body{flex:1;display:flex;align-items:flex-start;gap:10px;padding:10px 12px;background:transparent;border:none;text-align:left;cursor:pointer;color:inherit;font:inherit;min-width:0}.toast-body:hover{background:var(--surface2)}.toast-icon{display:inline-flex;flex-shrink:0;width:28px;height:28px;align-items:center;justify-content:center;border-radius:50%;background:var(--brand-light, rgba(0,0,0,.05));color:var(--brand)}.toast-text{display:flex;flex-direction:column;gap:2px;min-width:0}.toast-title{font-size:13px;font-weight:700;line-height:1.25;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.toast-msg{font-size:12px;color:var(--text2);line-height:1.35;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.toast-dismiss{flex-shrink:0;width:30px;border:none;background:transparent;color:var(--text3);cursor:pointer;border-left:1px solid var(--border);transition:background var(--transition),color var(--transition)}.toast-dismiss:hover{background:var(--surface2);color:var(--text)}@media (max-width: 1024px){.toast-stack{top:8px;left:8px;right:8px;max-width:none}}.task-kanban{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:14px;align-items:start}.task-kanban-col{display:flex;flex-direction:column;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius2);overflow:hidden;min-height:280px}.task-kanban-col-header{display:flex;align-items:center;justify-content:space-between;gap:8px;padding:10px 14px;border-top:3px solid var(--text3);border-bottom:1px solid var(--border);background:var(--surface)}.task-kanban-col-title{font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--text)}.task-kanban-col-count{font-size:11px;font-weight:700;color:var(--text3);background:var(--bg);border:1px solid var(--border);border-radius:999px;padding:2px 8px;min-width:22px;text-align:center}.task-kanban-col-body{flex:1;display:flex;flex-direction:column;gap:8px;padding:10px;min-height:220px;transition:background var(--transition)}.task-kanban-col-body.locked{background:linear-gradient(180deg,transparent,rgba(0,0,0,.02))}.task-kanban-col-body.drop-active{background:var(--brand-light);outline:2px dashed var(--brand);outline-offset:-6px}.task-kanban-empty{font-size:12px;color:var(--text3);text-align:center;padding:18px 10px;font-style:italic}.task-kanban-locked-hint{margin-top:auto;font-size:10px;color:var(--text3);text-align:center;padding-top:8px;opacity:.7}.task-card{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius);padding:10px 12px;display:flex;flex-direction:column;gap:6px;box-shadow:var(--shadow);transition:transform var(--transition),box-shadow var(--transition),border-color var(--transition);user-select:none;touch-action:none}.task-card:hover{border-color:var(--brand);box-shadow:var(--shadow2)}.task-card.overdue{border-left:3px solid var(--red)}.task-card.on_hold{opacity:.6}.task-card-title-row{display:flex;align-items:center;gap:6px;flex-wrap:wrap}.task-card-title{font-size:13px;font-weight:600;color:var(--text);line-height:1.35;word-break:break-word}.task-card-meta{display:flex;align-items:center;gap:8px;flex-wrap:wrap;font-size:11px;color:var(--text2)}@media (max-width: 1024px){.task-kanban{grid-template-columns:1fr}}
