:root{--color-primary:#2563eb;--color-primary-hover:#1d4ed8;--color-primary-light:#eff6ff;--color-success:#16a34a;--color-success-hover:#15803d;--color-success-light:#f0fdf4;--color-warning:#ea580c;--color-warning-hover:#c2410c;--color-warning-light:#fff7ed;--color-danger:#dc2626;--color-danger-hover:#b91c1c;--color-danger-light:#fef2f2;--color-info:#0891b2;--color-info-hover:#0e7490;--color-info-light:#ecfeff;--status-tentative-bg:#fef3c7;--status-tentative-text:#92400e;--status-preferred-bg:#dbeafe;--status-preferred-text:#1e40af;--status-confirmed-bg:#d1fae5;--status-confirmed-text:#065f46;--status-cancelled-bg:#fee2e2;--status-cancelled-text:#991b1b;--color-background:#fff;--color-background-secondary:#f9fafb;--color-background-tertiary:#f3f4f6;--color-border:#e5e7eb;--color-border-hover:#d1d5db;--color-text-primary:#111827;--color-text-secondary:#6b7280;--color-text-tertiary:#9ca3af;--shadow-sm:0 1px 2px 0 #0000000d;--shadow-md:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;--shadow-lg:0 10px 15px -3px #0000001a,0 4px 6px -2px #0000000d;--spacing-xs:.25rem;--spacing-sm:.5rem;--spacing-md:1rem;--spacing-lg:1.5rem;--spacing-xl:2rem;--spacing-2xl:3rem;--radius-sm:.375rem;--radius-md:.5rem;--radius-lg:.75rem;--radius-xl:1rem;--swimlane-row-height:64px;--swimlane-bar-height:48px;--swimlane-track-padding:8px;--swimlane-bar-margin:calc((var(--swimlane-row-height) - var(--swimlane-bar-height))/2);--transition-fast:.15s cubic-bezier(.4,0,.2,1);--transition-base:.2s cubic-bezier(.4,0,.2,1);--transition-slow:.3s cubic-bezier(.4,0,.2,1);--font-size-xs:.75rem;--font-size-sm:.875rem;--font-size-base:1rem;--font-size-lg:1.125rem;--font-size-xl:1.25rem}*{box-sizing:border-box;margin:0;padding:0}body{background:var(--color-background-secondary);color:var(--color-text-primary);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Helvetica,Arial,sans-serif;line-height:1.5}.page,.tm-page{flex-direction:column;height:100dvh;display:flex;overflow:hidden}.page-header{margin-bottom:var(--spacing-lg)}.page-header h1{margin:0 0 var(--spacing-xs);font-size:1.5rem;font-weight:600}.subtitle{align-items:center;gap:var(--spacing-sm);color:var(--color-text-secondary);margin:0;font-size:.95rem;display:flex}.subtitle-link{color:var(--color-primary);cursor:pointer;transition:color var(--transition-fast),text-decoration-color var(--transition-fast);background:0 0;border:none;padding:0;font-weight:600}.subtitle-link:hover:not(:disabled){color:var(--color-primary-hover);text-decoration:underline}.subtitle-link:disabled{color:var(--color-text-tertiary);cursor:not-allowed}.subtitle-separator{color:var(--color-text-tertiary)}.topbar{background:var(--color-background);border-bottom:1px solid var(--color-border);padding:var(--spacing-md)var(--spacing-xl);z-index:100;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#fffffff2;justify-content:space-between;align-items:center;display:flex;position:sticky;top:0}.topbar-left{align-items:center;gap:var(--spacing-md);display:flex}.topbar-title{color:var(--color-text-primary);font-size:1rem;font-weight:600}.topbar-right{align-items:center;gap:var(--spacing-md);display:flex}.topbar-email{color:var(--color-text-secondary);font-size:.875rem}.topbar-btn{padding:var(--spacing-sm)var(--spacing-md);color:var(--color-text-primary);background:var(--color-background);border:1px solid var(--color-border);border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast);align-items:center;gap:var(--spacing-sm);font-size:.875rem;font-weight:500;display:inline-flex}.topbar-btn:hover{background:var(--color-background-tertiary);border-color:var(--color-border-hover)}.topbar-btn:disabled{opacity:.5;cursor:not-allowed}.btn{align-items:center;gap:var(--spacing-sm);padding:var(--spacing-sm)var(--spacing-md);border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast);white-space:nowrap;border:1px solid #0000;font-family:inherit;font-size:.875rem;font-weight:500;display:inline-flex}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:var(--color-primary);color:#fff;border-color:var(--color-primary)}.btn-primary:hover:not(:disabled){background:var(--color-primary-hover);border-color:var(--color-primary-hover);box-shadow:var(--shadow-sm)}.btn-secondary{background:var(--color-background);color:var(--color-text-primary);border-color:var(--color-border)}.btn-secondary:hover:not(:disabled){background:var(--color-background-tertiary);border-color:var(--color-border-hover)}.btn-success{background:var(--color-success);color:#fff;border-color:var(--color-success)}.btn-success:hover:not(:disabled){background:var(--color-success-hover);border-color:var(--color-success-hover);box-shadow:var(--shadow-sm)}.btn-danger{background:var(--color-danger);color:#fff;border-color:var(--color-danger)}.btn-danger:hover:not(:disabled){background:var(--color-danger-hover);border-color:var(--color-danger-hover);box-shadow:var(--shadow-sm)}.btn-ghost{color:var(--color-text-primary);background:0 0;border-color:#0000}.btn-ghost:hover:not(:disabled){background:var(--color-background-tertiary)}.btn-sm{padding:var(--spacing-xs)var(--spacing-sm);font-size:.8125rem}.btn-lg{padding:var(--spacing-md)var(--spacing-lg);font-size:1rem}.submit-btn{justify-content:center;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-sm)var(--spacing-lg);color:#fff;background:linear-gradient(135deg,var(--color-primary)0%,var(--color-primary-hover)100%);border:1px solid var(--color-primary);border-radius:var(--radius-md);cursor:pointer;transition:transform var(--transition-fast),box-shadow var(--transition-fast),background var(--transition-fast);width:100%;font-size:1rem;font-weight:600;display:inline-flex}.submit-btn:hover:not(:disabled){box-shadow:var(--shadow-md);transform:translateY(-1px)}.submit-btn:disabled{opacity:.7;cursor:not-allowed;box-shadow:none}.btn-full{justify-content:center;width:100%}.card{background:var(--color-background);border-radius:var(--radius-lg);transition:all var(--transition-base);border:none;padding:1rem}.card.interactive{cursor:pointer}.card.interactive:hover{border-color:var(--color-primary)}.trip-events{background:var(--color-background);flex:1;max-width:100%;padding-bottom:120px;overflow-y:auto}.trip-content{flex-direction:column;flex:1;display:flex;overflow:hidden}.events-control-bar{margin-bottom:var(--spacing-lg);z-index:50;background:#fff;border:1px solid #e9ecef;border-radius:8px;justify-content:space-between;align-items:center;padding:12px 16px;display:flex;position:sticky;top:72px;box-shadow:0 2px 8px #0000000a}.add-new-dropdown{position:relative}.add-new-dropdown .btn{align-items:center;gap:6px;display:inline-flex}.dropdown-menu{z-index:100;background:#fff;border:1px solid #e9ecef;border-radius:8px;min-width:280px;padding:8px;animation:.15s dropdown-fade-in;position:absolute;top:calc(100% + 8px);right:0;box-shadow:0 4px 16px #0000001f}@keyframes dropdown-fade-in{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.dropdown-item{text-align:left;cursor:pointer;background:0 0;border:none;border-radius:6px;align-items:flex-start;gap:12px;width:100%;padding:12px;transition:background .15s;display:flex}.dropdown-item:hover{background:#f8f9fa}.dropdown-item svg{color:#6c757d;flex-shrink:0;margin-top:2px}.dropdown-item-title{color:#212529;margin-bottom:2px;font-size:14px;font-weight:600}.dropdown-item-desc{color:#6c757d;font-size:12px}.table-view{background:var(--color-background);border:1px solid var(--color-border);border-radius:var(--radius-lg);margin-bottom:24px;overflow:hidden}.form-group{margin-bottom:var(--spacing-lg)}.form-container{max-width:100%;margin:0 auto}.form-group label{margin-bottom:var(--spacing-sm);color:var(--color-text-primary);font-size:.875rem;font-weight:500;display:block}.label-hint{color:var(--color-text-secondary);margin-left:var(--spacing-sm);font-size:.75rem;font-weight:400}.form-group input[type=text],.form-group input[type=email],.form-group input[type=number],.form-group input[type=time],.form-group textarea,.form-group select{width:100%;padding:var(--spacing-sm)var(--spacing-md);color:var(--color-text-primary);background:var(--color-background);border:1px solid var(--color-border);border-radius:var(--radius-md);transition:all var(--transition-fast);font-family:inherit;font-size:.875rem}.form-group input:focus,.form-group textarea:focus,.form-group select:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px var(--color-primary-light);outline:none}.form-group input::placeholder,.form-group textarea::placeholder{color:var(--color-text-tertiary)}.input-hint{margin-top:var(--spacing-xs);color:var(--color-text-secondary);font-size:.8125rem}.form-page-wrapper{flex-direction:column;width:100%;min-height:100%;display:flex}.form-grid{gap:var(--spacing-lg);grid-template-columns:repeat(2,1fr);padding:1rem 1rem 160px;display:grid}@media (max-width:768px){.form-grid{gap:var(--spacing-md);grid-template-columns:1fr}}.expense-form-grid{gap:var(--spacing-lg);grid-template-columns:repeat(2,1fr);padding:.5rem;display:grid}@media (max-width:768px){.expense-form-grid{gap:var(--spacing-md);grid-template-columns:1fr}}.form-row{gap:var(--spacing-md);grid-column:1/-1;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));display:grid}.full-width{grid-column:1/-1}.status-selector{justify-content:center;align-items:center;gap:var(--spacing-sm);flex-wrap:wrap;display:flex}.status-pill{padding:var(--spacing-sm)var(--spacing-lg);border-radius:var(--radius-md);border:2px solid var(--color-border);color:var(--color-text-secondary);cursor:pointer;transition:all var(--transition-fast);background:#fff;min-width:110px;font-size:.9375rem;font-weight:600}.status-pill:hover:not(:disabled){border-color:var(--color-primary);box-shadow:var(--shadow-sm)}.status-pill-active{box-shadow:0 0 0 3px var(--color-primary-light)}.timeline-bar.status-tentative{background:var(--status-tentative-bg);color:var(--status-tentative-text);border-color:var(--status-tentative-text)}.timeline-bar.status-preferred{background:var(--status-preferred-bg);color:var(--status-preferred-text);border-color:var(--status-preferred-text)}.timeline-bar.status-confirmed,.timeline-bar.status-booked{background:var(--status-confirmed-bg);color:var(--status-confirmed-text);border-color:var(--status-confirmed-text)}.timeline-bar.status-location{color:#495057;background:linear-gradient(135deg,#e9ecef 0%,#dee2e6 100%);border-color:#adb5bd;font-weight:600}.timeline-bar.status-location-tentative{color:#6c757d;background:linear-gradient(135deg,#f8f9fa 0%,#e9ecef 100%);border-color:#dee2e6;font-style:italic}.status-tentative.status-pill-active{background:var(--status-tentative-bg);color:var(--status-tentative-text);border-color:var(--status-tentative-text)}.status-preferred.status-pill-active{background:var(--status-preferred-bg);color:var(--status-preferred-text);border-color:var(--status-preferred-text)}.status-confirmed.status-pill-active,.status-booked.status-pill-active{background:var(--status-confirmed-bg);color:var(--status-confirmed-text);border-color:var(--status-confirmed-text)}.status-cancelled.status-pill-active{background:var(--status-cancelled-bg);color:var(--status-cancelled-text);border-color:var(--status-cancelled-text)}@media (max-width:640px){.status-pill{padding:var(--spacing-xs)var(--spacing-md);min-width:95px;font-size:.875rem}.status-selector{gap:var(--spacing-xs)}}.category-selector{grid-template-columns:repeat(4,1fr);gap:6px;display:grid}.category-button{border:1px solid var(--color-border);border-radius:var(--radius-md);background:var(--color-background);cursor:pointer;transition:all var(--transition-fast);text-align:center;flex-direction:column;justify-content:center;align-items:center;gap:2px;min-height:56px;padding:6px;display:flex}.category-button:hover{border-color:var(--color-primary);box-shadow:var(--shadow-sm)}.category-button-active{border-color:var(--color-primary);background:var(--color-primary-light);color:var(--color-primary);box-shadow:var(--shadow-sm)}.category-emoji{justify-content:center;align-items:center;width:20px;height:20px;font-size:1.1rem;display:inline-flex}.category-label{text-align:center;white-space:nowrap;text-overflow:ellipsis;max-width:100%;font-size:.7rem;line-height:1.1;overflow:hidden}.add-return-btn{justify-content:center;align-items:center;gap:var(--spacing-sm);width:100%;padding:var(--spacing-sm)var(--spacing-md);color:var(--color-primary);background:var(--color-primary-light);border:1px dashed var(--color-primary);border-radius:var(--radius-md);cursor:pointer;transition:background var(--transition-fast),border-color var(--transition-fast),transform var(--transition-fast);font-weight:600;display:inline-flex}.add-return-btn:hover:not(:disabled){border-color:var(--color-primary-hover);background:#e0ebff;transform:translateY(-1px)}.add-return-btn:disabled{opacity:.6;cursor:not-allowed}.category-select-wrapper{flex-shrink:0;justify-content:center;align-items:center;width:42px;display:flex;position:relative}.category-icon-preview{pointer-events:none;color:var(--color-text-secondary);justify-content:center;align-items:center;display:flex;position:absolute}.category-select{opacity:0;cursor:pointer;appearance:none;width:100%;height:100%;position:absolute;top:0;left:0}@media (min-width:768px){.category-select-wrapper{width:auto;position:relative}.category-icon-preview{display:none}.category-select{opacity:1;appearance:auto;width:auto;height:auto;padding:var(--spacing-sm)var(--spacing-md);border:1px solid var(--color-border);border-radius:var(--radius-sm);background-color:var(--color-background);position:static}}@media (max-width:767px){.expense-form-grid .form-row{flex-direction:row;align-items:center}.expense-form-grid input#description,.expense-form-grid input#edit-description{width:100%}.category-select-wrapper{border:1px solid var(--color-border);border-radius:var(--radius-sm);background-color:var(--color-background);height:38px}}.badge{align-items:center;gap:var(--spacing-xs);padding:var(--spacing-xs)var(--spacing-sm);border-radius:var(--radius-sm);text-transform:capitalize;font-size:.75rem;font-weight:500;display:inline-flex}.badge-confirmed,.badge-booked{background:var(--color-success-light);color:var(--color-success)}.badge-tentative{background:var(--color-warning-light);color:var(--color-warning)}.badge-cancelled{background:var(--color-danger-light);color:var(--color-danger)}.msg{padding:var(--spacing-md);border-radius:var(--radius-md);margin:var(--spacing-md)0;align-items:center;gap:var(--spacing-sm);font-size:.875rem;display:flex}.msg.ok{background:var(--color-success-light);color:var(--color-success);border:1px solid var(--color-success)}.msg.err{background:var(--color-danger-light);color:var(--color-danger);border:1px solid var(--color-danger)}.main-dashboard{flex:1;width:100%;max-width:1200px;margin:0 auto;overflow-y:hidden}.tm-page{max-width:1200px;padding:var(--spacing-lg);flex-direction:column;flex:1;width:100%;margin:0 auto;display:flex;overflow:hidden}.trip-content{flex:1;overflow-y:auto}.tm-header{margin-bottom:var(--spacing-lg);justify-content:space-between;align-items:flex-start;gap:var(--spacing-md);display:flex}.tm-title{color:var(--color-text-primary);margin-bottom:var(--spacing-xs);font-size:1.6rem;font-weight:600}.tm-subtitle{color:var(--color-text-secondary);font-size:.875rem}.trip-mobile{padding-top:var(--spacing-md)}.trip-compact-header{gap:var(--spacing-sm);margin-bottom:var(--spacing-md);flex-direction:column;display:flex}.trip-navigation{align-items:center;gap:var(--spacing-xs);font-size:var(--font-size-sm);display:flex}.nav-link-btn{color:var(--color-text-secondary);font-size:var(--font-size-sm);cursor:pointer;padding:var(--spacing-xs)var(--spacing-sm);border-radius:var(--radius-sm);transition:all var(--transition-fast);background:0 0;border:none;align-items:center;gap:4px;font-weight:400;display:inline-flex}.nav-link-btn:hover{color:var(--color-primary);background-color:var(--color-primary-light)}.nav-separator{color:var(--color-text-tertiary);font-size:var(--font-size-sm);-webkit-user-select:none;user-select:none}.trip-title-wrap{width:100%}.trip-title-row{align-items:center;gap:var(--spacing-sm);justify-content:space-between;display:flex}.trip-name{color:var(--color-text-primary);align-items:center;gap:var(--spacing-xs);font-size:1.1rem;font-weight:600;display:inline-flex}.trip-subtext{color:var(--color-text-secondary);font-size:.85rem}.icon-btn{border:1px solid var(--color-border);border-radius:var(--radius-sm);cursor:pointer;background:#fff;justify-content:center;align-items:center;padding:6px;display:inline-flex}.icon-btn:hover{background:var(--color-background-tertiary)}.compact-card{padding:var(--spacing-md)}.compact-form .form-group{margin-bottom:var(--spacing-sm)}.share-modal-content{padding:1rem 0}.share-form{margin-bottom:1.5rem}.divider{text-align:center;color:var(--color-text-secondary);align-items:center;margin:1.5rem 0;font-size:.875rem;display:flex}.divider:before,.divider:after{content:"";border-bottom:1px solid var(--color-border);flex:1}.divider span{padding:0 1rem}.share-link-section{margin-top:1rem}.share-link-section label{color:var(--color-text-primary);margin-bottom:.5rem;font-weight:500;display:block}.loading-text{color:var(--color-text-secondary);font-style:italic}.link-input-group{gap:.5rem;margin-bottom:.5rem;display:flex}.link-input{border:1px solid var(--color-border);border-radius:var(--radius-sm);background:var(--color-background-secondary);width:100%;color:var(--color-text-primary);background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%23666' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M10 13a5 5 0 0 0 7.54.54l3-3a5 5 0 0 0-7.07-7.07l-1.72 1.71'%3E%3C/path%3E%3Cpath d='M14 11a5 5 0 0 0-7.54-.54l-3 3a5 5 0 0 0 7.07 7.07l1.71-1.71'%3E%3C/path%3E%3C/svg%3E");background-position:.5rem;background-repeat:no-repeat;background-size:16px;padding:.5rem .5rem .5rem 2rem;transition:all .2s;font-size:.875rem!important}.link-input:focus{border-color:var(--primary-color);background-color:#fff;outline:none;box-shadow:0 0 0 3px #0d6efd1a}.link-input:valid:not(:placeholder-shown){border-color:#28a745}.link-input:invalid:not(:placeholder-shown){border-color:#dc3545}.copy-btn{background:var(--color-primary);color:#fff;border-radius:var(--radius-sm);cursor:pointer;white-space:nowrap;border:none;align-items:center;gap:.25rem;padding:.5rem 1rem;font-size:.875rem;font-weight:500;display:flex}.copy-btn:hover{background:#1d4ed8}.trips-grid{padding-top:var(--spacing-md);gap:var(--spacing-lg);grid-template-columns:repeat(auto-fill,minmax(280px,1fr));display:grid}.trip-card{background:var(--color-background);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--spacing-xl);cursor:pointer;transition:all var(--transition-base);gap:var(--spacing-md);text-align:center;flex-direction:column;align-items:center;display:flex}.trip-card:hover{border-color:var(--color-primary);box-shadow:var(--shadow-md);transform:translateY(-2px)}.trip-card-icon{background:var(--color-primary-light);width:48px;height:48px;color:var(--color-primary);border-radius:var(--radius-md);justify-content:center;align-items:center;display:flex}.trip-card-title{color:var(--color-text-primary);font-size:1.125rem;font-weight:600}.trip-card-info{color:var(--color-text-secondary);align-items:center;gap:var(--spacing-xs);font-size:.875rem;display:flex}.tab-navigation{border-bottom:1px solid var(--color-border);gap:var(--spacing-sm);margin-top:var(--spacing-md);background:#fff;justify-content:space-between;align-items:center;margin-bottom:0;padding:8px 16px;display:flex}.nav-primary-row{align-items:center;gap:var(--spacing-md);display:flex}.nav-secondary-row{align-items:center;display:flex}@media (max-width:640px){.tab-navigation{flex-direction:column;align-items:stretch;gap:12px;height:auto;padding:12px 16px}.nav-primary-row{justify-content:flex-start;width:100%}.nav-primary-row .tab-btn{flex:1;justify-content:center}.section-label{display:none}.nav-primary-row .tm-linear-btn{padding-left:12px;padding-right:12px}.nav-secondary-row{justify-content:start;width:100%}.view-selector{background:#f8f9fa;border-radius:6px;width:100%;padding:2px;display:flex}.view-selector .view-btn{flex:1;justify-content:center}}.tab-btn{color:var(--color-text-tertiary);cursor:pointer;background:0 0;border:none;border-bottom:2px solid #0000;border-radius:0;align-items:center;gap:8px;padding:8px 16px;font-size:.95rem;font-weight:500;transition:all .2s;display:inline-flex}.tab-btn:hover{color:var(--color-text-primary)}.tab-btn.active{color:#000;box-shadow:none;border-bottom:2px solid var(--color-primary);background:#fff;font-weight:600}.tabs-wrapper{flex-direction:column;gap:4px;display:flex}.tabs-row{align-items:center;gap:var(--spacing-xs);display:flex}.section-label{text-transform:uppercase;color:var(--color-text-tertiary);letter-spacing:.05em;margin-left:2px;font-size:.65rem;font-weight:700}.tm-linear-btn{align-items:center;gap:var(--spacing-sm);border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast);white-space:nowrap;background:var(--color-primary);color:#fff;border:1px solid #0000;border-color:var(--color-primary);box-shadow:var(--shadow-sm);margin-left:auto;padding:8px 16px;font-size:.875rem;font-weight:600;display:inline-flex}.tm-linear-btn:hover{background:var(--color-primary-hover);border-color:var(--color-primary-hover);box-shadow:var(--shadow-md);transform:translateY(-1px)}.scrollable-tabs{gap:var(--spacing-xs);align-items:center;width:100%;display:flex;overflow-x:auto}.add-tab-btn{padding:var(--spacing-sm);background:var(--color-primary);color:#fff;border-radius:var(--radius-sm);cursor:pointer;border:none;justify-content:center;align-items:center;display:inline-flex}.add-tab-btn:hover{background:var(--color-primary-hover)}.quick-actions{align-items:center;gap:var(--spacing-sm);margin-bottom:var(--spacing-xl);padding:var(--spacing-md);background:var(--color-background-secondary);border:1px solid var(--color-border);border-radius:var(--radius-md);display:flex}.quick-actions-label{color:var(--color-text-secondary);margin-right:var(--spacing-xs);font-size:.875rem;font-weight:600}.quick-actions .btn.active{background:var(--color-primary);color:#fff;border-color:var(--color-primary)}.quick-actions .btn.active:hover{background:var(--color-primary-hover);border-color:var(--color-primary-hover)}.view-selector{background:var(--color-background);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:var(--spacing-xs);gap:var(--spacing-xs);display:inline-flex}.view-mode-toggle{padding:var(--spacing-xs);margin-bottom:var(--spacing-lg)}.view-btn{padding:var(--spacing-sm)var(--spacing-lg);color:var(--color-text-secondary);border-radius:var(--radius-sm);cursor:pointer;transition:all var(--transition-fast);align-items:center;gap:var(--spacing-sm);background:0 0;border:none;font-size:.875rem;font-weight:500;display:inline-flex}.view-btn:hover{color:var(--color-text-primary);background:var(--color-background-tertiary)}.view-btn.active{color:var(--color-primary);background:var(--color-primary-light)}.table-view{background:var(--color-background);border:1px solid var(--color-border);border-radius:var(--radius-lg);overflow:hidden}.events-table{border-collapse:collapse;table-layout:fixed;width:100%}.events-table thead{background:var(--color-background-secondary);border-bottom:1px solid var(--color-border);z-index:40;position:sticky;top:0}.events-table th{padding:var(--spacing-md)var(--spacing-sm);text-align:left;color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.05em;background:var(--color-background-secondary);font-size:.75rem;font-weight:600}.events-table th:first-child,.events-table td:first-child{width:30%}.events-table th:nth-child(2),.events-table td:nth-child(2){width:25%}.events-table th:nth-child(3),.events-table td:nth-child(3){width:20%}.events-table th:nth-child(4),.events-table td:nth-child(4){text-align:center;width:15%}.events-table th:nth-child(5),.events-table td:nth-child(5){text-align:center;width:10%}.events-table td{padding:var(--spacing-md)var(--spacing-sm);border-bottom:1px solid var(--color-border);vertical-align:middle}.events-table tbody tr{transition:background var(--transition-fast);position:relative}.events-table tbody tr[data-event-type=booking]:before{background:#0d6efd}.events-table tbody tr[data-event-type=flight]:before,.events-table tbody tr[data-event-type=transportation]:before{background:#198754}.events-table tbody tr[data-event-type=event]:before{background:#6f42c1}.events-table tbody tr:hover{background:var(--color-background-secondary)}.events-table tbody tr:last-child td{border-bottom:none}.event-type{color:var(--color-text-primary);white-space:nowrap;align-items:center;gap:var(--spacing-sm);padding-left:8px;font-weight:600;display:flex}.event-type-icon{border-radius:var(--radius-md);background:#0d6efd1a;flex-shrink:0;justify-content:center;align-items:center;width:40px;height:40px;display:flex}.event-type-icon.type-booking{color:#0d6efd;background:#0d6efd1a}.event-type-icon.type-transportation,.event-type-icon.type-flight{color:#198754;background:#1987541a}.event-type-icon.type-event{color:#6f42c1;background:#6f42c11a}.event-details{gap:var(--spacing-sm);align-items:center;min-width:200px;max-width:350px;display:flex}.detail-with-thumbnail{gap:var(--spacing-sm);align-items:center;width:100%;display:flex;overflow:hidden}.detail-thumbnail{border-radius:var(--radius-md);background:var(--color-background-secondary);width:40px;height:40px;color:var(--color-text-secondary);flex-shrink:0;justify-content:center;align-items:center;display:flex}.event-thumbnail{border-radius:var(--radius-md);object-fit:cover;background:var(--color-background-secondary);flex-shrink:0;justify-content:center;align-items:center;width:40px;height:40px;display:flex}.event-thumbnail img{object-fit:cover;border-radius:var(--radius-md);width:100%;height:100%}.event-thumbnail-placeholder{border-radius:var(--radius-md);width:40px;height:40px;color:var(--color-text-secondary);background:#6c757d1a;flex-shrink:0;justify-content:center;align-items:center;display:flex}.event-details-text{flex:1;min-width:0}.detail-main{color:var(--color-text-primary);white-space:nowrap;text-overflow:ellipsis;margin-bottom:2px;font-size:.875rem;font-weight:600;overflow:hidden}.detail-sub{color:var(--color-text-secondary);white-space:nowrap;text-overflow:ellipsis;font-size:.75rem;line-height:1.3;overflow:hidden}.event-date{color:var(--color-text-primary);white-space:nowrap;min-width:140px;font-size:.8125rem}.date-duration{color:var(--color-text-secondary);margin-left:4px;font-size:.7rem;font-weight:400;display:inline}.event-location{color:var(--color-text-secondary);min-width:100px;max-width:150px;font-size:.8125rem}.event-status{text-align:center;flex-direction:column;justify-content:center;align-items:center;gap:4px;min-width:90px;display:flex}.status-badge{text-transform:capitalize;white-space:nowrap;border-radius:12px;align-items:center;padding:3px 10px;font-size:.7rem;font-weight:600;display:inline-flex}.status-badge.status-cancelled{background:var(--status-cancelled-bg);color:var(--status-cancelled-text)}.assigned-to{color:#6b7280;text-align:center;margin-top:2px;font-size:.7rem;font-weight:500}.calendar-view{gap:var(--spacing-xs);flex-direction:column;display:flex}.calendar-month-navigation{align-items:center;gap:var(--spacing-sm);padding:var(--spacing-xs)var(--spacing-md);background:var(--color-background);border:1px solid var(--color-border);border-radius:var(--radius-md);z-index:50;display:flex}.sticky-header{box-shadow:var(--shadow-sm);border-radius:0;border-radius:var(--radius-md);margin-bottom:var(--spacing-xs);position:sticky;top:0}.month-nav-btn{border-radius:var(--radius-sm);width:28px;height:28px;color:var(--color-text-secondary);cursor:pointer;background:0 0;border:none;justify-content:center;align-items:center;transition:all .2s;display:flex}.month-nav-btn:hover{background:var(--color-background-tertiary);color:var(--color-text-primary)}.month-display{display:contents}.month-year{color:var(--color-text-primary);margin:0 var(--spacing-xs);font-size:1rem;font-weight:600}.today-btn{color:var(--color-primary);border:1px solid var(--color-primary);border-radius:var(--radius-sm);cursor:pointer;background:0 0;padding:4px 10px;font-size:.8rem;font-weight:500;transition:all .2s}.today-btn:hover{background:var(--color-primary);color:#fff}.period-card{background:var(--color-background);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--spacing-xl);transition:all var(--transition-base)}.period-card:hover{border-color:var(--color-primary);box-shadow:var(--shadow-md)}.period-header{margin-bottom:var(--spacing-lg);padding-bottom:var(--spacing-lg);border-bottom:1px solid var(--color-border);justify-content:space-between;align-items:flex-start;display:flex}.period-title{gap:var(--spacing-lg);flex:1;align-items:center;display:flex}.period-icon{background:var(--color-primary-light);width:56px;height:56px;color:var(--color-primary);border-radius:var(--radius-lg);justify-content:center;align-items:center;display:flex}.period-title h3{color:var(--color-text-primary);margin-bottom:var(--spacing-xs);font-size:1.25rem;font-weight:600}.period-location{color:var(--color-text-secondary);align-items:center;gap:var(--spacing-xs);font-size:.875rem;display:flex}.period-dates{align-items:flex-end;gap:var(--spacing-sm);flex-direction:column;display:flex}.date-range{color:var(--color-text-primary);white-space:nowrap;font-size:.875rem;font-weight:600}.period-info{background:var(--color-warning-light);border:1px solid var(--color-warning);color:var(--color-warning);padding:var(--spacing-md);border-radius:var(--radius-md);margin-bottom:var(--spacing-lg);align-items:center;gap:var(--spacing-sm);font-size:.875rem;font-weight:500;display:flex}.period-section{margin-top:var(--spacing-lg)}.section-title{color:var(--color-text-secondary);margin-bottom:var(--spacing-md);text-transform:uppercase;letter-spacing:.05em;align-items:center;gap:var(--spacing-sm);font-size:.75rem;font-weight:600;display:flex}.flight-list,.event-list{gap:var(--spacing-md);flex-direction:column;display:flex}.flight-item,.event-item{align-items:center;gap:var(--spacing-md);padding:var(--spacing-md);background:var(--color-background-secondary);border:1px solid var(--color-border);border-radius:var(--radius-md);transition:all var(--transition-fast);display:flex}.flight-item:hover,.event-item:hover{background:var(--color-primary-light);border-color:var(--color-primary)}.flight-icon,.event-icon{background:var(--color-background);border:1px solid var(--color-border);border-radius:var(--radius-md);flex-shrink:0;justify-content:center;align-items:center;width:40px;height:40px;display:flex}.flight-info,.event-info{flex:1}.flight-route{margin-bottom:var(--spacing-xs);color:var(--color-text-primary);font-size:.9375rem;font-weight:600}.flight-details,.event-details-text{color:var(--color-text-secondary);font-size:.8125rem}.event-title{color:var(--color-text-primary);margin-bottom:var(--spacing-xs);font-size:.9375rem;font-weight:600}.expense-header{margin-bottom:var(--spacing-lg);justify-content:space-between;align-items:center;display:flex}.expenses-list{padding-top:var(--spacing-lg);gap:var(--spacing-md);flex-direction:column;display:flex}.expense-item{background:var(--color-background);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--spacing-lg);transition:all var(--transition-fast)}.expense-item:hover{border-color:var(--color-primary);box-shadow:var(--shadow-sm)}.expense-main{margin-bottom:var(--spacing-sm);justify-content:space-between;align-items:flex-start;display:flex}.expense-description{color:var(--color-text-primary);margin-bottom:var(--spacing-xs);font-size:1rem;font-weight:600}.expense-meta{color:var(--color-text-secondary);align-items:center;gap:var(--spacing-sm);font-size:.8125rem;display:flex}.expense-amount{color:var(--color-primary);white-space:nowrap;font-size:1.25rem;font-weight:700}.expense-splits{color:var(--color-text-secondary);padding-top:var(--spacing-sm);border-top:1px solid var(--color-border);font-size:.8125rem}.expense-actions{align-items:center;gap:.25rem;display:flex}.confirmation-modal{text-align:center;padding:1rem}.warning-icon{justify-content:center;margin-bottom:1rem;display:flex}.expense-name{color:var(--color-text-primary);margin:.5rem 0;font-size:1rem;font-weight:600}.warning-text{color:var(--color-danger);margin-bottom:1.5rem;font-size:.875rem}.button-row{justify-content:center;gap:.5rem;display:flex}.btn-danger{background:var(--color-danger);color:#fff;border-radius:var(--radius-md);cursor:pointer;transition:background var(--transition-fast);border:none;padding:.5rem 1.5rem;font-weight:500}.btn-danger:hover:not(:disabled){background:#b91c1c}.btn-danger:disabled{opacity:.6;cursor:not-allowed}.btn-secondary{border:1px solid var(--color-border);border-radius:var(--radius-md);cursor:pointer;color:var(--color-text-primary);transition:all var(--transition-fast);background:0 0;padding:.5rem 1.5rem;font-weight:500}.btn-secondary:hover{background:var(--color-background-secondary)}.balance-summary{background:var(--color-background);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--spacing-xl);margin-bottom:var(--spacing-xl)}.balance-summary h3{color:var(--color-text-primary);margin-bottom:var(--spacing-lg);font-size:1.125rem;font-weight:600}.balance-stat{padding:var(--spacing-md)0;border-bottom:1px solid var(--color-border);justify-content:space-between;align-items:center;display:flex}.balance-stat:last-child{border-bottom:none}.balance-label{color:var(--color-text-secondary);font-size:.875rem;font-weight:500}.balance-value{color:var(--color-text-primary);font-size:1.125rem;font-weight:700}.balance-categories{margin-top:var(--spacing-lg);padding-top:var(--spacing-lg);border-top:1px solid var(--color-border)}.balance-categories h4{color:var(--color-text-primary);margin-bottom:var(--spacing-md);font-size:.875rem;font-weight:600}.category-item{padding:var(--spacing-sm)0;justify-content:space-between;font-size:.875rem;display:flex}.settlements{background:var(--color-background);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--spacing-xl);margin-bottom:var(--spacing-xl)}.settlements h3{color:var(--color-text-primary);margin-bottom:var(--spacing-xs);font-size:1.125rem;font-weight:600}.settlements-subtitle{color:var(--color-text-secondary);margin-bottom:var(--spacing-lg);font-size:.8125rem}.settlements-list{gap:var(--spacing-md);flex-direction:column;display:flex}.settlement-item{align-items:center;gap:var(--spacing-md);padding:var(--spacing-md);background:var(--color-background-secondary);border:1px solid var(--color-border);border-radius:var(--radius-md);display:flex}.settlement-from,.settlement-to{color:var(--color-text-primary);flex:1;font-size:.875rem;font-weight:500}.settlement-arrow{color:var(--color-primary);font-size:1.125rem}.settlement-amount{color:var(--color-primary);white-space:nowrap;font-size:1rem;font-weight:700}.balances{background:var(--color-background);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--spacing-xl)}.balances h3{color:var(--color-text-primary);margin-bottom:var(--spacing-xs);font-size:1.125rem;font-weight:600}.balances-subtitle{color:var(--color-text-secondary);margin-bottom:var(--spacing-lg);font-size:.8125rem}.balances-list{gap:var(--spacing-sm);flex-direction:column;display:flex}.balance-item{padding:var(--spacing-md);background:var(--color-background-secondary);border-radius:var(--radius-md);justify-content:space-between;display:flex}.balance-user{color:var(--color-text-primary);font-size:.875rem;font-weight:500}.balance-amount{font-size:.875rem;font-weight:700}.balance-amount.positive{color:var(--color-success)}.balance-amount.negative{color:var(--color-danger)}.balance-amount.settled{color:var(--color-text-secondary);font-weight:500}.tm-cards-grid{gap:var(--spacing-lg);margin-bottom:var(--spacing-2xl);grid-template-columns:repeat(auto-fill,minmax(260px,1fr));display:grid}.tm-card{background:var(--color-background);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--spacing-xl);cursor:pointer;transition:all var(--transition-base);gap:var(--spacing-md);flex-direction:column;display:flex}.tm-card:hover{border-color:var(--color-primary);box-shadow:var(--shadow-md);transform:translateY(-2px)}.tm-card-icon{background:var(--color-primary-light);width:48px;height:48px;color:var(--color-primary);border-radius:var(--radius-md);justify-content:center;align-items:center;display:flex}.tm-card-title{color:var(--color-text-primary);font-size:1rem;font-weight:600}.tm-card-text{color:var(--color-text-secondary);font-size:.875rem;line-height:1.5}.tm-features{margin-top:var(--spacing-2xl)}.tm-features-title{margin-bottom:var(--spacing-xl);text-align:center;color:var(--color-text-primary);font-size:1.5rem;font-weight:600}.tm-features-grid{gap:var(--spacing-lg);grid-template-columns:repeat(auto-fill,minmax(280px,1fr));display:grid}.tm-feature-item{gap:var(--spacing-md);padding:var(--spacing-lg);background:var(--color-background);border:1px solid var(--color-border);border-radius:var(--radius-md);align-items:flex-start;display:flex}.tm-feature-icon{background:var(--color-primary-light);width:32px;height:32px;color:var(--color-primary);border-radius:var(--radius-sm);flex-shrink:0;justify-content:center;align-items:center;display:flex}.tm-feature-item p{color:var(--color-text-secondary);margin:0;font-size:.875rem;line-height:1.5}.tm-feature-item strong{color:var(--color-text-primary)}.center{text-align:center;justify-content:center;align-items:center;min-height:200px;display:flex}.trip-header-container{padding:var(--spacing-md)var(--spacing-md);background:var(--color-background);justify-content:space-between;align-items:center;display:flex}.trip-compact-header{padding:var(--spacing-md);margin-bottom:0}.trip-header-left-group{align-items:center;gap:var(--spacing-md);display:flex}.trip-title-wrapper{align-items:center;gap:var(--spacing-sm);display:flex}.trip-year-text{color:var(--color-text-secondary);font-size:.9rem;font-weight:500}.desktop-members{color:var(--color-text-secondary);margin-left:var(--spacing-md);font-size:.9rem;display:inline-block}.mobile-members{display:none}.trip-header-right-group{align-items:center;gap:var(--spacing-md);display:flex}.header-actions{align-items:center;gap:var(--spacing-sm);display:flex}@media (max-width:768px){.topbar{gap:var(--spacing-md);flex-direction:column}.topbar-right{justify-content:space-between;width:100%}.tm-page,.main-dashboard{padding:var(--spacing-xs)}.trip-compact-header{padding:var(--spacing-md);margin-bottom:0}.tm-header{flex-direction:column;align-items:stretch}.trips-grid,.tm-cards-grid,.tm-features-grid{grid-template-columns:1fr}.form-grid{grid-template-columns:1fr;padding:.2rem}.expense-form-grid{grid-template-columns:1fr}.table-view{overflow-x:visible}.events-table{width:100%;min-width:100%}.period-header{gap:var(--spacing-md);flex-direction:column}.period-title{text-align:center;flex-direction:column}.period-dates{align-items:flex-start;width:100%}.card{padding:0}.flight-item,.event-item{flex-direction:column;align-items:flex-start}.view-toggle,.tab-navigation{width:100%}.toggle-btn,.tab-btn{flex:1;justify-content:center}}.trip-filter-card{background:#fff;border-radius:8px;flex-wrap:wrap;align-items:center;gap:8px;margin-bottom:20px;padding:12px 16px;display:flex;box-shadow:0 1px 3px #0000001a}.trip-filter-label{color:#495057;font-weight:600}.trip-filter-select{border:1px solid #ced4da;border-radius:6px;min-width:200px;padding:8px 12px;font-size:14px}.trip-filter-current{color:#6c757d;margin-left:8px;font-size:14px}.trip-filter-clear{color:#dc3545;cursor:pointer;background:0 0;border:none;margin-left:8px;font-weight:500}.section-title{color:#212529;align-items:center;margin-top:24px;margin-bottom:12px;font-size:18px;display:flex}.table-wrapper{width:100%;overflow-x:auto}.booking-table{border-collapse:collapse;background:#fff;border-radius:8px;width:100%;margin-top:4px;overflow:hidden;box-shadow:0 1px 3px #0000001a}.booking-table th,.booking-table td{border-bottom:1px solid #e9ecef;padding:12px 16px;font-size:14px}.booking-table th{text-align:left;color:#495057;text-transform:uppercase;letter-spacing:.5px;background:linear-gradient(#f8f9fa,#e9ecef);font-size:12px;font-weight:600}.booking-table tbody tr{transition:background-color .15s}.booking-table tbody tr:hover{background-color:#f1f3f5}.booking-table tbody tr:last-child td{border-bottom:none}.hotel-name{color:#212529;font-weight:500}.date-range{color:#495057;white-space:nowrap}.trip-label{color:#495057;font-weight:500}.status-badge{text-transform:capitalize;cursor:pointer;-webkit-user-select:none;user-select:none;border-radius:16px;padding:6px 14px;font-size:13px;font-weight:600;transition:all .2s;display:inline-block}.status-badge:hover{transform:scale(1.05);box-shadow:0 2px 4px #00000026}.overlap-flag{color:#856404;background:#fff3cd;border:1px solid #ffeeba;border-radius:6px;margin-top:4px;padding:4px 8px;font-size:12px;font-weight:600;display:inline-block}.info-flag{color:#0b5ed7;background:#e7f3ff;border:1px solid #b6d4fe;border-radius:6px;margin-top:4px;margin-right:4px;padding:4px 8px;font-size:12px;font-weight:600;display:inline-block}.assign-trip-btn{color:#2e7d32;cursor:pointer;background:#e8f5e9;border:1px solid #2e7d32;border-radius:6px;padding:6px 12px;font-size:13px;transition:all .15s}.assign-trip-btn:hover{color:#fff;background:#2e7d32}.delete-btn{color:#fff;cursor:pointer;background:#dc3545;border:none;border-radius:4px;padding:6px 14px;font-size:13px;font-weight:500;transition:background-color .15s}.delete-btn:hover{background:#c82333}.add-menu-options{gap:var(--spacing-sm);padding:var(--spacing-sm)0;flex-direction:column;display:flex}.add-menu-btn{align-items:center;gap:var(--spacing-md);background:var(--color-background);border:1px solid var(--color-border);border-radius:var(--radius-lg);color:var(--color-text-primary);text-align:left;cursor:pointer;transition:all var(--transition-fast);padding:16px;font-size:.95rem;font-weight:600;display:flex}.add-menu-btn:hover{background:var(--color-background-secondary);border-color:var(--color-primary);color:var(--color-primary);box-shadow:var(--shadow-sm);transform:translateY(-1px)}.add-menu-btn svg{color:var(--color-text-secondary);opacity:.8}.add-menu-btn:hover svg{opacity:1}.category-grid{gap:var(--spacing-xs);margin-bottom:var(--spacing-md);grid-template-columns:repeat(4,1fr);display:grid}.category-btn{background:var(--color-background);border:2px solid var(--color-border);border-radius:var(--radius-sm);color:var(--color-text-secondary);text-transform:capitalize;cursor:pointer;transition:all var(--transition-fast);flex-direction:column;justify-content:center;align-items:center;gap:4px;min-height:60px;padding:8px 6px;font-size:.75rem;font-weight:500;display:flex}.category-btn svg{width:18px;height:18px}.category-btn span{text-align:center;font-size:.7rem;line-height:1.2}.category-btn:hover{border-color:var(--color-primary);color:var(--color-primary);background:var(--color-primary-light)}.category-btn.active{border-color:var(--color-primary);background:var(--color-primary);color:#fff}@media (max-width:640px){.category-grid{grid-template-columns:repeat(2,1fr);gap:6px}.category-btn{gap:3px;min-height:55px;padding:6px 4px}}.transport-mode-grid{gap:var(--spacing-xs);margin-bottom:var(--spacing-md);grid-template-columns:repeat(4,1fr);display:grid}.transport-mode-groups{gap:var(--spacing-md);flex-direction:column;display:flex}.transport-group-title{color:var(--color-text-secondary);text-transform:uppercase;margin-bottom:var(--spacing-sm);letter-spacing:.5px;font-size:.75rem;font-weight:600}.transport-mode-btn{background:var(--color-background);border:2px solid var(--color-border);border-radius:var(--radius-sm);color:var(--color-text-secondary);text-transform:capitalize;cursor:pointer;transition:all var(--transition-fast);flex-direction:column;justify-content:center;align-items:center;gap:4px;min-height:60px;padding:8px 6px;font-size:.75rem;font-weight:500;display:flex}.transport-mode-btn svg{width:18px;height:18px}.transport-mode-btn span{text-align:center;font-size:.7rem;line-height:1.2}.transport-mode-btn:hover{border-color:var(--color-primary);color:var(--color-primary);background:var(--color-primary-light)}.transport-mode-btn.active{border-color:var(--color-primary);background:var(--color-primary);color:#fff}@media (max-width:640px){.transport-mode-grid{grid-template-columns:repeat(2,1fr);gap:6px}.transport-mode-btn{gap:3px;min-height:55px;padding:6px 4px}.transport-mode-btn svg{width:16px;height:16px}.transport-mode-btn span{font-size:.65rem}}.checkbox-label{align-items:center;gap:var(--spacing-sm);cursor:pointer;font-size:var(--font-size-base);color:var(--color-text-primary);line-height:1;display:inline-flex}.checkbox-label input[type=checkbox]{cursor:pointer;vertical-align:middle;appearance:auto;-webkit-appearance:checkbox;-moz-appearance:checkbox;flex-shrink:0;width:18px;height:18px;margin:0;padding:0}.checkbox-label span{padding-top:1px;padding-left:.5rem;line-height:1.5}.form-actions{gap:var(--spacing-sm);margin-top:var(--spacing-lg);display:flex}.form-actions .btn{flex:1;justify-content:center}.form-actions .btn-primary{background-color:#3b82f6;border-color:#3b82f6}.form-actions .btn-primary:hover:not(:disabled){background-color:#2563eb;border-color:#2563eb}input[type=date],input[type=time]{appearance:none;padding:var(--spacing-sm)var(--spacing-md);border:1px solid var(--color-border);border-radius:var(--radius-md);font-size:var(--font-size-base);color:var(--color-text-primary);background:var(--color-background);transition:border-color var(--transition-fast),box-shadow var(--transition-fast);font-family:inherit;position:relative}input[type=date]:hover,input[type=time]:hover{border-color:var(--color-border-hover)}input[type=date]:focus,input[type=time]:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px var(--color-primary-light);outline:none}input[type=date]::-webkit-calendar-picker-indicator{cursor:pointer;opacity:.6;transition:opacity var(--transition-fast)}input[type=time]::-webkit-calendar-picker-indicator{cursor:pointer;opacity:.6;transition:opacity var(--transition-fast)}input[type=date]::-webkit-calendar-picker-indicator:hover{opacity:1}input[type=time]::-webkit-calendar-picker-indicator:hover{opacity:1}.input-hint{margin-top:var(--spacing-xs);font-size:var(--font-size-sm);color:var(--color-text-secondary)}.date-quick-select{gap:var(--spacing-xs);margin-top:var(--spacing-xs);flex-wrap:wrap;display:flex}.date-quick-btn{color:var(--color-text-secondary);background:var(--color-background-secondary);border:1px solid var(--color-border);border-radius:var(--radius-sm);cursor:pointer;transition:all var(--transition-fast);white-space:nowrap;padding:4px 10px;font-size:.75rem;font-weight:500}.date-quick-btn:hover{color:var(--color-primary);background:var(--color-primary-light);border-color:var(--color-primary)}.btn-icon{cursor:pointer;border-radius:var(--radius-sm);transition:all var(--transition-fast);background:0 0;border:none;justify-content:center;align-items:center;padding:4px 8px;font-size:1.2rem;display:inline-flex}.btn-icon:hover{background:var(--color-background-secondary);transform:scale(1.1)}.btn-icon:active{transform:scale(.95)}.btn-edit:hover{background:var(--color-info-light)}.btn-delete:hover{background:var(--color-error-light)}.btn-icon:disabled{opacity:.5;cursor:not-allowed;transform:none}.btn-icon:disabled:hover{background:0 0;transform:none}.event-actions{justify-content:flex-end;align-items:center;gap:4px;width:80px;min-width:80px;display:flex}@media (max-width:768px){.page{padding:0}.transport-mode-grid{grid-template-columns:repeat(2,1fr)}.form-row{grid-template-columns:1fr!important}.form-actions{flex-direction:column}.form-actions .btn{width:100%}.tm-cards-grid{gap:var(--spacing-md);grid-template-columns:1fr!important}.topbar{display:none}.trip-mobile{padding-top:0}.trip-compact-header{background:var(--color-background);flex-direction:column;gap:12px;margin-bottom:20px;display:flex}.trip-header-row-1{align-items:center;gap:12px;display:flex}.trip-header-row-2{justify-content:space-between;align-items:center;padding-left:28px;display:flex}.trip-header-row-2-left{color:var(--color-text-secondary);align-items:center;gap:8px;font-size:.9rem;display:flex}.trip-header-row-2-right{align-items:center;gap:8px;display:flex}.trip-members-count{background:var(--color-background-secondary);border-radius:16px;align-items:center;gap:6px;padding:4px 10px;font-size:.85rem;font-weight:500;display:flex}.trip-events{padding:0}.trip-events>div:first-child{align-items:stretch!important;gap:var(--spacing-md)!important;flex-direction:column!important}.trip-events>div:first-child>div,.view-selector{width:100%}.view-selector button{flex:1}.trip-events>div:first-child>div:last-child{gap:var(--spacing-xs);grid-template-columns:repeat(2,1fr);display:grid!important}.booking-table{font-size:.875rem}.booking-table th,.booking-table td{padding:var(--spacing-sm)}.events-table{font-size:.875rem}.events-table th,.events-table td{padding:var(--spacing-sm)var(--spacing-sm)}.events-table .event-status{min-width:70px}.events-table .event-actions{white-space:nowrap;min-width:70px}.events-table .event-details{min-width:0;max-width:100px}.assigned-to{font-size:.65rem}.period-card{padding:var(--spacing-md)}.period-header{gap:var(--spacing-sm);flex-direction:column;align-items:flex-start!important}input[type=text],input[type=email],input[type=password],input[type=date],input[type=time],input[type=number],input[type=url],select,textarea{min-height:44px;font-size:16px}.toggle-btn,.tab-btn{flex:1;justify-content:center;min-height:44px}}@media (max-width:480px){.transport-mode-grid{grid-template-columns:repeat(2,1fr)}.trip-events>div:first-child>div:last-child{grid-template-columns:1fr}.form-group label{font-size:.875rem}h1{font-size:1.25rem}h2{font-size:1.125rem}h3{font-size:1rem}}.settings-page{height:100%;overflow-y:auto}.settings-page .card{padding:var(--spacing-2xl);max-width:800px;margin:var(--spacing-xl)auto}.settings-page h2{color:var(--color-text-primary);margin-bottom:var(--spacing-xl);font-size:1.75rem;font-weight:600}.settings-page h3{color:var(--color-text-primary);margin-bottom:var(--spacing-md);font-size:1.125rem;font-weight:600}.settings-page .form-grid{margin-bottom:var(--spacing-lg);padding:0}.settings-page .divider{margin:var(--spacing-2xl)0}.settings-page .settings-section{margin-bottom:var(--spacing-xl)}.settings-page .settings-section:last-of-type{margin-bottom:0}.settings-page .settings-section .input-hint{margin-bottom:var(--spacing-md)}.settings-page .settings-section.danger{padding:var(--spacing-lg);background:var(--color-danger-light);border:1px solid var(--color-danger);border-radius:var(--radius-md)}@media (max-width:768px){.settings-page .card{padding:var(--spacing-lg);margin:var(--spacing-md);padding-bottom:120px}.settings-page h2{margin-bottom:var(--spacing-lg);font-size:1.5rem}}.expense-section{border-top:1px solid var(--color-border);width:100%}.expense-accordion-header{width:100%;padding:var(--spacing-md);background:var(--color-background-secondary);border-radius:var(--radius-md);cursor:pointer;color:var(--color-text-primary);transition:all var(--transition-fast);margin-top:var(--spacing-lg);border:none;justify-content:space-between;align-items:center;font-size:.9375rem;font-weight:500;display:flex}.expense-accordion-header:hover{background:var(--color-background-tertiary)}.expense-accordion-content{padding-top:var(--spacing-md)}.split-type-selector{gap:var(--spacing-sm);flex-wrap:wrap;display:flex}.split-type-btn{padding:var(--spacing-sm)var(--spacing-md);border:1px solid var(--color-border);border-radius:var(--radius-md);background:var(--color-background);color:var(--color-text-secondary);font-size:var(--font-size-sm);cursor:pointer;transition:all var(--transition-fast)}.split-type-btn:hover{border-color:var(--color-border-hover);background:var(--color-background-tertiary)}.split-type-btn.active{background:var(--color-primary);color:#fff;border-color:var(--color-primary)}.split-inputs{gap:var(--spacing-sm);flex-direction:column;display:flex}.split-input-row{gap:var(--spacing-sm);padding:var(--spacing-sm);border:1px solid var(--color-border);border-radius:var(--radius-sm);background:var(--color-background-secondary);grid-template-columns:1fr auto auto;align-items:center;display:grid}.split-member-name{font-size:var(--font-size-sm);color:var(--color-text-primary);font-weight:500}.split-input{width:120px;padding:var(--spacing-xs)var(--spacing-sm);border:1px solid var(--color-border);border-radius:var(--radius-sm);font-size:var(--font-size-sm)}.split-calculated{font-size:var(--font-size-sm);color:var(--color-text-secondary);text-align:right;min-width:100px;font-weight:500}.modal-overlay{z-index:1000;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);background:#11182780;justify-content:center;align-items:center;padding:16px;display:flex;position:fixed;inset:0}.modal-content{background:var(--color-background);border-radius:var(--radius-lg);border:1px solid var(--color-border);flex-direction:column;width:100%;max-height:90vh;margin:auto;display:flex;overflow:hidden;box-shadow:0 20px 60px #0000002e}@media (max-width:640px){.modal-content{border-radius:var(--radius-lg);width:92%;max-width:500px;height:auto;max-height:85vh;margin:auto}.modal-content.modal-sm{width:90%;max-width:400px;max-height:80vh;box-shadow:0 4px 20px #0003}.modal-overlay{align-items:center;padding:8px}.modal-body{scrollbar-width:none;-ms-overflow-style:none}.modal-body::-webkit-scrollbar{display:none}}.modal-sm{max-width:520px}.modal-md{max-width:720px}.modal-lg{max-width:900px}.modal-xl{max-width:1040px}.modal-header{border-bottom:1px solid var(--color-border);background:var(--color-background-secondary);justify-content:space-between;align-items:center;padding:18px 20px;display:flex}.modal-title{color:var(--color-text-primary);margin:0;font-size:20px}.modal-close-btn{cursor:pointer;color:var(--color-text-secondary);background:0 0;border:none;border-radius:999px;padding:6px;transition:background .15s,color .15s}.modal-close-btn:hover{background:var(--color-background-tertiary);color:var(--color-text-primary)}.modal-body{flex:1;min-height:0;padding:10px;overflow-y:auto}.bottom-sheet-overlay{z-index:1100;background:#11182766;justify-content:center;align-items:flex-end;display:flex;position:fixed;inset:0}.bottom-sheet{background:#fff;border-radius:16px 16px 0 0;width:100%;max-width:480px;padding:16px;box-shadow:0 -6px 30px #0000002e}@media (min-width:768px){.bottom-sheet-overlay{align-items:center}.bottom-sheet{border-radius:var(--radius-xl);box-shadow:var(--shadow-lg)}.modal-overlay{padding:24px}}.bottom-sheet-header{color:var(--color-text-primary);justify-content:space-between;align-items:center;margin-bottom:12px;font-weight:600;display:flex}.bottom-sheet-options{gap:8px;display:grid}.sheet-option{border:1px solid var(--color-border);border-radius:var(--radius-md);background:var(--color-background);text-align:left;cursor:pointer;width:100%;padding:12px 14px;font-weight:600}.sheet-option:hover{border-color:var(--color-primary);color:var(--color-primary)}.timeline-view{scrollbar-width:none;-ms-overflow-style:none;background:#fff;border-radius:12px;min-height:400px;padding:12px 0 24px;overflow:auto}.timeline-view::-webkit-scrollbar{display:none}.timeline-header{z-index:20;background:#fff;border-bottom:2px solid #e9ecef;padding-bottom:12px;display:flex;position:sticky;top:0}.timeline-header-spacer{z-index:25;border-right:1px solid var(--color-border);background:#fff;flex-direction:column;flex-shrink:0;justify-content:center;align-items:center;gap:8px;width:150px;padding:0 4px;display:flex;position:sticky;left:0}.header-controls{padding-bottom:4px}.compact-month-nav{align-items:center;gap:4px;display:flex}.month-year-inv{color:var(--color-text-primary);text-align:center;min-width:80px;font-size:.8rem;font-weight:600}.today-btn-sm{border:1px solid var(--color-border);background:var(--color-background-secondary);border-radius:var(--radius-sm);cursor:pointer;text-align:center;width:100%;padding:2px 8px;font-size:.75rem}.today-btn-sm:hover{background:var(--color-background-tertiary);border-color:var(--color-text-tertiary)}.timeline-labels{z-index:15;flex:1;min-width:0;height:50px;padding-left:20px;position:relative;overflow-x:visible}.timeline-date-label{flex-direction:column;align-items:center;gap:2px;min-width:40px;display:flex;position:absolute}.date-label-day{color:#212529;font-size:16px;font-weight:600}.date-label-month{text-transform:uppercase;color:#6c757d;letter-spacing:.5px;font-size:11px}.timeline-body{flex-direction:column;display:flex}.timeline-swimlane{min-height:var(--swimlane-row-height);border-bottom:1px solid #f1f3f5;width:100%;display:flex}.swimlane-label{color:#495057;z-index:20;background:#fff;border-right:2px solid #e9ecef;flex-shrink:0;align-items:center;gap:8px;width:150px;padding:8px;font-size:14px;font-weight:600;display:flex;position:sticky;left:0}.swimlane-icon{flex-shrink:0;align-items:center;display:flex}.swimlane-label>span:not(.swimlane-icon){text-overflow:ellipsis;white-space:nowrap;flex:1;min-width:0;overflow:hidden}.swimlane-track{min-height:var(--swimlane-row-height);padding:var(--swimlane-track-padding)0;background:linear-gradient(90deg,#f8f9fa 0%,#0000 1px) 0 0/64px 100%;flex:1;position:relative}.swimlane-track.has-overlaps{padding:var(--swimlane-track-padding)0}.timeline-bar{height:var(--swimlane-bar-height);margin:var(--swimlane-bar-margin)0;border:2px solid #0000;border-radius:6px;align-items:center;display:flex;position:absolute;box-shadow:0 2px 4px #0000001a}.timeline-bar:hover{z-index:5;transform:translateY(-2px);box-shadow:0 4px 8px #00000026}.timeline-bar:active{cursor:grabbing}.bar-content{z-index:2;flex-direction:column;justify-content:center;align-items:flex-start;gap:1px;width:fit-content;max-width:100%;padding-left:4px;display:flex;position:sticky;left:150px}.bar-top-row{opacity:.85;align-items:center;gap:4px;font-size:11px;display:flex}.bar-top-row .bar-icon{flex-shrink:0}.bar-top-row .bar-time{white-space:nowrap}.bar-label{-webkit-line-clamp:1;line-clamp:1;text-overflow:ellipsis;-webkit-box-orient:vertical;font-size:12px;font-weight:600;line-height:1.3;display:-webkit-box;overflow:hidden}.status-confirmed:hover,.status-booked:hover{box-shadow:0 4px 12px #065f464d}.status-tentative:hover{box-shadow:0 4px 12px #92400e4d}.status-preferred:hover{box-shadow:0 4px 12px #1e40af4d}.status-cancelled{background:var(--status-cancelled-bg);color:var(--status-cancelled-text);border-color:var(--status-cancelled-text)}.status-cancelled:hover{box-shadow:0 4px 12px #991b1b4d}.status-pending{color:#fff;background:linear-gradient(135deg,#6c757d 0%,#5a6268 100%);border-color:#545b62}.status-pending:hover{border-color:#6c757d;box-shadow:0 4px 12px #6c757d4d}.status-default{color:#fff;background:linear-gradient(135deg,#0d6efd 0%,#0b5ed7 100%);border-color:#0a58ca}.location-bar{color:#495057;opacity:.9;cursor:default;pointer-events:none;background:linear-gradient(135deg,#e9ecef 0%,#dee2e6 100%);border-color:#adb5bd;font-weight:600}.swimlane-icon{margin-right:var(--spacing-xs);align-items:center;display:inline-flex}.swimlane-location .swimlane-label{opacity:.85;font-style:italic}.timeline-warning{height:var(--swimlane-bar-height);cursor:pointer;pointer-events:auto;z-index:10;border:2px solid #0000;border-radius:6px;align-items:center;padding:0 16px;transition:transform .2s;display:flex;position:absolute;box-shadow:0 2px 4px #0000001a}.timeline-warning:hover{transform:scale(1.05)}.warning-gap{border-radius:var(--radius-sm);background:repeating-linear-gradient(45deg,#ffc10726,#ffc10726 10px,#ff980026 10px 20px);border:2px dashed #ff9800}.warning-gap svg{color:#ff9800;filter:drop-shadow(0 2px 4px #ff98004d)}.warning-overlap{border-radius:var(--radius-sm);pointer-events:auto;box-shadow:none;background:0 0;border:2px dashed #ff4500;align-items:flex-start;padding:0}.warning-overlap svg{color:#ff4500;filter:drop-shadow(0 1px 2px #0000001a);z-index:10;background:#fff;border:1px solid #ff4500;border-radius:50%;width:20px;height:20px;padding:2px;position:absolute;top:-14px;left:-8px}.warning-popover{z-index:1000;background:#fff;border:none;border-radius:16px;flex-direction:column;gap:10px;min-width:240px;max-width:320px;padding:16px;animation:.15s ease-out popoverFadeIn;display:flex;position:fixed;transform:translate(-50%);box-shadow:0 4px 6px -1px #00000012,0 10px 20px -2px #0000001a,0 0 0 1px #0000000d}.warning-popover:before{content:"";background:#fff;border-radius:2px;width:12px;height:12px;position:absolute;top:-6px;left:50%;transform:translate(-50%)rotate(45deg);box-shadow:-2px -2px 4px #0000000a}.warning-popover>.btn-sm{padding:var(--spacing-xs)var(--spacing-sm);width:100%;font-size:.875rem}.warning-popover-header{text-transform:uppercase;letter-spacing:.05em;color:var(--color-warning,#f59e0b);border-bottom:1px solid #0000000f;padding-bottom:8px;font-size:.75rem;font-weight:600}.warning-popover-item{border-bottom:1px solid #0000000a;justify-content:space-between;align-items:center;gap:12px;padding:8px 0;display:flex}.warning-popover-item:last-child{border-bottom:none;padding-bottom:0}.warning-item-info{flex:1;align-items:center;gap:8px;min-width:0;display:flex}.warning-item-title{color:var(--text-color);text-overflow:ellipsis;white-space:nowrap;font-size:.9rem;font-weight:500;overflow:hidden}.warning-item-mode{color:var(--text-muted,#666);flex-shrink:0;align-items:center;display:flex}.warning-item-mode svg{width:16px;height:16px}.warning-item-actions{flex-shrink:0;gap:6px;display:flex}.warning-item-actions .btn{justify-content:center;align-items:center;min-width:0;padding:6px 10px;display:flex}.warning-item-actions .btn-primary{background:#3b82f6;border-color:#3b82f6}.warning-item-actions .btn-primary:hover:not(:disabled){background:#2563eb;border-color:#2563eb}.warning-item-actions .btn-danger{background:#ef4444;border-color:#ef4444}.warning-item-actions .btn-danger:hover:not(:disabled){background:#dc2626;border-color:#dc2626}.summary-popover{z-index:1000;background:#fff;border:none;border-radius:16px;flex-direction:column;gap:12px;min-width:240px;max-width:320px;padding:16px;animation:.15s ease-out popoverFadeIn;display:flex;position:fixed;transform:translate(-50%);box-shadow:0 4px 6px -1px #00000012,0 10px 20px -2px #0000001a,0 0 0 1px #0000000d}.summary-popover-upward{animation:.15s ease-out popoverFadeInUpward}@keyframes popoverFadeIn{0%{opacity:0;transform:translate(-50%)translateY(4px)}to{opacity:1;transform:translate(-50%)translateY(0)}}@keyframes popoverFadeInUpward{0%{opacity:0;transform:translate(-50%)translateY(-4px)}to{opacity:1;transform:translate(-50%)translateY(0)}}.summary-popover:before{content:"";background:#fff;border-radius:2px;width:12px;height:12px;position:absolute;top:-6px;left:50%;transform:translate(-50%)rotate(45deg);box-shadow:-2px -2px 4px #0000000a}.summary-popover-upward:before{top:auto;bottom:-6px;box-shadow:2px 2px 4px #0000000a}.summary-header{justify-content:space-between;align-items:flex-start;gap:12px;display:flex}.summary-header-text{flex-direction:column;flex:1;gap:6px;min-width:0;display:flex}.summary-title{color:var(--text-color);font-size:1.05rem;font-weight:600;line-height:1.3}.summary-type{text-transform:uppercase;letter-spacing:.06em;color:var(--primary-color);background:#0d6efd14;border-radius:4px;width:fit-content;padding:3px 8px;font-size:.65rem;font-weight:600;display:inline-block}.summary-actions{flex-shrink:0;gap:6px;display:flex}.summary-actions .btn{justify-content:center;align-items:center;min-width:0;padding:6px 10px;display:flex}.summary-actions .btn-sm{font-size:.8rem}.summary-actions .btn-primary{background:#3b82f6;border-color:#3b82f6}.summary-actions .btn-primary:hover:not(:disabled){background:#2563eb;border-color:#2563eb}.summary-actions .btn-danger{background:#ef4444;border-color:#ef4444}.summary-actions .btn-danger:hover:not(:disabled){background:#dc2626;border-color:#dc2626}.summary-rows{border-top:1px solid #0000000f;flex-direction:column;gap:8px;padding-top:12px;display:flex}.summary-row{justify-content:space-between;align-items:center;gap:16px;font-size:.8rem;display:flex}.summary-label{color:var(--text-muted);flex:none;font-weight:500}.summary-value{text-align:right;color:var(--text-color);text-overflow:ellipsis;white-space:nowrap;flex:1;font-weight:500;overflow:hidden}.autocomplete-wrapper{width:100%;position:relative}.autocomplete-suggestions{border:1px solid var(--border-color);border-radius:0 0 var(--radius-md)var(--radius-md);z-index:1000;background:#fff;border-top:none;max-height:200px;margin:0;padding:0;list-style:none;position:absolute;top:100%;left:0;right:0;overflow-y:auto;box-shadow:0 4px 12px #0000001a}.autocomplete-suggestion-item{padding:var(--spacing-sm)var(--spacing-md);cursor:pointer;border-bottom:1px solid var(--border-color);transition:background-color .2s}.autocomplete-suggestion-item:last-child{border-bottom:none}.autocomplete-suggestion-item:hover{background-color:var(--primary-color);color:#fff}.timeline-bar[draggable=true]{cursor:grab}.timeline-bar.dragging{opacity:.5;cursor:grabbing}.swimlane-track.drag-over{background-color:#0d6efd0d;border:2px dashed #0d6efd;border-radius:6px}@media (max-width:768px){.timeline-view{padding:16px}.swimlane-label{width:60px;padding:8px 4px;font-size:12px}.timeline-header-spacer{width:60px}.swimlane-label>span:not(.swimlane-icon){display:none}.swimlane-icon{margin:0 auto}.calendar-month-navigation{padding:var(--spacing-sm)var(--spacing-md);gap:var(--spacing-sm)}.month-display{gap:var(--spacing-xs);flex-direction:column;align-items:center}.month-year{font-size:1rem}.today-btn{padding:var(--spacing-xs)var(--spacing-sm);font-size:.75rem}.month-nav-btn{width:36px;height:36px}.timeline-bar{height:32px}.bar-label{font-size:11px}.date-label-day{font-size:14px}.date-label-month{font-size:10px}.events-table th:nth-child(3),.events-table td:nth-child(3),.events-table th:nth-child(4),.events-table td:nth-child(4){display:none}.events-table th,.events-table td{box-sizing:border-box;font-size:.7rem;padding:var(--spacing-sm)var(--spacing-sm)!important}.events-table th{font-size:.65rem}.events-table th:first-child,.events-table td:first-child{width:50%!important}.events-table th:nth-child(2),.events-table td:nth-child(2){width:35%!important}.events-table th:nth-child(5),.events-table td:nth-child(5){text-align:center;width:15%!important}.events-table .event-date{font-size:.75rem;line-height:1.3}.events-table .detail-sub{display:none}.events-table .event-status{min-width:0}.events-table .event-status .assigned-to{display:none}.events-table .event-actions{min-width:0;padding:4px}}.event-info-modal{padding:var(--spacing-sm)}.info-header{align-items:center;display:flex}.info-header h3{color:var(--color-text-primary);margin:0;font-size:1.25rem;font-weight:600}.info-section{gap:var(--spacing-md);margin-bottom:var(--spacing-lg);grid-template-columns:1fr 1fr;display:grid}.info-row{gap:var(--spacing-lg);padding:var(--spacing-sm)var(--spacing-sm);border-radius:var(--radius-sm);transition:background var(--transition-fast);grid-template-columns:24px 140px 1fr;align-items:center;display:grid}.info-row:hover{background:var(--color-background-secondary)}.info-row>svg{color:var(--color-text-secondary);flex-shrink:0}.info-label{color:var(--color-text-secondary);font-size:.875rem;font-weight:400}.info-value{color:var(--color-text-primary);word-break:break-word;font-size:.875rem;font-weight:500}.info-actions{justify-content:center;gap:var(--spacing-md);padding-top:var(--spacing-md);border-top:1px solid var(--color-border);display:flex}.info-actions .btn{justify-content:center;align-items:center;gap:var(--spacing-sm);min-width:120px;max-width:180px;padding:var(--spacing-sm)var(--spacing-lg);flex:0 auto;font-size:.875rem;display:flex}.info-actions .btn-primary{background:#3b82f6;border-color:#3b82f6}.info-actions .btn-primary:hover:not(:disabled){background:#2563eb;border-color:#2563eb}.info-actions .btn-danger{background:#ef4444;border-color:#ef4444}.info-actions .btn-danger:hover:not(:disabled){background:#dc2626;border-color:#dc2626}.btn-info{color:var(--color-primary);cursor:pointer;padding:var(--spacing-xs);border-radius:var(--radius-sm);transition:all var(--transition-fast);background:0 0;border:none}.btn-info:hover{background:var(--color-primary-light)}@media (max-width:768px){.info-section{grid-template-columns:1fr}.info-row{gap:var(--spacing-md);grid-template-columns:20px auto 1fr}.info-label{white-space:nowrap}.info-value{text-align:left}}.table-row{transition:background var(--transition-fast);position:relative}.table-row[data-event-type=booking]:before{background:#0d6efd}.table-row[data-event-type=flight]:before,.table-row[data-event-type=transportation]:before{background:#198754}.table-row[data-event-type=event]:before{background:#6f42c1}.table-row:hover{background:var(--color-background-secondary)}.row-cell{padding:var(--spacing-md)var(--spacing-sm);border-bottom:1px solid var(--color-border);vertical-align:middle}.row-cell-details{width:30%}.row-cell-date{width:25%}.row-cell-location{width:20%}.row-cell-status{text-align:center;width:15%}.row-cell-actions{text-align:center;width:10%}.row-detail-wrapper{align-items:center;gap:var(--spacing-sm);max-width:100%;display:flex}.row-icon{background:var(--color-background-secondary);border-radius:var(--radius-md);width:40px;height:40px;color:var(--color-text-secondary);flex-shrink:0;justify-content:center;align-items:center;display:flex}.row-text{flex:1;min-width:0;overflow:hidden}.row-title{color:var(--color-text-primary);white-space:nowrap;text-overflow:ellipsis;margin-bottom:2px;font-size:.875rem;font-weight:600;overflow:hidden}.row-subtitle{color:var(--color-text-secondary);white-space:nowrap;text-overflow:ellipsis;font-size:.75rem;line-height:1.3;overflow:hidden}.row-assigned{color:var(--color-text-secondary);margin-top:4px;font-size:.65rem}.status-cell-content{justify-content:center;align-items:center;gap:var(--spacing-xs);display:flex}.status-dot{border-radius:50%;flex-shrink:0;width:10px;height:10px;display:inline-block}.status-dot.status-confirmed,.status-dot.status-booked{background-color:var(--status-confirmed-text)}.status-dot.status-preferred{background-color:var(--status-preferred-text)}.status-dot.status-tentative{background-color:var(--status-tentative-text)}.status-dot.status-cancelled{background-color:var(--status-cancelled-text)}.status-dot-mobile{display:none}.actions-cell-content{justify-content:center;align-items:center;gap:var(--spacing-xs);display:flex}.date-range{flex-wrap:wrap;align-items:center;gap:4px;display:flex}.date-separator{color:var(--color-text-secondary);font-size:.875rem}.date-duration{color:var(--color-text-secondary);white-space:nowrap;font-size:.75rem}@media (max-width:768px){.row-cell-location,.row-cell-status{display:none}.row-cell-details{width:50%;min-width:0;max-width:none}.row-cell-date{width:35%;font-size:.7rem;line-height:1.2}.row-cell-actions{width:15%;min-width:0;max-width:none}.events-table .event-details{min-width:0!important;max-width:none!important}.events-table .event-status,.events-table .event-actions{min-width:0!important}.event-details{min-width:0!important;max-width:none!important}.row-subtitle,.row-assigned{display:none}.row-icon{width:24px;height:24px}.row-icon svg{width:12px;height:12px}.row-detail-wrapper{gap:4px}.row-title{font-size:.8rem;font-weight:500;line-height:1.2}.date-range{color:var(--color-text-primary);flex-direction:column;align-items:flex-start;gap:2px;font-size:.8rem;font-weight:500;line-height:1.2}.date-separator{display:none}.date-start:after{content:" →";color:var(--color-text-secondary)}.date-duration{font-size:.65rem}.status-text{display:none}.status-dot{width:12px;height:12px}.status-dot-mobile{border-radius:50%;flex-shrink:0;width:10px;height:10px;display:inline-block}.status-dot-mobile.status-confirmed,.status-dot-mobile.status-booked{background-color:var(--status-confirmed-text)}.status-dot-mobile.status-preferred{background-color:var(--status-preferred-text)}.status-dot-mobile.status-tentative{background-color:var(--status-tentative-text)}.status-dot-mobile.status-cancelled{background-color:var(--status-cancelled-text)}.btn-icon{padding:6px}.btn-icon svg{width:14px;height:14px}}.trip-day-number{color:#9ca3af;text-transform:uppercase;letter-spacing:.5px;margin-top:2px;font-size:10px;font-weight:500}.date-input-container{width:100%;position:relative}.date-input-label{color:var(--color-text-primary);margin-bottom:.5rem;font-size:.875rem;font-weight:500;display:block}.date-input-wrapper{position:relative}.date-input-trigger{border:1px solid var(--color-border);border-radius:var(--radius-md);width:100%;color:var(--color-text-primary);cursor:pointer;text-align:left;background:#fff;align-items:center;gap:10px;height:42px;padding:.5rem .75rem;font-size:.875rem;transition:all .2s;display:flex}.date-input-trigger:hover{border-color:var(--color-border-hover);background:var(--color-background-secondary)}.date-input-trigger.empty .date-text{color:var(--color-text-tertiary)}.date-icon{color:var(--color-text-secondary);flex-shrink:0}.date-text{white-space:nowrap;text-overflow:ellipsis;flex:1;overflow:hidden}.clear-date-btn{color:var(--color-text-tertiary);border-radius:50%;justify-content:center;align-items:center;padding:2px;transition:all .2s;display:flex}.clear-date-btn:hover{background:var(--color-background-tertiary);color:var(--color-text-primary)}.date-picker-popup{border:1px solid var(--color-border);border-radius:var(--radius-md);z-index:1000;background:#fff;width:280px;margin-top:4px;padding:12px;animation:.15s dropdown-fade-in;position:absolute;top:100%;left:0;box-shadow:0 4px 12px #00000026}.date-picker-header{justify-content:space-between;align-items:center;margin-bottom:12px;display:flex}.date-picker-header button{cursor:pointer;color:var(--color-text-secondary);background:0 0;border:none;border-radius:4px;align-items:center;padding:4px;display:flex}.date-picker-header button:hover{background:var(--color-background-secondary);color:var(--color-text-primary)}.current-month{color:var(--color-text-primary);font-size:.9rem;font-weight:600}.date-picker-grid{text-align:center;grid-template-columns:repeat(7,1fr);gap:2px;display:grid}.date-picker-weekday{color:var(--color-text-tertiary);margin-bottom:4px;font-size:.75rem;font-weight:500}.date-picker-day{cursor:pointer;color:var(--color-text-primary);border-radius:4px;padding:6px 0;font-size:.85rem}.date-picker-day:hover{background:var(--color-background-secondary)}.date-picker-day.today{color:var(--color-primary);font-weight:600}.date-picker-day.selected{background:var(--color-primary);color:#fff}.date-picker-day.selected:hover{background:var(--color-primary-hover)}@media (max-width:640px){.tab-navigation{flex-direction:column;align-items:stretch;gap:8px;height:auto;padding:8px}.nav-primary-row{align-items:center;gap:8px;width:100%;display:flex}.nav-primary-row .tab-btn{flex:none;justify-content:center;padding:12px 20px}.nav-primary-row .tm-linear-btn{margin-left:auto}.trip-header-container{padding:var(--spacing-md);flex-direction:column;align-items:stretch;gap:8px}.trip-header-left-group{width:100%;margin-bottom:4px}.desktop-members{display:none!important}.mobile-members{display:inline-block}.trip-header-right-group{justify-content:space-between;width:100%}.nav-secondary-row{justify-content:start;width:100%;margin-top:0;display:flex}.view-selector{background:#f8f9fa;border-radius:6px;width:100%;padding:2px;gap:0!important;display:flex!important}.view-selector .view-btn{border-radius:4px;flex:1;justify-content:center;padding:6px 0}}.mobile-schedule-view{background:var(--color-background);border-top:1px solid var(--color-border-light,#f1f1f1);border-bottom:1px solid var(--color-border-light,#f1f1f1);flex-direction:column;gap:0;min-height:100%;margin-top:16px;padding:0;display:flex;overflow:hidden}.mobile-schedule-empty{color:var(--color-text-secondary);text-align:center;justify-content:center;align-items:center;padding:48px 24px;font-size:.95rem;display:flex}.schedule-location-section{background:var(--color-background);margin-bottom:8px}.schedule-location-warning{background:var(--color-warning-light,#fff7ed);padding:12px 16px}.schedule-warning{color:var(--color-warning,#ea580c);align-items:center;gap:8px;font-size:.85rem;font-weight:500;display:flex}.schedule-warning svg{flex-shrink:0}.schedule-warning-route{color:var(--color-text-secondary);font-weight:400}.schedule-location-header{z-index:10;background:var(--color-background);border-bottom:1px solid var(--color-border);-webkit-tap-highlight-color:transparent;align-items:stretch;padding-left:6px;display:flex;position:relative;top:0}.schedule-location-header:active{background:var(--color-background-secondary)}.schedule-location-info{flex:1;align-items:flex-start;gap:12px;min-width:0;padding:16px 0;display:flex}.schedule-location-icon{color:var(--color-primary);flex-shrink:0;margin-top:2px}.schedule-location-text{flex-direction:column;gap:4px;min-width:0;padding-left:6px;display:flex}.schedule-location-name{color:var(--color-text-primary);margin:0;font-size:1.1rem;font-weight:600;line-height:1.3}.schedule-location-dates{font-size:var(--font-size-sm);color:var(--color-text-secondary)}.schedule-accommodation{background:var(--color-background-secondary);border-bottom:1px solid var(--color-border);color:var(--color-text-secondary);cursor:pointer;align-items:center;gap:10px;padding:12px 16px;font-size:.9rem;display:flex}.schedule-accommodation:active{background:var(--color-background-tertiary)}.schedule-accommodation svg{color:var(--color-text-tertiary);flex-shrink:0}.schedule-accommodation-name{color:var(--color-text-primary);text-overflow:ellipsis;white-space:nowrap;flex:1;font-weight:500;overflow:hidden}.schedule-accommodation-actions{gap:4px;display:flex}.schedule-days{flex-direction:column;display:flex}.schedule-day{border-bottom:1px solid var(--color-border)}.schedule-day:last-child{border-bottom:none}.schedule-today-indicator{border-left:3px solid var(--color-primary);background:linear-gradient(90deg,#2563eb14 0%,#2563eb08 100%);align-items:center;gap:8px;margin-left:0;padding:6px 12px 6px 52px;display:flex}.schedule-today-indicator span{text-transform:uppercase;letter-spacing:.05em;color:var(--color-primary);font-size:.7rem;font-weight:600}.schedule-day-header{background:var(--color-background-tertiary);align-items:stretch;padding:6px;display:flex}.schedule-day-header .timeline-segment{justify-content:center;align-items:center;display:flex}.schedule-day-header .timeline-segment:after{content:"";z-index:1;background:var(--color-background);border:2px solid var(--timeline-color);border-radius:50%;width:10px;height:10px;position:relative}.schedule-day-date{color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.03em;flex:1;align-items:center;padding:12px 0 12px 8px;font-size:.8rem;font-weight:600;display:flex}.schedule-day-toggle{color:var(--color-primary);cursor:pointer;background:0 0;border:none;border-radius:4px;margin-right:16px;padding:4px 8px;font-size:.75rem}.schedule-day-toggle:active{background:var(--color-primary-light)}.schedule-day-items{flex-direction:column;display:flex}.schedule-day-empty{color:var(--color-text-tertiary);padding:16px;font-size:.85rem;font-style:italic}.mobile-schedule-view{--timeline-width:44px;--timeline-line-width:2px;--timeline-color:var(--color-border)}.timeline-segment{width:var(--timeline-width);min-width:var(--timeline-width);flex-shrink:0;justify-content:center;align-items:center;display:flex;position:relative}.timeline-segment:before{content:"";width:var(--timeline-line-width);background:repeating-linear-gradient(to bottom,var(--timeline-color)0,var(--timeline-color)4px,transparent 4px,transparent 8px);position:absolute;top:0;bottom:0;left:50%;transform:translate(-50%)}.timeline-segment.timeline-last:before{bottom:50%}.timeline-segment.timeline-header:before{top:50%}.timeline-segment.timeline-header-icon:before,.timeline-segment.timeline-no-line:before{display:none}.timeline-icon{z-index:1;background:var(--color-background-tertiary,#f3f4f6);border-radius:8px;justify-content:center;align-items:center;width:44px;height:44px;display:flex;position:relative}.timeline-icon svg{width:22px;height:22px}.timeline-icon-bordered{color:var(--color-text-secondary);border:none}.timeline-icon-bordered.timeline-icon-event{color:#8b5cf6}.timeline-icon-filled{background:var(--color-background-tertiary,#f3f4f6);color:#2dd4bf;border:none}.timeline-icon-header{background:var(--color-background-tertiary,#f3f4f6);width:44px;height:44px;color:var(--color-primary);border:none;border-radius:8px}.timeline-segment.timeline-header-icon{position:relative}.timeline-segment.timeline-header-icon:after{content:"";width:var(--timeline-line-width);background:repeating-linear-gradient(to bottom,var(--timeline-color)0,var(--timeline-color)4px,transparent 4px,transparent 8px);position:absolute;top:calc(50% + 16px);bottom:0;left:50%;transform:translate(-50%)}.schedule-transport-section{flex-direction:column;display:flex}.schedule-empty-group{border-bottom:1px solid var(--color-border);align-items:stretch;min-height:60px;padding:0 0 0 6px;display:flex}.schedule-empty-group-content{flex-direction:column;justify-content:center;gap:4px;padding:16px 16px 16px 8px;display:flex}.schedule-empty-dates{font-size:var(--font-size-base);color:var(--color-text-secondary);font-weight:600}.schedule-empty-label{color:var(--color-text-tertiary);font-size:.85rem;font-style:italic}.schedule-day-empty-single{color:var(--color-text-tertiary);align-items:stretch;padding:0;font-size:.85rem;font-style:italic;display:flex}.schedule-day-empty-single span{align-items:center;padding:12px 16px 12px 8px;display:flex}.schedule-day-collapsed{color:var(--color-text-secondary);align-items:center;padding:12px 16px 12px 0;font-size:.85rem;display:flex}.schedule-item{cursor:pointer;border-bottom:1px solid #0000000a;align-items:stretch;padding:0 0 0 6px;display:flex}.schedule-item:last-child{border-bottom:none}.schedule-item.schedule-item-travel{border-bottom:1px solid #0000000f;padding:6px}.schedule-item-content{flex:1;align-items:center;gap:12px;min-width:0;padding:14px 0 14px 8px;display:flex}.schedule-map-link{background:var(--color-background-tertiary,#f3f4f6);width:36px;height:36px;color:var(--color-text-secondary);border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;margin-right:12px;transition:background .15s,color .15s;display:flex}.schedule-map-link:hover{background:var(--color-primary-light);color:var(--color-primary)}.schedule-map-link:active{background:var(--color-primary);color:#fff}.schedule-location-header .schedule-map-link,.schedule-item .schedule-map-link{align-self:center}.schedule-item-details{flex-direction:column;flex:1;gap:4px;min-width:0;display:flex}.schedule-item-title{font-size:var(--font-size-base);color:var(--color-text-primary);font-weight:500;line-height:1.3}.schedule-item-time{font-size:var(--font-size-sm);color:var(--color-text-secondary);align-items:center;gap:4px;font-weight:500;display:flex}.schedule-item-time-allday,.schedule-item-time-unknown{color:var(--color-text-tertiary);font-style:italic}.schedule-item-time-unknown svg{opacity:.7}.schedule-item-datetime{flex-wrap:wrap;align-items:center;gap:0;display:flex}.schedule-item-date{font-size:var(--font-size-sm);color:var(--color-text-secondary);font-weight:600}.schedule-item-date-separator{color:var(--color-text-tertiary)}.schedule-item-time-value{font-size:var(--font-size-sm);align-items:center;gap:7px;padding-left:6px;display:flex}@media (max-width:480px){.schedule-item-datetime{flex-direction:column;align-items:flex-start;gap:2px}.schedule-item-date-separator{display:none}.schedule-location-header{padding-left:6px}}.schedule-item-notes{color:var(--color-text-tertiary);margin-top:2px;font-size:.8rem;line-height:1.4}.schedule-item-actions{flex-shrink:0;gap:6px;display:flex}.schedule-action-btn{background:var(--color-background-tertiary);width:32px;height:32px;color:var(--color-text-tertiary);cursor:pointer;-webkit-tap-highlight-color:transparent;border:none;border-radius:6px;justify-content:center;align-items:center;display:flex}.schedule-action-btn:active{background:var(--color-primary);color:#fff}.schedule-action-btn-danger:active{background:var(--color-danger);color:#fff}.page>main.card{padding-bottom:env(safe-area-inset-bottom);flex:1;overflow-y:auto}.desktop-itinerary-container{background:var(--color-background);border-left:1px solid var(--color-border);border-right:1px solid var(--color-border);max-width:680px;min-height:100%;margin:0 auto}@media (max-width:768px){.desktop-only{display:none!important}}.mobile-schedule-view{padding-bottom:2rem}.empty-state{text-align:center;background:var(--color-background);border-radius:var(--radius-lg);border:1px dashed var(--color-border);flex-direction:column;justify-content:center;align-items:center;max-width:480px;margin:2rem auto;padding:4rem 2rem;display:flex}.empty-state-icon{background:var(--color-primary-light);height:60px;color:var(--color-primary);box-shadow:0 0 0 8px var(--color-background),0 0 0 9px var(--color-primary-light);border-radius:50%;justify-content:center;align-items:center;margin-bottom:1.5rem;display:flex;width:60px!important}.empty-state-icon svg{width:40px;height:40px}.empty-state-title{font-size:var(--font-size-lg);color:var(--color-text-primary);margin-bottom:.5rem;font-weight:600}.empty-state-description{font-size:var(--font-size-sm);color:var(--color-text-secondary);max-width:320px;margin-bottom:2rem;line-height:1.6}@keyframes spin{to{transform:rotate(360deg)}}@keyframes fadeIn{0%{opacity:0;transform:translateY(-5px)}to{opacity:1;transform:translateY(0)}}@keyframes pulse-subtle{0%,to{opacity:1;transform:scale(1)}50%{opacity:.8;transform:scale(.98)}}.loading-container{color:var(--color-text-secondary);text-align:center;flex-direction:column;justify-content:center;align-items:center;min-height:200px;padding:2rem;animation:.4s ease-out fadeIn;display:flex}.loading-logo-wrapper{justify-content:center;align-items:center;margin-bottom:32px;animation:2s ease-in-out infinite pulse-subtle;display:flex}.loading-logo-wrapper svg{width:80px;height:80px}.loading-spinner-wrapper{justify-content:center;align-items:center;margin-bottom:8px;display:flex;position:relative}.loading-spinner{color:var(--color-primary);opacity:.9;animation:1s linear infinite spin}.loading-text{color:var(--color-text-secondary);letter-spacing:.01rem;opacity:.7;margin-top:24px;font-size:1.1rem;font-weight:500}.modal-subtitle{color:var(--color-text-secondary);margin:-10px 0 20px;font-size:.9rem}.export-options{flex-direction:column;gap:12px;display:flex}.export-card-btn{text-align:left;background:var(--color-surface);border:1px solid var(--color-border);cursor:pointer;border-radius:12px;align-items:flex-start;gap:16px;width:100%;padding:16px;transition:all .2s;display:flex}.export-card-btn:hover{background:var(--color-background-hover);border-color:var(--color-primary);transform:translateY(-1px);box-shadow:0 4px 6px -1px #0000001a}.export-icon-wrapper{border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;width:48px;height:48px;display:flex}.calendar-bg{color:#0284c7;background:#e0f2fe}.pdf-bg{color:#ef4444;background:#fee2e2}.export-text{flex-direction:column;gap:4px;display:flex}.export-title{color:var(--color-text-primary);font-size:1rem;font-weight:600}.export-desc{color:var(--color-text-secondary);font-size:.85rem;line-height:1.4}.tm-page .app-header-title{letter-spacing:-.025em;font-size:var(--font-size-lg)!important;font-weight:600!important}.tm-page .app-actions .btn-ghost svg{width:20px!important;height:20px!important}.tm-page .app-actions{gap:.75rem}.export-toast{color:#fff;background:#10b981;border-radius:20px;align-items:center;gap:8px;padding:8px 16px;font-size:.9rem;font-weight:500;animation:3s forwards fadeInOut;display:flex;position:absolute;bottom:20px;left:50%;transform:translate(-50%);box-shadow:0 4px 6px -1px #0000001a}@keyframes fadeInOut{0%{opacity:0;transform:translate(-50%,10px)}10%{opacity:1;transform:translate(-50%)}90%{opacity:1;transform:translate(-50%)}to{opacity:0;transform:translate(-50%,-10px)}}.app-header{z-index:50;background-color:#fff;border-bottom:1px solid #e2e8f0;justify-content:space-between;align-items:center;height:64px;padding:.75rem 1.5rem;display:flex;position:sticky;top:0}.app-header-left,.app-header-right{align-items:center;gap:1rem;display:flex}.app-logo{margin-right:.5rem;font-size:1.5rem}.app-nav{align-items:center;display:flex}.app-actions{align-items:center;gap:.5rem;display:flex}.nav-separator{color:#94a3b8;margin:0 .5rem}.nav-btn{color:#64748b;cursor:pointer;background:0 0;border:none;border-radius:4px;padding:.25rem .5rem;font-size:.95rem;font-weight:500;transition:color .2s,background-color .2s}.nav-btn:hover{color:#0f172a;background-color:#f1f5f9}.nav-current{color:#0f172a;padding:.25rem .5rem;font-size:.95rem;font-weight:600}.user-menu-container{position:relative}.user-avatar-btn{cursor:pointer;color:#64748b;background-color:#f8fafc;border:1px solid #e2e8f0;border-radius:50%;justify-content:center;align-items:center;width:40px;height:40px;transition:ring .2s;display:flex;overflow:hidden}.user-avatar-btn:hover{box-shadow:0 0 0 2px #e2e8f0}.user-avatar-img{object-fit:cover;width:100%;height:100%}.user-dropdown{z-index:100;background-color:#fff;border:1px solid #e2e8f0;border-radius:8px;width:200px;margin-top:.5rem;animation:.1s ease-out fadeIn;position:absolute;top:100%;right:0;overflow:hidden;box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f}.user-info{background-color:#f8fafc;border-bottom:1px solid #e2e8f0;padding:1rem}.user-name{color:#0f172a;margin:0;font-size:.9rem;font-weight:600}.user-email{color:#64748b;white-space:nowrap;text-overflow:ellipsis;margin:0;font-size:.8rem;overflow:hidden}.dropdown-item{text-align:left;cursor:pointer;color:#334155;background:0 0;border:none;align-items:center;gap:.75rem;width:100%;padding:.75rem 1rem;font-size:.9rem;transition:background-color .2s;display:flex}.dropdown-item:hover{background-color:#f1f5f9}.dropdown-item.danger{color:#ef4444}.dropdown-item.danger:hover{background-color:#fef2f2}.dropdown-icon{color:inherit;opacity:.7}.toggle-group{background-color:#0000;gap:8px;padding:0;display:flex}.toggle-group .icon-btn{color:#64748b;cursor:pointer;white-space:nowrap;background:0 0;border:1px solid #0000;border-radius:8px;justify-content:center;align-items:center;gap:8px;padding:8px 12px;font-size:.9rem;font-weight:500;transition:all .2s cubic-bezier(.4,0,.2,1);display:flex}.toggle-group .icon-btn:hover{color:var(--color-text-primary);background-color:#fff;box-shadow:0 1px 2px #0000000d}.toggle-group .icon-btn.active{color:var(--color-primary);background-color:#fff;border-color:#0000000d;box-shadow:0 1px 3px #0000001a}.toggle-group .icon-btn.active .btn-label,.toggle-group .icon-btn:not(.active) .btn-label{display:inline-block}@media (max-width:640px){.toggle-group .icon-btn .btn-label{display:none!important}}.hidden-mobile{display:inline}@media (max-width:640px){.hidden-mobile{display:none!important}.app-header{height:auto;min-height:60px;padding:.75rem 1rem}.app-logo{font-size:1.25rem}.user-dropdown{width:240px;right:-10px}}.settings-page{flex-direction:column;height:100vh;display:flex;overflow:hidden}.settings-container{-webkit-overflow-scrolling:touch;flex-direction:column;flex:1;gap:2rem;width:100%;max-width:1200px;margin:0 auto;padding:2rem 1.5rem;display:flex;overflow-y:auto}.settings-section-card{background:#fff;border:1px solid #e2e8f0;border-radius:12px;height:100%;transition:box-shadow .2s;overflow:hidden;box-shadow:0 1px 3px #0000000d}.settings-section-card:hover{box-shadow:0 4px 6px -1px #0000001a}.settings-header{background-color:#f8fafc;border-bottom:1px solid #f1f5f9;align-items:center;gap:.5rem;padding:.75rem 1rem;display:flex}.settings-header h3{color:#0f172a;margin:0;font-size:1.1rem;font-weight:600}.settings-header .icon{color:#64748b}.settings-content{flex-direction:column;gap:1rem;height:100%;padding:1rem;display:flex}.settings-grid{grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1rem;display:grid}.danger-zone{border-color:#fecaca}.danger-zone .settings-header{background-color:#fef2f2;border-bottom-color:#fecaca}.danger-zone h3{color:#991b1b}.danger-zone .icon{color:#ef4444}@media (min-width:1024px){.settings-container{grid-template-columns:repeat(2,1fr);align-items:start;padding:3rem 2rem;display:grid}.settings-section-card:nth-child(2),.settings-section-card:nth-child(3){grid-column:span 1}.settings-container{gap:2rem}}@media (max-width:768px){.hidden-mobile,.app-header-right .user-menu-container{display:none!important}.app-header{padding-left:.75rem!important;padding-right:.75rem!important}}@media (min-width:769px){.hidden-desktop{display:none!important}}.split-layout-grid{gap:var(--spacing-lg);margin-top:var(--spacing-sm);grid-column:1/-1;grid-template-columns:1fr;display:grid}@media (min-width:768px){.split-layout-grid{grid-template-columns:1fr 1.25fr;align-items:start}}.split-layout-grid .form-group{margin-bottom:0}@media (max-width:640px){.tm-page .app-header-title{letter-spacing:-.025em;font-size:var(--font-size-lg)!important;font-weight:600!important}.tm-page .app-actions .btn-ghost svg{width:20px!important;height:20px!important}.tm-page .app-actions{gap:.75rem}}.tm-helper-section{text-align:center;flex-direction:column;align-items:center;gap:1.5rem;padding:2.5rem 1.5rem;animation:.4s ease-out fadeIn;display:flex}.tm-helper-text{color:var(--color-text-secondary);max-width:320px;margin:0;font-size:.95rem;line-height:1.5}.btn-secondary-cta{border:1.5px solid var(--color-border);width:100%;max-width:320px;color:var(--color-text-primary);background-color:#0000;border-radius:999px;justify-content:center;align-items:center;gap:.75rem;padding:.875rem 1.5rem;font-size:.95rem;font-weight:600;transition:all .2s;display:flex}.btn-secondary-cta:hover{background-color:var(--color-background-secondary);border-color:var(--color-border-hover);transform:translateY(-1px)}.btn-secondary-cta:active{transform:translateY(0)}.signin-page{background:radial-gradient(circle at 100% 0,#f8fafc 0%,#e2e8f0 100%);height:100vh}.signin-card{-webkit-backdrop-filter:blur(12px);text-align:center;background:#fffc;border:1px solid #ffffff4d;border-radius:24px;width:100%;max-width:400px;padding:3rem 2rem;animation:.6s ease-out fadeIn;box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a}.signin-logo-wrapper{background:#fff;border-radius:16px;margin-bottom:1.5rem;padding:1rem;animation:4s ease-in-out infinite pulse-subtle;display:inline-flex;box-shadow:0 4px 6px -1px #0000000d}.signin-logo-wrapper svg{width:48px;height:48px}.signin-title{color:#0f172a;letter-spacing:-.05em;margin-bottom:.75rem;font-size:2rem;font-weight:800}.signin-prompt{color:#64748b;margin-bottom:2.5rem;font-size:1rem;line-height:1.5}.signin-btn{color:#334155;background:#fff;border:1px solid #e2e8f0;border-radius:12px;justify-content:center;align-items:center;gap:12px;width:100%;padding:.75rem 1.5rem;font-size:1rem;font-weight:600;transition:all .2s;display:flex;box-shadow:0 1px 2px #0000000d}.signin-btn:hover{background:#f8fafc;border-color:#cbd5e1;transform:translateY(-1px);box-shadow:0 4px 6px -1px #0000000d}.signin-btn:active{transform:translateY(0)}.google-icon{flex-shrink:0}.signin-email-form{flex-direction:column;gap:12px;width:100%;display:flex}.signin-input{background:#fff;border:1px solid #e2e8f0;border-radius:12px;width:100%;padding:.875rem 1rem;font-size:1rem;transition:all .2s}.signin-input:focus{border-color:#3b82f6;outline:none;box-shadow:0 0 0 3px #3b82f61a}.signin-submit-btn{color:#fff;cursor:pointer;background:#3b82f6;border:none;border-radius:12px;width:100%;padding:.875rem;font-size:1rem;font-weight:600;transition:all .2s}.signin-submit-btn:hover{background:#2563eb;transform:translateY(-1px)}.signin-submit-btn:disabled{opacity:.7;cursor:not-allowed;transform:none}.signin-divider{color:#94a3b8;align-items:center;margin:1.5rem 0;font-size:.875rem;font-weight:500;display:flex}.signin-divider:before,.signin-divider:after{content:"";background:#e2e8f0;flex:1;height:1px}.signin-divider span{padding:0 1rem}.signin-error{color:#ef4444;text-align:left;margin-top:4px;font-size:.875rem}.signin-sent-message{color:#166534;background:#f0fdf4;border:1px solid #bbf7d0;border-radius:16px;padding:2rem 1rem;animation:.4s ease-out fadeIn}.signin-sent-icon{margin-bottom:1rem;font-size:2.5rem}.signin-sent-text{font-weight:500;line-height:1.5}
