:root{--color-bg: #f9f6f1;--color-bg-secondary: #f0ebe3;--color-surface: #ffffff;--color-text: #2a2016;--color-text-secondary: #8c7e6a;--color-accent: #c0542e;--color-accent-hover: #a3462a;--color-accent-subtle: rgba(192, 84, 46, .07);--color-border: #e4ddd2;--color-border-light: #ede8e0;--color-danger: #b33d3d;--color-danger-subtle: #fdf0f0;--color-success: #4d7c4f;--color-success-subtle: #eef6ee;--color-warning: #c09235;--color-warning-subtle: #fdf6e8;--color-sidebar-bg: #2a2016;--color-sidebar-text: #c8bba8;--color-sidebar-text-bright: #f0ebe3;--color-sidebar-hover: rgba(255, 255, 255, .06);--color-sidebar-active-bg: rgba(192, 84, 46, .15);--color-sidebar-active-text: #e8845e;--color-sidebar-border: rgba(255, 255, 255, .06);--space-xs: 4px;--space-sm: 8px;--space-md: 16px;--space-lg: 24px;--space-xl: 32px;--space-2xl: 48px;--space-3xl: 64px;--font-display: "Young Serif", Georgia, serif;--font-family: "Figtree", -apple-system, BlinkMacSystemFont, sans-serif;--font-mono: "SF Mono", "Fira Code", "Consolas", monospace;--font-size-xs: .75rem;--font-size-sm: .8125rem;--font-size-base: .9375rem;--font-size-lg: 1.125rem;--font-size-xl: 1.5rem;--font-size-2xl: 2rem;--font-size-3xl: 2.5rem;--radius-sm: 8px;--radius-md: 10px;--radius-lg: 14px;--radius-xl: 20px;--shadow-xs: 0 1px 2px rgba(42, 32, 22, .04);--shadow-sm: 0 1px 3px rgba(42, 32, 22, .06), 0 1px 2px rgba(42, 32, 22, .04);--shadow-md: 0 4px 12px rgba(42, 32, 22, .07), 0 1px 3px rgba(42, 32, 22, .04);--shadow-lg: 0 10px 30px rgba(42, 32, 22, .1), 0 2px 8px rgba(42, 32, 22, .04);--safe-top: env(safe-area-inset-top, 0px);--safe-bottom: env(safe-area-inset-bottom, 0px);--sidebar-width: 256px;--sidebar-width-collapsed: 72px;--header-height: 56px;--bottom-nav-height: calc(60px + var(--safe-bottom));--transition-fast: .15s ease;--transition-normal: .25s ease;--transition-slow: .4s ease}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-family:var(--font-family);font-size:16px;line-height:1.55;color:var(--color-text);background-color:var(--color-bg);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{min-height:100dvh;padding-top:var(--safe-top);padding-bottom:var(--safe-bottom)}@media(prefers-reduced-motion:no-preference){html{scroll-behavior:smooth}}::selection{background:#c0542e26;color:var(--color-text)}:focus-visible{outline:2px solid var(--color-accent);outline-offset:2px}.loading-screen{display:flex;align-items:center;justify-content:center;min-height:100dvh;color:var(--color-text-secondary);font-family:var(--font-display);font-size:var(--font-size-lg);letter-spacing:.02em}.login-page{display:flex;align-items:center;justify-content:center;min-height:100dvh;padding:var(--space-lg);background:linear-gradient(160deg,#f9f6f1,#ede4d6,#e8ddd0);position:relative}.login-page:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background-image:url("data:image/svg+xml,%3Csvg width='40' height='40' viewBox='0 0 40 40' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='%23c0542e' fill-opacity='0.03'%3E%3Cpath d='M20 20.5V18H0v-2h20v-2H0v-2h20v-2H0V8h20V6H0V4h20V2H0V0h22v20h2V0h2v20h2V0h2v20h2V0h2v20h2V0h2v22H20v-1.5zM0 20h2v20H0V20zm4 0h2v20H4V20zm4 0h2v20H8V20zm4 0h2v20h-2V20zm4 0h2v20h-2V20zm4 0h2v20h-2V20z'/%3E%3C/g%3E%3C/svg%3E");pointer-events:none}.login-card{text-align:center;max-width:420px;width:100%;padding:var(--space-3xl) var(--space-xl);background:var(--color-surface);border-radius:var(--radius-xl);box-shadow:var(--shadow-lg);position:relative}.login-card h1{font-family:var(--font-display);font-size:var(--font-size-3xl);font-weight:400;color:var(--color-text);margin-bottom:var(--space-xs);letter-spacing:-.01em}.login-card p{color:var(--color-text-secondary);margin-bottom:var(--space-xl);font-size:var(--font-size-base)}.google-btn{display:inline-flex;align-items:center;gap:var(--space-sm);padding:14px var(--space-xl);font-size:var(--font-size-base);font-weight:500;color:var(--color-text);background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-sm);cursor:pointer;transition:all var(--transition-fast);min-height:48px;font-family:var(--font-family)}.google-btn:hover{border-color:var(--color-text-secondary);box-shadow:var(--shadow-sm);transform:translateY(-1px)}.google-btn:active{transform:translateY(0)}.app-shell{display:flex;min-height:100dvh}.sidebar{position:fixed;top:0;left:0;bottom:0;width:var(--sidebar-width);background:var(--color-sidebar-bg);display:flex;flex-direction:column;z-index:100;padding-top:var(--safe-top);transition:width var(--transition-normal);overflow:hidden}.sidebar__logo{display:flex;align-items:center;gap:10px;padding:var(--space-xl) var(--space-lg);font-family:var(--font-display);font-size:var(--font-size-xl);font-weight:400;color:var(--color-sidebar-text-bright);text-decoration:none;white-space:nowrap;letter-spacing:-.01em}.sidebar__logo-icon{width:28px;height:28px;flex-shrink:0;color:var(--color-sidebar-active-text)}.sidebar__nav{flex:1;padding:var(--space-sm) var(--space-md);display:flex;flex-direction:column;gap:2px;overflow-y:auto}.sidebar__nav-item{display:flex;align-items:center;gap:var(--space-md);height:44px;padding:0 var(--space-md);border-radius:var(--radius-sm);color:var(--color-sidebar-text);text-decoration:none;font-size:var(--font-size-sm);font-weight:500;white-space:nowrap;transition:all var(--transition-fast);cursor:pointer;border:none;background:none;width:100%;text-align:left;font-family:inherit;letter-spacing:.01em}.sidebar__nav-item:hover{background:var(--color-sidebar-hover);color:var(--color-sidebar-text-bright)}.sidebar__nav-item--active{background:var(--color-sidebar-active-bg);color:var(--color-sidebar-active-text)}.sidebar__nav-item--active:hover{color:var(--color-sidebar-active-text);background:var(--color-sidebar-active-bg)}.sidebar__nav-icon{width:18px;height:18px;flex-shrink:0;opacity:.8}.sidebar__nav-item--active .sidebar__nav-icon{opacity:1}.sidebar__nav-label{overflow:hidden;text-overflow:ellipsis}.sidebar__user{padding:var(--space-lg) var(--space-lg);border-top:1px solid var(--color-sidebar-border);display:flex;align-items:center;gap:var(--space-sm);white-space:nowrap}.sidebar__avatar{width:32px;height:32px;border-radius:50%;flex-shrink:0;object-fit:cover;border:2px solid var(--color-sidebar-border)}.sidebar__user-info{flex:1;min-width:0;overflow:hidden}.sidebar__user-name{font-size:var(--font-size-sm);font-weight:500;color:var(--color-sidebar-text-bright);overflow:hidden;text-overflow:ellipsis}.sidebar__sign-out{font-size:var(--font-size-xs);color:var(--color-sidebar-text);background:none;border:none;cursor:pointer;padding:0;font-family:inherit;transition:color var(--transition-fast)}.sidebar__sign-out:hover{color:var(--color-danger)}.sidebar--collapsed{width:var(--sidebar-width-collapsed)}.sidebar--collapsed .sidebar__logo{padding:var(--space-lg) 0;justify-content:center}.sidebar--collapsed .sidebar__logo-icon{margin:0}.sidebar--collapsed .sidebar__logo span,.sidebar--collapsed .sidebar__nav-label,.sidebar--collapsed .sidebar__user-info,.sidebar--collapsed .sidebar__sign-out{display:none}.sidebar--collapsed .sidebar__nav-item{justify-content:center;padding:0;height:44px}.sidebar--collapsed .sidebar__user{justify-content:center}.app-header{position:sticky;top:0;height:var(--header-height);display:flex;align-items:center;justify-content:space-between;padding:0 var(--space-lg);background:var(--color-bg);border-bottom:1px solid var(--color-border-light);z-index:90}.app-header__left{display:flex;align-items:center;gap:var(--space-sm);min-width:0}.app-header__back{display:inline-flex;align-items:center;justify-content:center;width:38px;height:38px;border-radius:var(--radius-sm);background:none;border:none;color:var(--color-text);cursor:pointer;transition:background var(--transition-fast);flex-shrink:0}.app-header__back:hover{background:var(--color-bg-secondary)}.app-header__title{font-family:var(--font-display);font-size:var(--font-size-lg);font-weight:400;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.app-header__right{display:flex;align-items:center;gap:var(--space-sm);flex-shrink:0}.app-header__avatar{width:32px;height:32px;border-radius:50%;object-fit:cover}.offline-indicator{display:inline-flex;align-items:center;gap:var(--space-xs);padding:var(--space-xs) var(--space-sm);font-size:var(--font-size-xs);color:var(--color-warning);background:var(--color-warning-subtle);border-radius:999px;font-weight:500}.offline-indicator__dot{width:6px;height:6px;border-radius:50%;background:var(--color-warning)}.bottom-nav{position:fixed;bottom:0;left:0;right:0;height:var(--bottom-nav-height);background:var(--color-surface);border-top:1px solid var(--color-border-light);display:none;grid-template-columns:repeat(4,1fr);align-items:start;padding-bottom:var(--safe-bottom);z-index:100;box-shadow:0 -2px 12px #2a20160a}.bottom-nav__tab{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;padding-top:10px;height:60px;font-size:10px;font-weight:600;color:var(--color-text-secondary);text-decoration:none;background:none;border:none;cursor:pointer;transition:color var(--transition-fast);-webkit-tap-highlight-color:transparent;font-family:inherit;letter-spacing:.02em}.bottom-nav__tab--active{color:var(--color-accent)}.bottom-nav__tab-icon{width:22px;height:22px}.bottom-nav__tab--add{position:relative}.bottom-nav__add-btn{width:46px;height:46px;border-radius:50%;background:var(--color-accent);color:#fff;display:flex;align-items:center;justify-content:center;border:none;cursor:pointer;box-shadow:0 3px 10px #c0542e59;transition:all var(--transition-fast);margin-top:-6px}.bottom-nav__add-btn:hover{background:var(--color-accent-hover)}.bottom-nav__add-btn:active{transform:scale(.93)}.bottom-nav__add-icon{width:22px;height:22px}.app-main{flex:1;min-height:100dvh;width:100%}.app-main--sidebar{margin-left:var(--sidebar-width)}.app-main--sidebar-collapsed{margin-left:var(--sidebar-width-collapsed)}.app-content{max-width:1200px;margin:0 auto;width:100%;padding:var(--space-xl)}.page-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-xl)}.page-header__title{font-family:var(--font-display);font-size:var(--font-size-2xl);font-weight:400;color:var(--color-text);letter-spacing:-.01em}.section-label{font-size:var(--font-size-xs);font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:var(--color-text-secondary);margin-bottom:var(--space-md);margin-top:var(--space-xl)}@media(min-width:1024px){.sidebar{display:flex}.app-header,.bottom-nav{display:none}.app-main{margin-left:var(--sidebar-width)}.app-content{padding:var(--space-2xl) var(--space-xl)}.app-header--desktop-title{display:flex;border-bottom:none;padding:var(--space-lg) 0 var(--space-md);position:static;height:auto;background:transparent}.app-header--desktop-title .app-header__title{font-size:var(--font-size-2xl)}}@media(min-width:768px)and (max-width:1023px){.sidebar{display:flex;width:var(--sidebar-width-collapsed)}.sidebar .sidebar__logo{padding:var(--space-lg) 0;justify-content:center}.sidebar .sidebar__logo span,.sidebar .sidebar__nav-label,.sidebar .sidebar__user-info,.sidebar .sidebar__sign-out{display:none}.sidebar .sidebar__nav-item{justify-content:center;padding:0}.sidebar .sidebar__user{justify-content:center}.app-header{display:flex}.bottom-nav{display:none}.app-main{margin-left:var(--sidebar-width-collapsed)}}@media(max-width:767px){.sidebar{display:none}.app-header{display:flex}.bottom-nav{display:grid}.app-main{margin-left:0;padding-bottom:calc(var(--bottom-nav-height) + var(--space-md))}.app-content{padding:var(--space-md)}}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#2a201673;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);z-index:1000;display:flex;align-items:center;justify-content:center;animation:modal-overlay-in var(--transition-normal) both}@keyframes modal-overlay-in{0%{opacity:0}to{opacity:1}}.modal-content{max-width:560px;width:100%;max-height:80vh;background:var(--color-surface);border-radius:var(--radius-lg);overflow:hidden;display:flex;flex-direction:column;position:relative;animation:modal-desktop-in var(--transition-normal) both;box-shadow:var(--shadow-lg)}@keyframes modal-desktop-in{0%{opacity:0;transform:scale(.96) translateY(8px)}to{opacity:1;transform:scale(1) translateY(0)}}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-xl) var(--space-xl) var(--space-md);flex-shrink:0}.modal-header__title{font-family:var(--font-display);font-size:var(--font-size-xl);font-weight:400;letter-spacing:-.01em}.modal-header__close{display:inline-flex;align-items:center;justify-content:center;width:34px;height:34px;border-radius:var(--radius-sm);background:none;border:none;color:var(--color-text-secondary);cursor:pointer;transition:all var(--transition-fast);flex-shrink:0;font-size:18px}.modal-header__close:hover{background:var(--color-bg-secondary);color:var(--color-text)}.modal-body{flex:1;overflow-y:auto;padding:0 var(--space-xl);-webkit-overflow-scrolling:touch}.modal-footer{flex-shrink:0;padding:var(--space-md) var(--space-xl);border-top:1px solid var(--color-border-light);background:var(--color-surface);display:flex;justify-content:flex-end;gap:var(--space-sm)}@media(max-width:767px){.modal-overlay{align-items:flex-end}.modal-content{max-width:100%;max-height:90vh;border-radius:var(--radius-xl) var(--radius-xl) 0 0;animation:modal-sheet-in var(--transition-normal) both}.modal-header{padding:var(--space-lg) var(--space-lg) var(--space-sm)}.modal-body{padding:0 var(--space-lg)}.modal-footer{padding:var(--space-md) var(--space-lg) calc(var(--space-md) + var(--safe-bottom))}@keyframes modal-sheet-in{0%{transform:translateY(100%)}to{transform:translateY(0)}}}.card{background:var(--color-surface);border:1px solid var(--color-border-light);border-radius:var(--radius-md);padding:var(--space-lg);transition:all var(--transition-fast);box-shadow:var(--shadow-xs)}.card--clickable{cursor:pointer}.card--clickable:hover{box-shadow:var(--shadow-md);border-color:var(--color-border);transform:translateY(-1px)}.card--clickable:active{transform:translateY(0)}.badge{display:inline-flex;align-items:center;padding:2px 10px;border-radius:999px;font-size:var(--font-size-xs);font-weight:600;line-height:1.4;letter-spacing:.02em}.badge--success{background:var(--color-success-subtle);color:var(--color-success)}.badge--warning{background:var(--color-warning-subtle);color:#8a6a1e}.badge--danger{background:var(--color-danger-subtle);color:var(--color-danger)}.badge--neutral{background:var(--color-bg-secondary);color:var(--color-text-secondary)}.badge--info{background:#c0542e14;color:var(--color-accent)}.empty-state{text-align:center;padding:var(--space-3xl) var(--space-lg)}.empty-state__icon{width:48px;height:48px;color:var(--color-text-secondary);margin:0 auto var(--space-lg);opacity:.35}.empty-state__title{font-family:var(--font-display);font-size:var(--font-size-xl);font-weight:400;margin-bottom:var(--space-sm);color:var(--color-text)}.empty-state__description{color:var(--color-text-secondary);margin-bottom:var(--space-xl);max-width:340px;margin-left:auto;margin-right:auto;line-height:1.55;font-size:var(--font-size-base)}.empty-state__action{display:inline-flex;align-items:center;gap:var(--space-sm);padding:12px var(--space-xl);background:var(--color-accent);color:#fff;border:none;border-radius:var(--radius-sm);font-size:var(--font-size-sm);font-weight:600;font-family:inherit;cursor:pointer;transition:all var(--transition-fast);min-height:44px;box-shadow:0 1px 3px #c0542e33}.empty-state__action:hover{background:var(--color-accent-hover);transform:translateY(-1px);box-shadow:0 2px 6px #c0542e4d}.confirm-dialog .modal-content{max-width:400px}.confirm-dialog__body{padding:var(--space-lg);text-align:center}.confirm-dialog__title{font-family:var(--font-display);font-size:var(--font-size-lg);font-weight:400;margin-bottom:var(--space-sm)}.confirm-dialog__message{color:var(--color-text-secondary);line-height:1.55;font-size:var(--font-size-base)}.confirm-dialog__actions{display:flex;gap:var(--space-sm);justify-content:center;padding:var(--space-md) var(--space-lg) var(--space-lg)}.toast-container{position:fixed;top:var(--space-lg);right:var(--space-md);z-index:1100;display:flex;flex-direction:column;gap:var(--space-sm);pointer-events:none}.toast{padding:12px var(--space-lg);border-radius:var(--radius-md);box-shadow:var(--shadow-md);display:flex;align-items:center;gap:var(--space-sm);animation:toast-slide-in-right .3s cubic-bezier(.2,.9,.3,1) both;pointer-events:auto;font-weight:500;font-size:var(--font-size-sm);max-width:400px;border-left:3px solid transparent}.toast--success{background:var(--color-success-subtle);color:var(--color-success);border-left-color:var(--color-success)}.toast--error{background:var(--color-danger-subtle);color:var(--color-danger);border-left-color:var(--color-danger)}.toast--info{background:var(--color-accent-subtle);color:var(--color-accent);border-left-color:var(--color-accent)}.toast__icon{width:18px;height:18px;flex-shrink:0}.toast__message{flex:1}.toast__close{background:none;border:none;color:inherit;opacity:.5;cursor:pointer;padding:var(--space-xs);margin-left:auto;transition:opacity var(--transition-fast);flex-shrink:0}.toast__close:hover{opacity:1}@keyframes toast-slide-in-right{0%{transform:translate(110%);opacity:0}to{transform:translate(0);opacity:1}}@media(max-width:767px){.toast-container{top:calc(var(--safe-top) + var(--space-sm));right:var(--space-md);left:var(--space-md)}.toast{max-width:100%;animation:toast-slide-in-down .3s cubic-bezier(.2,.9,.3,1) both}@keyframes toast-slide-in-down{0%{transform:translateY(-110%);opacity:0}to{transform:translateY(0);opacity:1}}}.collapsible{border-bottom:1px solid var(--color-border-light)}.collapsible__header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-md) 0;cursor:pointer;min-height:48px;-webkit-user-select:none;user-select:none;-webkit-tap-highlight-color:transparent;background:none;border:none;width:100%;font-family:inherit;font-size:inherit;color:inherit;text-align:left}.collapsible__header-left{display:flex;align-items:center;gap:var(--space-sm)}.collapsible__icon{width:18px;height:18px;color:var(--color-text-secondary);flex-shrink:0}.collapsible__title{font-size:var(--font-size-base);font-weight:600}.collapsible__count{font-size:var(--font-size-xs);color:var(--color-text-secondary);background:var(--color-bg-secondary);padding:1px 8px;border-radius:999px;font-weight:600}.collapsible__header-right{display:flex;align-items:center;gap:var(--space-sm)}.collapsible__add-btn{font-size:var(--font-size-sm);color:var(--color-accent);background:none;border:none;cursor:pointer;padding:var(--space-xs) var(--space-sm);font-weight:600;font-family:inherit;transition:opacity var(--transition-fast)}.collapsible__add-btn:hover{opacity:.75}.collapsible__chevron{width:18px;height:18px;color:var(--color-text-secondary);transition:transform var(--transition-fast);flex-shrink:0}.collapsible--expanded .collapsible__chevron{transform:rotate(180deg)}.collapsible__content{overflow:hidden;transition:max-height var(--transition-normal);max-height:0}.collapsible--expanded .collapsible__content{max-height:2000px}.color-swatch{display:inline-block;width:24px;height:24px;border-radius:50%;border:2px solid var(--color-border);flex-shrink:0;box-shadow:inset 0 1px 2px #0000000f}.color-swatch--lg{width:40px;height:40px}.color-swatch--xl{width:64px;height:64px}.filter-bar{display:flex;gap:var(--space-sm);overflow-x:auto;padding:var(--space-sm) 0;-webkit-overflow-scrolling:touch;scrollbar-width:none}.filter-bar::-webkit-scrollbar{display:none}.filter-chip{padding:6px 14px;border-radius:999px;border:1px solid var(--color-border);background:var(--color-surface);font-size:var(--font-size-xs);font-weight:600;font-family:inherit;white-space:nowrap;cursor:pointer;min-height:34px;display:inline-flex;align-items:center;gap:var(--space-xs);transition:all var(--transition-fast);color:var(--color-text-secondary);-webkit-tap-highlight-color:transparent;letter-spacing:.01em}.filter-chip:hover{border-color:var(--color-text-secondary);color:var(--color-text)}.filter-chip--active{background:var(--color-accent);color:#fff;border-color:var(--color-accent);box-shadow:0 1px 3px #c0542e33}.filter-chip--active:hover{background:var(--color-accent-hover);border-color:var(--color-accent-hover);color:#fff}.quick-add-sheet .modal-overlay{align-items:flex-end}.quick-add-sheet .modal-content{max-width:100%;border-radius:var(--radius-xl) var(--radius-xl) 0 0;padding:var(--space-xl);padding-bottom:calc(var(--space-xl) + var(--safe-bottom));animation:quick-add-sheet-in var(--transition-normal) both}@keyframes quick-add-sheet-in{0%{transform:translateY(100%)}to{transform:translateY(0)}}.quick-add-sheet__title{font-family:var(--font-display);font-size:var(--font-size-xl);font-weight:400;margin-bottom:var(--space-xl);text-align:center}.quick-add-sheet__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--space-md);padding:var(--space-md) 0}.quick-add-sheet__option{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--space-sm);padding:var(--space-xl) var(--space-md);background:var(--color-bg);border:1px solid var(--color-border-light);border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast);min-height:100px;text-decoration:none;color:var(--color-text);font-size:var(--font-size-sm);font-weight:600;font-family:inherit;text-align:center}.quick-add-sheet__option:hover{border-color:var(--color-accent);background:var(--color-accent-subtle)}.quick-add-sheet__option:active{transform:scale(.97)}.quick-add-sheet__option-icon{width:28px;height:28px;color:var(--color-accent)}.search-modal .modal-content{padding:0;max-width:640px;overflow:hidden}.search-modal__input-wrapper{position:relative;display:flex;align-items:center}.search-modal__input{width:100%;padding:var(--space-md) var(--space-lg);padding-left:48px;border:none;border-bottom:1px solid var(--color-border-light);font-size:var(--font-size-lg);font-family:inherit;outline:none;background:transparent;color:var(--color-text)}.search-modal__input::placeholder{color:var(--color-text-secondary);opacity:.7}.search-modal__input-icon{position:absolute;left:var(--space-md);width:20px;height:20px;color:var(--color-text-secondary);pointer-events:none}.search-modal__kbd{position:absolute;right:var(--space-md);font-size:11px;color:var(--color-text-secondary);background:var(--color-bg-secondary);padding:2px 8px;border-radius:4px;border:1px solid var(--color-border);font-family:inherit;font-weight:600}.search-modal__results{max-height:60vh;overflow-y:auto;padding:var(--space-sm)}.search-modal__empty{padding:var(--space-2xl) var(--space-lg);text-align:center;color:var(--color-text-secondary)}.search-result{padding:10px var(--space-md);display:flex;gap:var(--space-md);align-items:center;border-radius:var(--radius-sm);cursor:pointer;transition:background var(--transition-fast);text-decoration:none;color:var(--color-text)}.search-result:hover,.search-result--focused{background:var(--color-bg-secondary)}.search-result__icon{width:38px;height:38px;flex-shrink:0;display:flex;align-items:center;justify-content:center;background:var(--color-bg-secondary);border-radius:var(--radius-sm);color:var(--color-text-secondary)}.search-result__info{flex:1;min-width:0}.search-result__title{font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-size:var(--font-size-base)}.search-result__meta{font-size:var(--font-size-xs);color:var(--color-text-secondary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}@media(max-width:767px){.search-modal__kbd{display:none}}.photo-uploader__capture{width:100%;min-height:48px;border:2px dashed var(--color-border);border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;gap:var(--space-sm);background:var(--color-bg);color:var(--color-text-secondary);font-size:var(--font-size-sm);font-weight:500;font-family:inherit;cursor:pointer;transition:all var(--transition-fast);padding:var(--space-md)}.photo-uploader__capture:hover{border-color:var(--color-accent);color:var(--color-accent);background:var(--color-accent-subtle)}.photo-uploader__capture-icon{width:20px;height:20px}.photo-uploader__grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(80px,1fr));gap:var(--space-sm);margin-top:var(--space-md)}.photo-uploader__thumb{aspect-ratio:1;border-radius:var(--radius-sm);overflow:hidden;position:relative;background:var(--color-bg-secondary)}.photo-uploader__thumb img{width:100%;height:100%;object-fit:cover;display:block}.photo-uploader__remove{position:absolute;top:4px;right:4px;width:22px;height:22px;border-radius:50%;background:#2a2016a6;color:#fff;border:none;display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:13px;line-height:1;transition:background var(--transition-fast);padding:0}.photo-uploader__remove:hover{background:#2a2016d9}.location-picker{position:relative}.location-picker__trigger{width:100%;padding:12px var(--space-md);border:1px solid var(--color-border);border-radius:var(--radius-sm);font-size:var(--font-size-base);font-family:inherit;background:var(--color-surface);cursor:pointer;display:flex;align-items:center;justify-content:space-between;min-height:46px;transition:border-color var(--transition-fast),box-shadow var(--transition-fast);color:var(--color-text)}.location-picker__trigger:focus{border-color:var(--color-accent);outline:none;box-shadow:0 0 0 3px #c0542e1a}.location-picker__trigger--placeholder{color:var(--color-text-secondary);opacity:.7}.location-picker__chevron{width:14px;height:14px;color:var(--color-text-secondary);flex-shrink:0}.location-picker__dropdown{position:absolute;top:calc(100% + var(--space-xs));left:0;right:0;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-sm);box-shadow:var(--shadow-lg);z-index:50;max-height:240px;overflow-y:auto}.location-picker__option{padding:10px var(--space-md);cursor:pointer;transition:background var(--transition-fast);display:flex;align-items:center;gap:var(--space-sm);font-size:var(--font-size-base)}.location-picker__option:hover{background:var(--color-bg-secondary)}.location-picker__option--selected{color:var(--color-accent);font-weight:600}.location-picker__add{padding:10px var(--space-md);color:var(--color-accent);font-weight:600;cursor:pointer;border-top:1px solid var(--color-border-light);display:flex;align-items:center;gap:var(--space-sm);font-size:var(--font-size-sm);transition:background var(--transition-fast)}.location-picker__add:hover{background:var(--color-bg-secondary)}.photo-lightbox{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1200;background:#f0f2f5f2;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;animation:photo-lightbox-in var(--transition-normal) both}@keyframes photo-lightbox-in{0%{opacity:0}to{opacity:1}}.photo-lightbox__img{max-width:90vw;max-height:90vh;object-fit:contain;border-radius:var(--radius-sm);box-shadow:0 4px 24px #00000026;animation:photo-lightbox-img-in var(--transition-normal) both}@keyframes photo-lightbox-img-in{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}.photo-lightbox__close{position:absolute;top:var(--space-lg);right:var(--space-lg);width:40px;height:40px;border-radius:50%;background:#0000000f;color:#3a3f47;border:none;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:background var(--transition-fast);z-index:1}.photo-lightbox__close:hover{background:#0000001f}.photo-lightbox__nav{position:absolute;top:50%;transform:translateY(-50%);width:44px;height:44px;border-radius:50%;background:#0000000f;color:#3a3f47;border:none;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:background var(--transition-fast);z-index:1}.photo-lightbox__nav:hover{background:#0000001f}.photo-lightbox__nav--prev{left:var(--space-lg)}.photo-lightbox__nav--next{right:var(--space-lg)}.photo-lightbox__counter{position:absolute;bottom:var(--space-lg);left:50%;transform:translate(-50%);color:#5a6069;font-size:var(--font-size-sm);font-weight:500;background:#0000000f;padding:4px 14px;border-radius:999px}@media(max-width:767px){.photo-lightbox__nav{width:36px;height:36px}.photo-lightbox__nav--prev{left:var(--space-sm)}.photo-lightbox__nav--next{right:var(--space-sm)}.photo-lightbox__close{top:var(--space-md);right:var(--space-md)}}.form-group{margin-bottom:var(--space-lg)}.form-label{display:block;font-size:var(--font-size-sm);font-weight:600;margin-bottom:6px;color:var(--color-text);letter-spacing:.01em}.form-label--required:after{content:" *";color:var(--color-accent)}.form-input,.form-select,.form-textarea{width:100%;padding:12px var(--space-md);border:1px solid var(--color-border);border-radius:var(--radius-sm);font-size:var(--font-size-base);font-family:inherit;background:var(--color-surface);color:var(--color-text);min-height:46px;transition:border-color var(--transition-fast),box-shadow var(--transition-fast);-webkit-appearance:none;-moz-appearance:none;appearance:none}.form-input::placeholder,.form-textarea::placeholder{color:var(--color-text-secondary);opacity:.7}.form-input:focus,.form-select:focus,.form-textarea:focus{border-color:var(--color-accent);outline:none;box-shadow:0 0 0 3px #c0542e1a}.form-input:disabled,.form-select:disabled,.form-textarea:disabled{background:var(--color-bg-secondary);color:var(--color-text-secondary);cursor:not-allowed}.form-select{background-image:url("data:image/svg+xml,%3Csvg width='12' height='8' viewBox='0 0 12 8' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M1 1.5L6 6.5L11 1.5' stroke='%238c7e6a' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right var(--space-md) center;padding-right:calc(var(--space-md) + 24px)}.form-textarea{min-height:100px;resize:vertical;line-height:1.55}.form-error{font-size:var(--font-size-xs);color:var(--color-danger);margin-top:var(--space-xs);font-weight:500}.form-hint{font-size:var(--font-size-xs);color:var(--color-text-secondary);margin-top:var(--space-xs)}.form-input--error,.form-select--error,.form-textarea--error{border-color:var(--color-danger)}.form-input--error:focus,.form-select--error:focus,.form-textarea--error:focus{box-shadow:0 0 0 3px #b33d3d1a}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-sm);padding:12px var(--space-lg);border-radius:var(--radius-sm);font-size:var(--font-size-sm);font-weight:600;font-family:inherit;cursor:pointer;border:none;min-height:44px;text-decoration:none;white-space:nowrap;transition:all var(--transition-fast);-webkit-tap-highlight-color:transparent;letter-spacing:.01em}.btn:disabled{opacity:.45;cursor:not-allowed}.btn--primary{background:var(--color-accent);color:#fff;box-shadow:0 1px 3px #c0542e33}.btn--primary:hover:not(:disabled){background:var(--color-accent-hover);box-shadow:0 2px 6px #c0542e4d;transform:translateY(-1px)}.btn--primary:active:not(:disabled){transform:translateY(0);box-shadow:0 1px 3px #c0542e33}.btn--secondary{background:var(--color-surface);color:var(--color-text);border:1px solid var(--color-border)}.btn--secondary:hover:not(:disabled){background:var(--color-bg-secondary);border-color:var(--color-text-secondary)}.btn--danger{background:var(--color-danger);color:#fff;box-shadow:0 1px 3px #b33d3d33}.btn--danger:hover:not(:disabled){background:#9c3535}.btn--danger:active:not(:disabled){transform:scale(.98)}.btn--ghost{background:none;color:var(--color-text-secondary);padding:var(--space-sm);min-height:auto}.btn--ghost:hover:not(:disabled){color:var(--color-text);background:var(--color-bg-secondary)}.btn--full{width:100%}.btn--sm{min-height:34px;padding:6px var(--space-md);font-size:var(--font-size-xs)}.btn__icon{width:16px;height:16px;flex-shrink:0}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-md)}@media(max-width:767px){.form-row{grid-template-columns:1fr}}.form-more-toggle{background:none;border:none;color:var(--color-accent);font-size:var(--font-size-sm);font-weight:600;font-family:inherit;cursor:pointer;padding:var(--space-sm) 0;display:inline-flex;align-items:center;gap:var(--space-xs);transition:opacity var(--transition-fast)}.form-more-toggle:hover{opacity:.8}.form-more-toggle__icon{width:14px;height:14px;transition:transform var(--transition-fast)}.form-more-toggle--expanded .form-more-toggle__icon{transform:rotate(180deg)}.form-more-content{overflow:hidden;transition:max-height var(--transition-normal);max-height:0}.form-more-content--visible{max-height:1000px}.form-checkbox{display:flex;align-items:center;gap:var(--space-sm);cursor:pointer;min-height:44px}.form-checkbox input[type=checkbox],.form-checkbox input[type=radio]{width:18px;height:18px;accent-color:var(--color-accent);cursor:pointer;flex-shrink:0}.form-checkbox__label{font-size:var(--font-size-base);-webkit-user-select:none;user-select:none}.form-actions{display:flex;gap:var(--space-sm);justify-content:flex-end;padding-top:var(--space-lg)}.form-actions--sticky{position:sticky;bottom:0;background:var(--color-surface);border-top:1px solid var(--color-border);margin-top:var(--space-lg);padding:var(--space-md) 0}@media(max-width:767px){.form-actions{flex-direction:column-reverse}.form-actions .btn{width:100%}}.form-color-picker{display:flex;align-items:center;gap:var(--space-sm)}.form-color-input{width:46px;height:46px;border:1px solid var(--color-border);border-radius:var(--radius-sm);cursor:pointer;padding:2px;background:none;flex-shrink:0}.form-color-picker .form-input{flex:1}.form-check{display:flex;align-items:center;gap:var(--space-sm);cursor:pointer;min-height:44px}.form-check input[type=checkbox],.form-check input[type=radio]{width:18px;height:18px;accent-color:var(--color-accent);cursor:pointer;flex-shrink:0}.form-check--sm{min-height:32px;font-size:var(--font-size-sm)}.form-check--sm input[type=checkbox]{width:16px;height:16px}.modal-footer-stack{display:flex;flex-direction:column;gap:var(--space-sm);align-items:center;width:100%}.locations-page{max-width:1000px;margin:0 auto;padding:var(--space-lg) var(--space-md)}.locations-grid{display:grid;gap:var(--space-lg);grid-template-columns:repeat(3,1fr)}@media(min-width:768px)and (max-width:1023px){.locations-grid{grid-template-columns:repeat(2,1fr)}}@media(max-width:767px){.locations-grid{grid-template-columns:1fr;gap:var(--space-md)}}.location-card{background:var(--color-surface);border:1px solid var(--color-border-light);border-radius:var(--radius-lg);padding:var(--space-lg);display:flex;flex-direction:column;gap:var(--space-xs);cursor:pointer;text-decoration:none;color:var(--color-text);box-shadow:var(--shadow-xs);transition:box-shadow var(--transition-normal),transform var(--transition-normal),border-color var(--transition-normal)}.location-card:hover{box-shadow:var(--shadow-md);transform:translateY(-1px);border-color:var(--color-border)}.location-card:active{transform:translateY(0);box-shadow:var(--shadow-sm)}.location-card:focus-visible{outline:2px solid var(--color-accent);outline-offset:2px}.location-card__icon{width:36px;height:36px;color:var(--color-accent);margin-bottom:var(--space-sm);flex-shrink:0}.location-card__name{font-family:var(--font-display);font-weight:400;font-size:var(--font-size-lg);color:var(--color-text);letter-spacing:-.01em;line-height:1.3}.location-card__meta{font-size:var(--font-size-sm);color:var(--color-text-secondary);margin-top:var(--space-xs);line-height:1.45}.location-card__counts{display:flex;gap:var(--space-md);margin-top:var(--space-md);padding-top:var(--space-md);border-top:1px solid var(--color-border-light);font-size:var(--font-size-sm);color:var(--color-text-secondary)}.location-card__count{display:flex;align-items:center;gap:6px}.location-card__count-icon{width:14px;height:14px;opacity:.55;flex-shrink:0}.location-detail{max-width:800px;margin:0 auto;padding:var(--space-lg) var(--space-md)}.location-detail__header{padding-bottom:var(--space-lg);border-bottom:1px solid var(--color-border-light);margin-bottom:var(--space-xl)}.location-detail__title{font-family:var(--font-display);font-size:var(--font-size-2xl);font-weight:400;color:var(--color-text);letter-spacing:-.01em;line-height:1.2}.location-detail__meta{font-size:var(--font-size-sm);color:var(--color-text-secondary);margin-top:var(--space-sm);line-height:1.5}.location-detail__actions{display:flex;gap:var(--space-sm);margin-top:var(--space-lg);flex-wrap:wrap}.location-detail__section{margin-bottom:var(--space-xl)}.section-header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-md) 0;gap:var(--space-md)}.section-header__title{font-family:var(--font-display);font-size:var(--font-size-lg);font-weight:400;letter-spacing:-.01em;color:var(--color-text);display:flex;align-items:center;gap:var(--space-sm)}.section-header__action{font-size:var(--font-size-sm);font-weight:600;font-family:var(--font-family);color:var(--color-accent);background:none;border:none;cursor:pointer;padding:var(--space-xs) var(--space-sm);border-radius:var(--radius-sm);transition:background var(--transition-fast),color var(--transition-fast);white-space:nowrap}.section-header__action:hover{background:var(--color-accent-subtle);color:var(--color-accent-hover)}.section-header__action:active{background:#c0542e1f}.section-header__action:focus-visible{outline:2px solid var(--color-accent);outline-offset:2px}.location-detail__item{display:flex;align-items:center;justify-content:space-between;padding:var(--space-md) var(--space-sm);border-bottom:1px solid var(--color-border-light);gap:var(--space-md);transition:background var(--transition-fast)}.location-detail__item:last-child{border-bottom:none}.location-detail__item:hover{background:var(--color-accent-subtle);border-radius:var(--radius-sm)}.location-detail__item-meta{font-size:var(--font-size-sm);color:var(--color-text-secondary);flex-shrink:0}.location-detail__empty-hint{padding:var(--space-2xl) var(--space-lg);text-align:center;color:var(--color-text-secondary);font-size:var(--font-size-sm);line-height:1.6;background:var(--color-bg-secondary);border-radius:var(--radius-md);border:1px dashed var(--color-border)}.location-detail__notes{color:var(--color-text-secondary);font-size:var(--font-size-base);line-height:1.7;margin-bottom:var(--space-xl)}.assets-page{max-width:1000px;margin:0 auto;padding:var(--space-lg) var(--space-md)}.assets-list{display:grid;gap:var(--space-lg);grid-template-columns:repeat(3,1fr)}@media(min-width:768px)and (max-width:1023px){.assets-list{grid-template-columns:repeat(2,1fr)}}@media(max-width:767px){.assets-list{grid-template-columns:1fr;gap:var(--space-md)}}.asset-card{background:var(--color-surface);border:1px solid var(--color-border-light);border-radius:var(--radius-lg);overflow:hidden;cursor:pointer;text-decoration:none;color:var(--color-text);box-shadow:var(--shadow-xs);display:flex;flex-direction:column;transition:box-shadow var(--transition-normal),transform var(--transition-normal),border-color var(--transition-normal)}.asset-card:hover{box-shadow:var(--shadow-md);transform:translateY(-1px);border-color:var(--color-border)}.asset-card:active{transform:translateY(0);box-shadow:var(--shadow-sm)}.asset-card:focus-visible{outline:2px solid var(--color-accent);outline-offset:2px}.asset-card__photo{aspect-ratio:4 / 3;overflow:hidden;background:var(--color-bg-secondary);display:flex;align-items:center;justify-content:center;flex-shrink:0}.asset-card__photo img{width:100%;height:100%;object-fit:cover;display:block;transition:transform var(--transition-normal)}.asset-card:hover .asset-card__photo img{transform:scale(1.03)}.asset-card__photo-placeholder{width:40px;height:40px;color:var(--color-text-secondary);opacity:.25}.asset-card__info{padding:var(--space-md) var(--space-lg);flex:1;display:flex;flex-direction:column;gap:2px;min-width:0}.asset-card__name{font-family:var(--font-display);font-weight:400;font-size:var(--font-size-base);letter-spacing:-.01em;color:var(--color-text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;line-height:1.35}.asset-card__location{font-size:var(--font-size-sm);color:var(--color-text-secondary);margin-top:var(--space-xs);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;line-height:1.4}.asset-card__make{font-size:var(--font-size-xs);color:var(--color-text-secondary);margin-top:2px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;text-transform:uppercase;letter-spacing:.03em}.asset-card__warranty{margin-top:var(--space-sm)}@media(max-width:767px){.asset-card{flex-direction:row}.asset-card__photo{width:110px;min-height:110px;aspect-ratio:1;border-radius:0}.asset-card__info{padding:var(--space-md);justify-content:center}}.asset-detail{max-width:800px;margin:0 auto;padding:var(--space-lg) var(--space-md)}.asset-detail__header{margin-bottom:var(--space-xl);padding-bottom:var(--space-lg);border-bottom:1px solid var(--color-border-light)}.asset-detail__title{font-family:var(--font-display);font-size:var(--font-size-2xl);font-weight:400;color:var(--color-text);letter-spacing:-.01em;line-height:1.2}.asset-detail__subtitle{font-size:var(--font-size-sm);color:var(--color-text-secondary);margin-top:var(--space-sm);line-height:1.5}.asset-detail__actions{display:flex;gap:var(--space-sm);margin-top:var(--space-lg);flex-wrap:wrap}.asset-detail__photos{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:var(--space-md);margin-bottom:var(--space-xl)}.asset-detail__photos img{width:100%;aspect-ratio:4 / 3;object-fit:cover;border-radius:var(--radius-md);background:var(--color-bg-secondary);display:block;border:1px solid var(--color-border-light);transition:box-shadow var(--transition-normal)}.asset-detail__photos img:hover{box-shadow:var(--shadow-md)}@media(max-width:767px){.asset-detail__photos{display:flex;overflow-x:auto;gap:var(--space-sm);padding-bottom:var(--space-sm);-webkit-overflow-scrolling:touch;scroll-snap-type:x mandatory;scrollbar-width:none}.asset-detail__photos::-webkit-scrollbar{display:none}.asset-detail__photos img{min-width:260px;flex-shrink:0;scroll-snap-align:start}}.asset-detail__info-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:0 var(--space-xl);margin-bottom:var(--space-xl)}@media(max-width:767px){.asset-detail__info-grid{grid-template-columns:1fr}}.asset-detail__field{padding:var(--space-md) 0;border-bottom:1px solid var(--color-border-light)}.asset-detail__field:last-child{border-bottom:none}.asset-detail__field-label{font-size:var(--font-size-xs);font-weight:600;color:var(--color-text-secondary);margin-bottom:var(--space-xs);text-transform:uppercase;letter-spacing:.04em}.asset-detail__field-value{font-weight:500;font-size:var(--font-size-base);color:var(--color-text);line-height:1.5}.asset-detail__field-value--empty{color:var(--color-text-secondary);font-style:italic;font-weight:400;opacity:.7}.asset-detail__section-title{font-family:var(--font-display);font-size:var(--font-size-lg);font-weight:400;letter-spacing:-.01em;color:var(--color-text);margin-bottom:var(--space-md);margin-top:var(--space-xl);padding-bottom:var(--space-sm);border-bottom:1px solid var(--color-border-light)}.asset-detail__notes{margin-bottom:var(--space-xl)}.asset-detail__notes p{color:var(--color-text-secondary);font-size:var(--font-size-base);line-height:1.7}.quick-capture__camera-btn{width:100%;height:140px;border:2px dashed var(--color-border);border-radius:var(--radius-lg);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--space-sm);background:var(--color-bg-secondary);cursor:pointer;color:var(--color-text-secondary);font-size:var(--font-size-sm);font-weight:500;font-family:var(--font-family);transition:border-color var(--transition-normal),color var(--transition-normal),background var(--transition-normal)}.quick-capture__camera-btn:hover{border-color:var(--color-accent);color:var(--color-accent);background:var(--color-accent-subtle)}.quick-capture__camera-btn:active{transform:scale(.98)}.quick-capture__camera-btn:focus-visible{outline:2px solid var(--color-accent);outline-offset:2px}.quick-capture__camera-icon{width:32px;height:32px;opacity:.7}.quick-capture__camera-btn:hover .quick-capture__camera-icon{opacity:1}.quick-capture__preview{margin-top:var(--space-md);position:relative;border-radius:var(--radius-md);overflow:hidden;box-shadow:var(--shadow-sm)}.quick-capture__preview img{width:100%;display:block;border-radius:var(--radius-md)}.quick-capture__preview-remove{position:absolute;top:var(--space-sm);right:var(--space-sm);width:32px;height:32px;border-radius:50%;background:#2a2016a6;color:#fff;border:none;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:background var(--transition-fast),transform var(--transition-fast);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.quick-capture__preview-remove:hover{background:#2a2016d9;transform:scale(1.1)}.quick-capture__preview-remove:focus-visible{outline:2px solid #ffffff;outline-offset:2px}.finishes-page{max-width:1000px}.finishes-list{display:grid;gap:var(--space-md);grid-template-columns:repeat(3,1fr)}@media(min-width:768px)and (max-width:1023px){.finishes-list{grid-template-columns:repeat(2,1fr)}}@media(max-width:767px){.finishes-list{grid-template-columns:1fr}}.finish-card{background:var(--color-surface);border:1px solid var(--color-border-light);border-radius:var(--radius-md);padding:var(--space-lg);cursor:pointer;transition:box-shadow var(--transition-fast),border-color var(--transition-fast),transform var(--transition-fast);text-decoration:none;color:var(--color-text);box-shadow:var(--shadow-xs);display:block}.finish-card:hover{box-shadow:var(--shadow-md);border-color:var(--color-border);transform:translateY(-1px)}.finish-card:active{transform:translateY(0);box-shadow:var(--shadow-xs)}.finish-card:focus-visible{outline:2px solid var(--color-accent);outline-offset:2px}.finish-card__header{display:flex;align-items:center;gap:var(--space-md)}.finish-card__swatch{width:40px;height:40px;border-radius:50%;border:2px solid var(--color-border);flex-shrink:0;box-shadow:inset 0 1px 2px #0000000f}.finish-card__title{flex:1;min-width:0}.finish-card__name{font-weight:600;font-size:var(--font-size-base);color:var(--color-text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.finish-card__brand{font-size:var(--font-size-sm);color:var(--color-text-secondary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;margin-top:2px}.finish-card__code{font-size:var(--font-size-sm);color:var(--color-text-secondary);margin-top:var(--space-xs)}.finish-card__surfaces{margin-top:var(--space-sm);display:flex;flex-wrap:wrap;gap:var(--space-xs)}.finish-card__surface-tag{font-size:var(--font-size-xs);font-weight:600;background:var(--color-bg-secondary);padding:2px 10px;border-radius:999px;color:var(--color-text-secondary);white-space:nowrap;letter-spacing:.01em}.finish-detail{max-width:800px;margin:0 auto}.finish-detail__header{display:flex;align-items:flex-start;gap:var(--space-lg);padding:var(--space-lg) 0;border-bottom:1px solid var(--color-border-light);margin-bottom:var(--space-xl)}.finish-detail__swatch{width:64px;height:64px;border-radius:50%;border:2px solid var(--color-border);flex-shrink:0;box-shadow:inset 0 1px 3px #0000000f}.finish-detail__title-area{flex:1;min-width:0}.finish-detail__name{font-family:var(--font-display);font-size:var(--font-size-xl);font-weight:400;letter-spacing:-.01em;color:var(--color-text)}.finish-detail__brand{font-size:var(--font-size-sm);color:var(--color-text-secondary);margin-top:var(--space-xs)}.finish-detail__actions{display:flex;gap:var(--space-sm);flex-shrink:0;margin-top:var(--space-xs)}.finish-detail__title{font-family:var(--font-display);font-size:var(--font-size-xl);font-weight:400;letter-spacing:-.01em;color:var(--color-text)}.finish-detail__code{font-size:var(--font-size-sm);color:var(--color-text-secondary);margin-top:var(--space-xs)}.finish-detail__info-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--space-md);margin-bottom:var(--space-xl)}@media(max-width:767px){.finish-detail__info-grid{grid-template-columns:1fr}}.finish-detail__field{padding:var(--space-md) 0;border-bottom:1px solid var(--color-border-light)}.finish-detail__field:last-child{border-bottom:none}.finish-detail__field-label{font-size:var(--font-size-xs);text-transform:uppercase;letter-spacing:.05em;color:var(--color-text-secondary);font-weight:600;margin-bottom:var(--space-xs)}.finish-detail__field-value{font-size:var(--font-size-base);font-weight:500;color:var(--color-text)}.finish-detail__section,.finish-detail__surfaces{margin-bottom:var(--space-xl)}.finish-detail__surfaces h3{font-family:var(--font-display);font-size:var(--font-size-lg);font-weight:400;letter-spacing:-.01em;color:var(--color-text);margin-bottom:var(--space-md)}.finish-detail__surface-item{display:flex;align-items:center;gap:var(--space-sm);padding:var(--space-md) 0;border-bottom:1px solid var(--color-border-light);font-size:var(--font-size-base);color:var(--color-text)}.finish-detail__surface-item:last-child{border-bottom:none}.finish-detail__surface-desc{font-size:var(--font-size-sm);color:var(--color-text-secondary);line-height:1.5}.finish-detail__notes{margin-bottom:var(--space-xl)}.finish-detail__notes h3{font-family:var(--font-display);font-size:var(--font-size-lg);font-weight:400;letter-spacing:-.01em;color:var(--color-text);margin-bottom:var(--space-sm)}.finish-detail__notes p{color:var(--color-text-secondary);line-height:1.6;font-size:var(--font-size-base);margin:0}.surface-entry{display:flex;gap:var(--space-sm);align-items:flex-end;margin-bottom:var(--space-sm);padding:var(--space-sm);border-radius:var(--radius-sm);transition:background var(--transition-fast)}.surface-entry:hover{background:var(--color-bg-secondary)}.surface-entry__fields{flex:1;display:grid;grid-template-columns:1fr 1fr;gap:var(--space-sm)}.surface-entry__location{flex:1}.surface-entry__remove{flex-shrink:0;width:36px;height:36px;border-radius:50%;background:none;border:none;color:var(--color-text-secondary);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:color var(--transition-fast),background var(--transition-fast)}.surface-entry__remove:hover{color:var(--color-danger);background:var(--color-danger-subtle)}.surface-entry__remove:focus-visible{outline:2px solid var(--color-danger);outline-offset:2px}.surface-entries__add{display:inline-flex;align-items:center;gap:var(--space-xs);color:var(--color-accent);background:none;border:none;font-size:var(--font-size-sm);font-weight:600;font-family:inherit;cursor:pointer;padding:var(--space-sm) var(--space-md);border-radius:var(--radius-sm);transition:background var(--transition-fast),color var(--transition-fast)}.surface-entries__add:hover{background:var(--color-accent-subtle);color:var(--color-accent-hover)}.surface-entries__add:focus-visible{outline:2px solid var(--color-accent);outline-offset:2px}@media(max-width:767px){.finish-detail__header{flex-direction:column;align-items:flex-start;gap:var(--space-md)}.surface-entry__fields{grid-template-columns:1fr}.surface-entry{flex-direction:column;align-items:stretch}.surface-entry__remove{align-self:flex-end}}.search-page{max-width:800px;margin:0 auto}.search-page__input-wrapper{position:relative;margin-bottom:var(--space-xl)}.search-page__input{width:100%;height:54px;padding:var(--space-md) var(--space-lg);padding-left:48px;border:1px solid var(--color-border);border-radius:var(--radius-md);font-size:var(--font-size-lg);font-family:inherit;background:var(--color-surface);color:var(--color-text);transition:border-color var(--transition-fast),box-shadow var(--transition-fast);box-shadow:var(--shadow-xs)}.search-page__input::placeholder{color:var(--color-text-secondary);opacity:.7}.search-page__input:focus{border-color:var(--color-accent);outline:none;box-shadow:0 0 0 3px #c0542e1a}.search-page__icon{position:absolute;left:var(--space-md);top:50%;transform:translateY(-50%);width:20px;height:20px;color:var(--color-text-secondary);pointer-events:none}.search-results{display:flex;flex-direction:column;gap:var(--space-xs)}.search-result-group{margin-bottom:var(--space-xl)}.search-result-group__title{font-size:var(--font-size-xs);font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:var(--color-text-secondary);padding:var(--space-sm) 0;border-bottom:1px solid var(--color-border-light);margin-bottom:var(--space-sm)}.search-results__empty{text-align:center;padding:var(--space-3xl) var(--space-lg);color:var(--color-text-secondary)}.search-results__empty-icon{width:48px;height:48px;margin:0 auto var(--space-md);opacity:.3}.search-recent{margin-bottom:var(--space-xl)}.search-recent__title{font-size:var(--font-size-xs);font-weight:600;color:var(--color-text-secondary);margin-bottom:var(--space-sm);text-transform:uppercase;letter-spacing:.06em}.search-recent__item{display:flex;align-items:center;gap:var(--space-sm);padding:var(--space-sm) 0;color:var(--color-text-secondary);font-size:var(--font-size-sm);cursor:pointer;transition:color var(--transition-fast)}.search-recent__item:hover{color:var(--color-text)}.search-recent__icon{width:16px;height:16px;opacity:.4}.search-shortcuts{display:flex;gap:var(--space-lg);justify-content:center;padding:var(--space-lg) 0;color:var(--color-text-secondary);font-size:var(--font-size-xs)}.search-shortcut{display:flex;align-items:center;gap:var(--space-xs)}.search-shortcut__key{background:var(--color-bg-secondary);padding:2px 6px;border-radius:4px;border:1px solid var(--color-border);font-family:inherit;font-size:10px;font-weight:600}@media(max-width:767px){.search-shortcuts{display:none}}.search-page__loading{text-align:center;padding:var(--space-xl);color:var(--color-text-secondary)}.search-page__empty{text-align:center;padding:var(--space-3xl) var(--space-lg);color:var(--color-text-secondary)}.search-page__empty-icon{opacity:.3;margin-bottom:var(--space-md)}.dashboard{max-width:800px;margin:0 auto;padding:var(--space-lg)}.dashboard__greeting{margin-bottom:var(--space-2xl)}.dashboard__greeting h1{font-family:var(--font-display);font-size:var(--font-size-3xl);font-weight:400;color:var(--color-text);letter-spacing:-.02em;line-height:1.2}.dashboard__greeting p{color:var(--color-text-secondary);font-size:var(--font-size-base);margin-top:var(--space-sm)}.dashboard__section{margin-bottom:var(--space-2xl)}.dashboard__section-title{font-family:var(--font-display);font-size:var(--font-size-lg);font-weight:400;margin-bottom:var(--space-md);display:flex;align-items:center;gap:var(--space-sm);color:var(--color-text)}.dashboard__section-title-icon{width:18px;height:18px;color:var(--color-text-secondary)}.dashboard__all-clear{text-align:center;padding:var(--space-3xl) var(--space-lg);color:var(--color-success)}.dashboard__all-clear p{color:var(--color-text-secondary);margin-top:var(--space-sm);font-size:var(--font-size-base)}.dashboard__stats{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--space-md);margin-bottom:var(--space-2xl)}@media(max-width:767px){.dashboard__stats{grid-template-columns:repeat(2,1fr);gap:10px}}.dashboard__stat{background:var(--color-surface);border:1px solid var(--color-border-light);border-radius:var(--radius-md);padding:var(--space-lg) var(--space-md);text-align:center;cursor:pointer;transition:all var(--transition-fast);display:flex;flex-direction:column;align-items:center;gap:var(--space-xs);box-shadow:var(--shadow-xs)}.dashboard__stat:hover{border-color:var(--color-accent);transform:translateY(-2px);box-shadow:var(--shadow-md)}.dashboard__stat:active{transform:translateY(0)}.dashboard__stat-icon{color:var(--color-accent);opacity:.7}.dashboard__stat-card{background:var(--color-surface);border:1px solid var(--color-border-light);border-radius:var(--radius-md);padding:var(--space-lg);text-align:center}.dashboard__stat-value{font-family:var(--font-display);font-size:var(--font-size-2xl);font-weight:400;color:var(--color-text)}.dashboard__stat-label{font-size:var(--font-size-xs);font-weight:600;color:var(--color-text-secondary);letter-spacing:.03em;text-transform:uppercase}.dashboard__task-card{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-sm);gap:var(--space-md)}.dashboard__task-info{flex:1;min-width:0}.dashboard__task-name{font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-size:var(--font-size-base)}.dashboard__task-meta{display:flex;align-items:center;gap:var(--space-sm);font-size:var(--font-size-xs);color:var(--color-text-secondary);margin-top:3px}.dashboard__task-done-btn{background:none;border:none;color:var(--color-text-secondary);cursor:pointer;padding:var(--space-sm);border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;transition:all var(--transition-fast);flex-shrink:0;-webkit-tap-highlight-color:transparent}.dashboard__task-done-btn:hover{color:var(--color-success);background:var(--color-success-subtle)}.dashboard__view-all{background:none;border:none;color:var(--color-accent);font-size:var(--font-size-sm);font-family:inherit;font-weight:600;cursor:pointer;padding:var(--space-sm) 0;margin-top:var(--space-xs)}.dashboard__view-all:hover{text-decoration:underline}.dashboard__improvement-card{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-sm);gap:var(--space-md)}.dashboard__improvement-info{flex:1;min-width:0}.dashboard__improvement-title{font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-size:var(--font-size-base)}.dashboard__improvement-meta{display:flex;align-items:center;gap:var(--space-sm);font-size:var(--font-size-xs);color:var(--color-text-secondary);margin-top:3px}.dashboard__improvement-meta span:not(:last-child):after{content:"·";margin-left:var(--space-sm)}.dashboard__warranty-card{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-sm)}.activity-item{padding:var(--space-md) 0;border-bottom:1px solid var(--color-border-light);display:flex;gap:var(--space-md);align-items:center}.activity-item:last-child{border-bottom:none}.activity-item--clickable{cursor:pointer;border-radius:var(--radius-sm);padding:var(--space-md);margin:0 calc(-1 * var(--space-md));transition:background var(--transition-fast)}.activity-item--clickable:hover{background:var(--color-bg-secondary)}.activity-item__icon{width:34px;height:34px;border-radius:50%;background:var(--color-bg-secondary);flex-shrink:0;display:flex;align-items:center;justify-content:center;color:var(--color-text-secondary)}.activity-item__icon svg{width:15px;height:15px}.activity-item__info{flex:1;min-width:0;display:flex;flex-direction:column}.activity-item__title{font-weight:500;font-size:var(--font-size-base);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.activity-item__type{font-size:var(--font-size-xs);color:var(--color-text-secondary);text-transform:capitalize}.activity-item__description{font-size:var(--font-size-sm);color:var(--color-text-secondary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.activity-item__time{font-size:var(--font-size-xs);color:var(--color-text-secondary);flex-shrink:0;white-space:nowrap}.onboarding{min-height:100dvh;display:flex;align-items:center;justify-content:center;background:linear-gradient(160deg,#f9f6f1,#ede4d6,#e8ddd0);padding:var(--space-lg)}.onboarding__card{max-width:560px;width:100%;background:var(--color-surface);border-radius:var(--radius-xl);padding:var(--space-2xl);box-shadow:var(--shadow-lg)}@media(max-width:767px){.onboarding__card{padding:var(--space-xl) var(--space-lg)}}.onboarding__step-indicator{display:flex;gap:var(--space-sm);justify-content:center;margin-bottom:var(--space-xl)}.onboarding__step-dot{width:8px;height:8px;border-radius:50%;background:var(--color-border);transition:all var(--transition-fast)}.onboarding__step-dot--active{background:var(--color-accent);transform:scale(1.3)}.onboarding__step-dot--completed{background:var(--color-success)}.onboarding__title{font-family:var(--font-display);font-size:var(--font-size-xl);font-weight:400;text-align:center;margin-bottom:var(--space-xs);color:var(--color-text)}.onboarding__description{color:var(--color-text-secondary);text-align:center;margin-bottom:var(--space-xl);line-height:1.55}.onboarding__content{margin-bottom:var(--space-xl)}.onboarding__footer{display:flex;align-items:center;justify-content:space-between;gap:var(--space-md)}.onboarding__skip{background:none;border:none;color:var(--color-text-secondary);font-size:var(--font-size-sm);font-family:inherit;cursor:pointer;padding:var(--space-sm);transition:color var(--transition-fast)}.onboarding__skip:hover{color:var(--color-text)}.room-checklist{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--space-sm)}@media(max-width:767px){.room-checklist{grid-template-columns:1fr}}.room-checklist__item{padding:12px var(--space-md);border:1px solid var(--color-border);border-radius:var(--radius-sm);display:flex;align-items:center;gap:var(--space-sm);cursor:pointer;min-height:46px;transition:all var(--transition-fast);-webkit-user-select:none;user-select:none;-webkit-tap-highlight-color:transparent}.room-checklist__item:hover{border-color:var(--color-text-secondary)}.room-checklist__item--selected{border-color:var(--color-accent);background:var(--color-accent-subtle)}.room-checklist__item--selected:hover{border-color:var(--color-accent)}.room-checklist__item input[type=checkbox]{width:18px;height:18px;accent-color:var(--color-accent);cursor:pointer;flex-shrink:0}.room-checklist__item-label{font-size:var(--font-size-base);font-weight:500}.room-checklist__item-icon{width:18px;height:18px;color:var(--color-text-secondary);flex-shrink:0}.room-custom-input{margin-top:var(--space-md);display:flex;gap:var(--space-sm)}.room-custom-input .form-input{flex:1}.onboarding__actions{display:flex;align-items:center;justify-content:flex-end;gap:var(--space-md);margin-top:var(--space-xl)}.onboarding__actions--center{justify-content:center}.onboarding__done-icon{display:flex;align-items:center;justify-content:center;width:80px;height:80px;border-radius:50%;background:var(--color-success-subtle);color:var(--color-success);margin:0 auto var(--space-lg)}.menu-page{max-width:600px;margin:0 auto;padding:var(--space-lg) 0}.menu-page__user{display:flex;align-items:center;gap:var(--space-md);padding:var(--space-lg) 0;border-bottom:1px solid var(--color-border-light);margin-bottom:var(--space-xl)}.menu-page__avatar{width:48px;height:48px;border-radius:50%;object-fit:cover;border:2px solid var(--color-border)}.menu-page__name{font-family:var(--font-display);font-weight:400;font-size:var(--font-size-xl)}.menu-page__email{font-size:var(--font-size-sm);color:var(--color-text-secondary)}.menu-page__items{display:flex;flex-direction:column;gap:var(--space-md);margin-bottom:var(--space-xl)}.menu-page__item{display:flex;align-items:center;gap:var(--space-md)}.menu-page__item-label{font-weight:500}.menu-page__item-desc{font-size:var(--font-size-sm);color:var(--color-text-secondary)}.menu-page__logout{margin-top:var(--space-xl)}.contractors-page{max-width:1200px;margin:0 auto}.contractors-list{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:var(--space-md)}.contractor-card{display:flex;justify-content:space-between;align-items:flex-start;gap:var(--space-md)}.contractor-card__info{flex:1;min-width:0}.contractor-card__name{font-weight:600;font-size:var(--font-size-base);color:var(--color-text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.contractor-card__trade{font-size:var(--font-size-sm);color:var(--color-text-secondary);text-transform:capitalize;margin-top:2px}.contractor-card__contact{font-size:var(--font-size-sm);color:var(--color-text-secondary);margin-top:var(--space-xs);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.contractor-card__right{display:flex;flex-direction:column;align-items:flex-end;gap:var(--space-xs);flex-shrink:0}.contractor-card__rating{font-size:var(--font-size-sm);color:var(--color-warning);letter-spacing:1px;line-height:1}.contractor-detail{max-width:800px;margin:0 auto}.contractor-detail__header{display:flex;justify-content:space-between;align-items:flex-start;gap:var(--space-lg);margin-bottom:var(--space-xl);padding-bottom:var(--space-lg);border-bottom:1px solid var(--color-border-light)}.contractor-detail__title{font-family:var(--font-display);font-size:var(--font-size-xl);font-weight:400;letter-spacing:-.01em;color:var(--color-text);margin:0 0 var(--space-xs) 0}.contractor-detail__meta{display:flex;align-items:center;gap:var(--space-sm);flex-wrap:wrap}.contractor-detail__stars{font-size:var(--font-size-sm);color:var(--color-warning);letter-spacing:1px;line-height:1}.contractor-detail__actions{display:flex;gap:var(--space-sm);flex-shrink:0}.contractor-detail__info-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--space-md);margin-bottom:var(--space-xl)}.contractor-detail__field{display:flex;flex-direction:column;gap:var(--space-xs);padding:var(--space-md) 0;border-bottom:1px solid var(--color-border-light)}.contractor-detail__field:last-child{border-bottom:none}.contractor-detail__field-label{font-size:var(--font-size-xs);text-transform:uppercase;letter-spacing:.05em;color:var(--color-text-secondary);font-weight:600}.contractor-detail__field-value{font-size:var(--font-size-base);color:var(--color-text)}.contractor-detail__field-value a{color:var(--color-accent);text-decoration:none;font-weight:500;transition:color var(--transition-fast)}.contractor-detail__field-value a:hover{color:var(--color-accent-hover);text-decoration:underline}.contractor-detail__field-value a:focus-visible{outline:2px solid var(--color-accent);outline-offset:2px;border-radius:2px}.contractor-detail__section-title{font-family:var(--font-display);font-size:var(--font-size-lg);font-weight:400;letter-spacing:-.01em;color:var(--color-text);margin:0 0 var(--space-md) 0}.contractor-detail__notes{margin-bottom:var(--space-xl)}.contractor-detail__notes p{color:var(--color-text-secondary);line-height:1.6;font-size:var(--font-size-base);margin:0}.contractor-detail__improvements{margin-bottom:var(--space-xl)}.contractor-detail__improvement-item{display:flex;justify-content:space-between;align-items:center;gap:var(--space-md);padding:var(--space-md) 0;border-bottom:1px solid var(--color-border-light);transition:background var(--transition-fast)}.contractor-detail__improvement-item:last-child{border-bottom:none}.contractor-detail__improvement-meta{font-size:var(--font-size-sm);color:var(--color-text-secondary);margin-top:2px;text-transform:capitalize}@media(max-width:767px){.contractors-list,.contractor-detail__info-grid{grid-template-columns:1fr}.contractor-detail__header{flex-direction:column;gap:var(--space-md)}.contractor-detail__actions{width:100%;justify-content:flex-end}.contractor-detail__improvement-item{flex-direction:column;align-items:flex-start;gap:var(--space-sm)}}.improvements-page__filters{display:flex;flex-direction:column;gap:var(--space-sm);margin-bottom:var(--space-lg)}.improvements-timeline{display:flex;flex-direction:column;gap:var(--space-xl)}.improvements-timeline__year-label{font-family:var(--font-display);font-size:var(--font-size-lg);font-weight:400;letter-spacing:-.01em;color:var(--color-text);margin-bottom:var(--space-md);padding-left:var(--space-xs)}.improvements-timeline__items{display:flex;flex-direction:column;gap:var(--space-sm)}.improvement-card{display:flex;align-items:center;justify-content:space-between;gap:var(--space-md)}.improvement-card__info{flex:1;min-width:0}.improvement-card__title{font-weight:500;color:var(--color-text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;font-size:var(--font-size-base);line-height:1.4}.improvement-card__meta{display:flex;flex-wrap:wrap;align-items:center;gap:var(--space-xs);font-size:var(--font-size-xs);color:var(--color-text-secondary);margin-top:2px;line-height:1.4}.improvement-card__meta>span:not(:last-child):after{content:"·";margin-left:var(--space-xs);color:var(--color-border)}.improvement-card__category{text-transform:capitalize}.improvement-card__right{display:flex;flex-direction:column;align-items:flex-end;gap:var(--space-xs);flex-shrink:0}.improvement-card__cost{font-weight:600;font-size:var(--font-size-sm);color:var(--color-text)}.improvement-detail{max-width:720px}.improvement-detail__header{display:flex;justify-content:space-between;align-items:flex-start;gap:var(--space-md);margin-bottom:var(--space-lg)}.improvement-detail__title{font-family:var(--font-display);font-size:var(--font-size-xl);font-weight:400;letter-spacing:-.01em;color:var(--color-text);margin:0;line-height:1.25}.improvement-detail__meta{display:flex;align-items:center;gap:var(--space-sm);margin-top:var(--space-sm);flex-wrap:wrap}.improvement-detail__total{display:inline-flex;align-items:center;gap:var(--space-xs);font-weight:600;font-size:var(--font-size-base);color:var(--color-text)}.improvement-detail__actions{display:flex;gap:var(--space-sm);flex-shrink:0}.improvement-detail__info-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:var(--space-md) var(--space-lg);margin-bottom:var(--space-xl)}.improvement-detail__field-label{font-size:var(--font-size-xs);font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--color-text-secondary);margin-bottom:2px}.improvement-detail__field-value{font-size:var(--font-size-base);color:var(--color-text);text-transform:capitalize}.improvement-detail__section{margin-bottom:var(--space-xl)}.improvement-detail__section-title{font-size:var(--font-size-base);font-weight:600;color:var(--color-text);margin:0 0 var(--space-sm)}.improvement-detail__section p{color:var(--color-text-secondary);line-height:1.55;margin:0;white-space:pre-wrap;font-size:var(--font-size-base)}.improvement-detail__locations{display:flex;flex-wrap:wrap;gap:var(--space-sm)}.improvement-detail__location-item{display:inline-flex;align-items:center;gap:var(--space-sm);padding:var(--space-sm) var(--space-md);font-size:var(--font-size-sm);background:var(--color-bg-secondary);border-radius:var(--radius-sm);color:var(--color-text)}.improvement-detail__contractor-card{display:flex;align-items:center;gap:var(--space-md)}.improvement-detail__contractor-trade{font-size:var(--font-size-sm);color:var(--color-text-secondary);text-transform:capitalize}.multi-location-picker{display:flex;flex-direction:column;gap:var(--space-md)}.multi-location-picker__group-label{font-size:var(--font-size-xs);font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--color-text-secondary);margin-bottom:var(--space-xs)}.multi-location-picker__grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:var(--space-xs) var(--space-md)}@media(max-width:767px){.improvement-detail__header{flex-direction:column}.improvement-detail__actions{width:100%;justify-content:flex-end}.improvement-detail__info-grid{grid-template-columns:1fr 1fr}.improvement-card{flex-direction:column;align-items:flex-start;gap:var(--space-sm)}.improvement-card__right{flex-direction:row;align-items:center;gap:var(--space-sm)}}.breakers-page__panel-tabs{display:flex;gap:var(--space-sm);overflow-x:auto;padding-bottom:var(--space-sm);margin-bottom:var(--space-md);-webkit-overflow-scrolling:touch;scrollbar-width:none}.breakers-page__panel-tabs::-webkit-scrollbar{display:none}.breakers-page__panel-tab{display:flex;align-items:center;gap:var(--space-sm);padding:var(--space-sm) var(--space-md);border:1px solid var(--color-border);border-radius:var(--radius-md);background:var(--color-surface);color:var(--color-text-secondary);font-size:var(--font-size-sm);font-weight:500;font-family:inherit;cursor:pointer;white-space:nowrap;transition:all var(--transition-fast);min-height:40px;-webkit-tap-highlight-color:transparent}.breakers-page__panel-tab:hover{border-color:var(--color-text-secondary);color:var(--color-text)}.breakers-page__panel-tab:focus-visible{outline:2px solid var(--color-accent);outline-offset:2px}.breakers-page__panel-tab--active{background:var(--color-accent);color:#fff;border-color:var(--color-accent);box-shadow:0 1px 3px #c0542e33}.breakers-page__panel-tab--active:hover{background:var(--color-accent-hover);border-color:var(--color-accent-hover);color:#fff}.breakers-page__panel-count{font-size:var(--font-size-xs);opacity:.7}.breakers-page__panel-info{display:flex;justify-content:space-between;align-items:center;gap:var(--space-md);margin-bottom:var(--space-md);flex-wrap:wrap}.breakers-page__panel-details{display:flex;gap:var(--space-sm);flex-wrap:wrap;font-size:var(--font-size-sm);color:var(--color-text-secondary)}.breakers-page__panel-details>span:not(:last-child):after{content:" ·";margin-left:var(--space-xs)}.breakers-page__panel-actions{display:flex;gap:var(--space-sm);flex-shrink:0}.breakers-page__highlight{display:flex;align-items:center;gap:var(--space-sm);margin-bottom:var(--space-md);flex-wrap:wrap}.breakers-page__highlight-label{font-size:var(--font-size-sm);color:var(--color-text-secondary);font-weight:500}.breakers-page__highlight-btn{padding:2px var(--space-sm);border:1px solid var(--color-border);border-radius:var(--radius-sm);background:var(--color-surface);color:var(--color-text-secondary);font-size:var(--font-size-xs);font-family:inherit;cursor:pointer;transition:all var(--transition-fast);min-height:28px;-webkit-tap-highlight-color:transparent}.breakers-page__highlight-btn:hover{border-color:var(--color-text-secondary);color:var(--color-text)}.breakers-page__highlight-btn:focus-visible{outline:2px solid var(--color-accent);outline-offset:2px}.breakers-page__highlight-btn--active{background:var(--color-accent);color:#fff;border-color:var(--color-accent)}.breakers-page__highlight-btn--active:hover{background:var(--color-accent-hover);border-color:var(--color-accent-hover);color:#fff}.breaker-grid{display:flex;gap:2px;background:var(--color-bg-secondary);border:2px solid var(--color-border);border-radius:var(--radius-md);padding:var(--space-sm);max-width:600px}.breaker-grid__col{flex:1;display:flex;flex-direction:column;gap:2px}.breaker-grid__divider{width:4px;background:var(--color-text-secondary);border-radius:2px;align-self:stretch;flex-shrink:0}.breaker-slot{display:flex;align-items:center;gap:var(--space-sm);padding:var(--space-sm);background:var(--slot-bg, var(--color-surface));border-radius:var(--radius-sm);cursor:pointer;transition:opacity var(--transition-normal),transform var(--transition-fast);min-height:36px;position:relative;-webkit-tap-highlight-color:transparent}.breaker-slot:hover{transform:scale(1.02);box-shadow:var(--shadow-xs)}.breaker-slot:focus-visible{outline:2px solid var(--color-accent);outline-offset:1px}.breaker-slot--double{min-height:74px}.breaker-slot--tandem{flex-direction:column;align-items:stretch;gap:0;padding:0;min-height:36px}.breaker-slot__tandem-row{display:flex;align-items:center;gap:var(--space-xs);padding:1px var(--space-sm);flex:1;min-height:0;font-size:.6875rem}.breaker-slot__tandem-row .breaker-slot__amp{font-size:.625rem;padding:0 3px}.breaker-slot__tandem-row .breaker-slot__label{font-size:.625rem}.breaker-slot__tandem-divider{height:1px;background:var(--color-border);margin:0 var(--space-xs)}.breaker-slot--spare{opacity:.5}.breaker-slot--dimmed{opacity:.2}.breaker-slot__num{font-size:.6875rem;font-weight:700;color:var(--color-text-secondary);min-width:18px;text-align:center;flex-shrink:0}.breaker-slot__amp{font-size:var(--font-size-xs);font-weight:600;color:var(--color-text);background:#2a20160f;padding:1px 4px;border-radius:3px;white-space:nowrap;flex-shrink:0}.breaker-slot__label{flex:1;font-size:var(--font-size-xs);color:var(--color-text-secondary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.breaker-slot__empty{flex:1;font-size:var(--font-size-xs);color:var(--color-text-secondary);font-style:italic}.breaker-slot__verified{color:var(--color-success);flex-shrink:0;font-size:var(--font-size-xs)}.breaker-sheet{position:fixed;top:0;right:0;bottom:0;left:0;z-index:200;display:flex;align-items:flex-end;justify-content:center}.breaker-sheet__backdrop{position:absolute;top:0;right:0;bottom:0;left:0;background:#2a201666;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.breaker-sheet__content{position:relative;background:var(--color-surface);border-radius:var(--radius-lg) var(--radius-lg) 0 0;padding:var(--space-lg);width:100%;max-width:500px;max-height:80vh;overflow-y:auto;animation:sheetUp var(--transition-normal) ease-out both;box-shadow:var(--shadow-lg);-webkit-overflow-scrolling:touch}@keyframes sheetUp{0%{transform:translateY(100%)}to{transform:translateY(0)}}.breaker-sheet__header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:var(--space-md)}.breaker-sheet__title{font-size:var(--font-size-lg);font-weight:600;color:var(--color-text);margin:0 0 var(--space-xs)}.breaker-sheet__badges{display:flex;gap:var(--space-sm);flex-wrap:wrap}.breaker-sheet__fields{display:flex;flex-direction:column;gap:var(--space-sm);margin-bottom:var(--space-lg)}.breaker-sheet__field{display:flex;justify-content:space-between;gap:var(--space-sm);font-size:var(--font-size-sm);line-height:1.5}.breaker-sheet__field-label{color:var(--color-text-secondary);flex-shrink:0}.breaker-sheet__actions{display:flex;gap:var(--space-sm);padding-bottom:env(safe-area-inset-bottom,0px)}@media(max-width:767px){.breaker-grid{max-width:100%}.breakers-page__panel-info{flex-direction:column;align-items:flex-start;gap:var(--space-sm)}.breakers-page__panel-actions{width:100%;justify-content:flex-end}.breaker-slot__label{max-width:80px}.breaker-sheet__content{max-width:100%;border-radius:var(--radius-lg) var(--radius-lg) 0 0;padding-bottom:calc(var(--space-lg) + env(safe-area-inset-bottom,0px))}}.maintenance-page__tabs{display:flex;gap:var(--space-sm);margin-bottom:var(--space-lg)}.maintenance-page__tab{display:flex;align-items:center;gap:var(--space-sm);padding:var(--space-sm) var(--space-md);border:1px solid var(--color-border);border-radius:var(--radius-md);background:var(--color-bg);color:var(--color-text-secondary);font-size:var(--font-size-sm);font-weight:500;font-family:inherit;cursor:pointer;transition:all var(--transition-fast);min-height:40px}.maintenance-page__tab:hover{border-color:var(--color-text-secondary);color:var(--color-text)}.maintenance-page__tab:focus-visible{outline:2px solid var(--color-accent);outline-offset:2px}.maintenance-page__tab--active{background:var(--color-accent);color:#fff;border-color:var(--color-accent);box-shadow:0 1px 3px #c0542e33}.maintenance-page__tab--active:hover{background:var(--color-accent-hover);border-color:var(--color-accent-hover);color:#fff}.maintenance-task-list{display:flex;flex-direction:column;gap:var(--space-xl)}.maintenance-task-group__header{display:flex;align-items:center;gap:var(--space-sm);margin-bottom:var(--space-sm)}.maintenance-task-group__count{font-size:var(--font-size-xs);color:var(--color-text-secondary)}.maintenance-task-card{display:flex;align-items:center;justify-content:space-between;gap:var(--space-md);padding:var(--space-md);background:var(--color-surface);border:1px solid var(--color-border-light);border-radius:var(--radius-md);margin-bottom:var(--space-sm);transition:all var(--transition-fast);box-shadow:var(--shadow-xs)}.maintenance-task-card:hover{box-shadow:var(--shadow-md);border-color:var(--color-border);transform:translateY(-1px)}.maintenance-task-card__info{flex:1;min-width:0}.maintenance-task-card__name{font-weight:500;color:var(--color-text);font-size:var(--font-size-base);line-height:1.4}.maintenance-task-card__meta{display:flex;flex-wrap:wrap;align-items:center;gap:var(--space-xs);font-size:var(--font-size-xs);color:var(--color-text-secondary);margin-top:var(--space-xs);line-height:1.4}.maintenance-task-card__meta>span:not(:last-child):after{content:"·";margin-left:var(--space-xs);color:var(--color-border)}.maintenance-task-card__actions{display:flex;gap:var(--space-xs);flex-shrink:0}.maintenance-templates{display:flex;flex-direction:column;gap:var(--space-lg)}.maintenance-templates__category-label{font-size:var(--font-size-xs);font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--color-text-secondary);margin-bottom:var(--space-sm)}.maintenance-template-card{display:flex;align-items:center;justify-content:space-between;gap:var(--space-md);padding:var(--space-md);background:var(--color-surface);border:1px solid var(--color-border-light);border-radius:var(--radius-md);margin-bottom:var(--space-sm);transition:all var(--transition-fast);box-shadow:var(--shadow-xs)}.maintenance-template-card:hover{box-shadow:var(--shadow-md);border-color:var(--color-border);transform:translateY(-1px)}.maintenance-template-card__info{flex:1;min-width:0}.maintenance-template-card__name{font-weight:500;color:var(--color-text);font-size:var(--font-size-base);margin-bottom:var(--space-xs)}.maintenance-template-card__meta{display:flex;align-items:center;gap:var(--space-sm);font-size:var(--font-size-sm);color:var(--color-text-secondary)}.maintenance-template-card__desc{font-size:var(--font-size-sm);color:var(--color-text-secondary);margin-top:var(--space-xs);line-height:1.5}.maintenance-templates__empty{text-align:center;padding:var(--space-xl) var(--space-lg);color:var(--color-text-secondary)}.maintenance-templates__empty-icon{opacity:.35;margin-bottom:var(--space-sm);color:var(--color-text-secondary)}.maintenance-templates__empty-hint{font-size:var(--font-size-sm);margin-top:var(--space-xs);color:var(--color-text-secondary);line-height:1.55}@media(max-width:767px){.maintenance-task-card{flex-direction:column;align-items:flex-start}.maintenance-task-card:hover{transform:none}.maintenance-task-card__actions{width:100%;justify-content:flex-end}.maintenance-template-card{flex-direction:column;align-items:flex-start;gap:var(--space-sm)}.maintenance-template-card:hover{transform:none}}.network-page__tabs{display:flex;gap:var(--space-sm);margin-bottom:var(--space-lg);flex-wrap:wrap}.network-page__tab{display:flex;align-items:center;gap:var(--space-sm);padding:var(--space-sm) var(--space-md);border:1px solid var(--color-border);border-radius:var(--radius-md);background:var(--color-surface);color:var(--color-text-secondary);font-size:var(--font-size-sm);font-weight:500;font-family:inherit;cursor:pointer;white-space:nowrap;transition:all var(--transition-fast);min-height:40px;-webkit-tap-highlight-color:transparent}.network-page__tab:hover{border-color:var(--color-text-secondary);color:var(--color-text)}.network-page__tab:focus-visible{outline:2px solid var(--color-accent);outline-offset:2px}.network-page__tab--active{background:var(--color-accent);color:#fff;border-color:var(--color-accent);box-shadow:0 1px 3px #c0542e33}.network-page__tab--active:hover{background:var(--color-accent-hover);border-color:var(--color-accent-hover);color:#fff}.network-table-wrapper{overflow-x:auto;-webkit-overflow-scrolling:touch;border-radius:var(--radius-md);border:1px solid var(--color-border-light);background:var(--color-surface)}.network-table{width:100%;border-collapse:collapse;font-size:var(--font-size-sm)}.network-table th{text-align:left;font-size:var(--font-size-xs);text-transform:uppercase;letter-spacing:.05em;color:var(--color-text-secondary);padding:var(--space-sm) var(--space-md);border-bottom:1px solid var(--color-border);white-space:nowrap;font-weight:600;background:var(--color-bg)}.network-table td{padding:var(--space-sm) var(--space-md);border-bottom:1px solid var(--color-border-light);color:var(--color-text-secondary);vertical-align:middle}.network-table tr:last-child td{border-bottom:none}.network-table__row{cursor:pointer;transition:background var(--transition-fast)}.network-table__row:hover{background:var(--color-accent-subtle)}.network-table__row:focus-visible{outline:2px solid var(--color-accent);outline-offset:-2px}.network-table__name{font-weight:500;color:var(--color-text)}.network-table__type{text-transform:capitalize}.network-table__ip{display:inline-flex;align-items:center;gap:var(--space-xs);cursor:pointer;font-family:var(--font-mono);font-size:var(--font-size-sm);color:var(--color-accent);transition:color var(--transition-fast);text-decoration:none}.network-table__ip:hover{text-decoration:underline;color:var(--color-accent-hover)}.network-table__port-num{font-weight:600;font-family:var(--font-mono);font-size:var(--font-size-sm)}.network-table--compact td{padding:var(--space-xs) var(--space-sm);font-size:var(--font-size-xs)}.network-table--compact th{padding:var(--space-xs) var(--space-sm)}.network-ssid-list{display:flex;flex-direction:column;gap:var(--space-sm)}.network-ssid-card{display:flex;align-items:center;justify-content:space-between;gap:var(--space-md);padding:var(--space-md) var(--space-lg);background:var(--color-surface);border:1px solid var(--color-border-light);border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast);box-shadow:var(--shadow-xs);-webkit-tap-highlight-color:transparent}.network-ssid-card:hover{box-shadow:var(--shadow-md);border-color:var(--color-border);transform:translateY(-1px)}.network-ssid-card:focus-visible{outline:2px solid var(--color-accent);outline-offset:2px}.network-ssid-card__info{display:flex;flex-direction:column;gap:2px;min-width:0}.network-ssid-card__name{font-weight:500;color:var(--color-text);font-size:var(--font-size-base)}.network-ssid-card__meta{display:flex;gap:var(--space-xs);font-size:var(--font-size-sm);color:var(--color-text-secondary);flex-wrap:wrap}.network-ssid-card__meta>span:not(:last-child):after{content:" ·";margin-left:var(--space-xs)}.network-detail{max-width:720px}.network-detail__header{display:flex;justify-content:space-between;align-items:flex-start;gap:var(--space-md);margin-bottom:var(--space-lg)}.network-detail__title{font-family:var(--font-display);font-size:var(--font-size-xl);font-weight:400;letter-spacing:-.01em;color:var(--color-text);margin:0}.network-detail__meta{display:flex;align-items:center;gap:var(--space-sm);margin-top:var(--space-sm);flex-wrap:wrap}.network-detail__ip{display:inline-flex;align-items:center;gap:var(--space-xs);font-family:var(--font-mono);font-size:var(--font-size-sm);color:var(--color-accent);cursor:pointer;transition:color var(--transition-fast);text-decoration:none}.network-detail__ip:hover{text-decoration:underline;color:var(--color-accent-hover)}.network-detail__actions{display:flex;gap:var(--space-sm);flex-shrink:0}.network-detail__info-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:var(--space-md) var(--space-lg);margin-bottom:var(--space-xl)}.network-detail__field-label{font-size:var(--font-size-xs);text-transform:uppercase;letter-spacing:.05em;color:var(--color-text-secondary);margin-bottom:2px;font-weight:600}.network-detail__field-value{font-size:var(--font-size-base);color:var(--color-text);text-transform:capitalize}.network-detail__copyable{display:inline-flex;align-items:center;gap:var(--space-xs);font-family:var(--font-mono);font-size:var(--font-size-sm);cursor:pointer;color:var(--color-accent);transition:color var(--transition-fast);text-decoration:none}.network-detail__copyable:hover{text-decoration:underline;color:var(--color-accent-hover)}.network-detail__section{margin-bottom:var(--space-xl)}.network-detail__section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-sm)}.network-detail__section-title{font-size:var(--font-size-base);font-weight:600;color:var(--color-text);margin:0}.network-detail__section p{color:var(--color-text-secondary);line-height:1.55;margin:0;font-size:var(--font-size-base)}.network-detail__empty-ports{color:var(--color-text-secondary);font-style:italic;font-size:var(--font-size-sm);padding:var(--space-md) 0}@media(max-width:767px){.network-detail__header{flex-direction:column;gap:var(--space-sm)}.network-detail__actions{width:100%;justify-content:flex-end}.network-detail__info-grid{grid-template-columns:1fr 1fr;gap:var(--space-sm) var(--space-md)}.network-table{font-size:var(--font-size-xs)}.network-table th,.network-table td{padding:var(--space-xs) var(--space-sm)}.network-ssid-card{padding:var(--space-sm) var(--space-md)}.network-page__tabs{overflow-x:auto;flex-wrap:nowrap;-webkit-overflow-scrolling:touch;scrollbar-width:none}.network-page__tabs::-webkit-scrollbar{display:none}}
