@import"https://fonts.googleapis.com/css2?family=Caveat:wght@400;500;600;700&family=Schibsted+Grotesk:wght@400;500;600;700;800&family=JetBrains+Mono:wght@400;500;600&display=swap";:root{--ink-900: #14110F;--ink-700: #3A3631;--ink-500: #6E665C;--ink-300: #B6AFA4;--ink-100: #E6E0D6;--paper-50: #FFFDF8;--paper-100: #FAF6EC;--paper-200: #F2EDDF;--paper-300: #E8E1D0;--pastel-rose: #F4C9C9;--pastel-butter: #F4E3A8;--pastel-mint: #C7E2C6;--pastel-sky: #BCD4E6;--pastel-lilac: #D9C9E8;--pastel-peach: #F5D2B5;--rose-ink: #8C3F3F;--butter-ink: #A08319;--mint-ink: #355E3B;--sky-ink: #345A78;--lilac-ink: #4E3A6E;--peach-ink: #8A4A20;--bg: var(--paper-100);--bg-sunken: var(--paper-200);--bg-raised: var(--paper-50);--fg: var(--ink-900);--fg-muted: var(--ink-500);--fg-subtle: var(--ink-300);--line: var(--ink-100);--line-strong:var(--ink-300);--accent: var(--pastel-rose);--accent-ink: var(--rose-ink);--success: var(--pastel-mint);--success-ink:var(--mint-ink);--warning: var(--pastel-butter);--warning-ink:var(--butter-ink);--danger: var(--pastel-rose);--danger-ink: var(--rose-ink);--info: var(--pastel-sky);--info-ink: var(--sky-ink);--font-sans: "Schibsted Grotesk", system-ui, -apple-system, "Segoe UI", sans-serif;--font-serif: var(--font-sans);--font-hand: "Caveat", "Brush Script MT", cursive;--font-mono: "JetBrains Mono", ui-monospace, "SF Mono", Consolas, monospace;--fs-xs: 12px;--fs-sm: 14px;--fs-base: 16px;--fs-md: 18px;--fs-lg: 21px;--fs-xl: 26px;--fs-2xl: 34px;--fs-3xl: 46px;--fs-4xl: 62px;--fs-5xl: 82px;--lh-tight: 1.05;--lh-snug: 1.2;--lh-base: 1.5;--lh-loose: 1.7;--tr-tight: -.02em;--tr-snug: -.01em;--tr-base: 0;--tr-wide: .04em;--tr-eyebrow: .16em;--fw-regular: 400;--fw-medium: 500;--fw-semibold:600;--fw-bold: 700;--space-0: 0;--space-1: 4px;--space-2: 8px;--space-3: 12px;--space-4: 16px;--space-5: 20px;--space-6: 24px;--space-8: 32px;--space-10: 40px;--space-12: 48px;--space-16: 64px;--space-20: 80px;--space-24: 96px;--r-none: 0;--r-sm: 4px;--r-md: 8px;--r-lg: 14px;--r-xl: 20px;--r-2xl: 28px;--r-pill: 999px;--shadow-1: 0 1px 0 rgba(20,17,15,.04), 0 1px 2px rgba(20,17,15,.06);--shadow-2: 0 2px 1px rgba(20,17,15,.03), 0 4px 12px rgba(20,17,15,.06);--shadow-3: 0 6px 24px rgba(20,17,15,.08), 0 2px 4px rgba(20,17,15,.04);--shadow-stamp: 3px 3px 0 var(--ink-900);--ease-out: cubic-bezier(.22, 1, .36, 1);--ease-in: cubic-bezier(.55, 0, 1, .45);--ease-springy: cubic-bezier(.34, 1.56, .64, 1);--dur-fast: .12s;--dur-base: .2s;--dur-slow: .32s}.h-display{font-family:var(--font-sans);font-size:var(--fs-5xl);line-height:var(--lh-tight);letter-spacing:var(--tr-tight);font-weight:700;color:var(--fg)}.h-display em,.h-display .hand{font-family:var(--font-hand);font-style:normal;font-weight:600;font-size:1.3em;line-height:.8;display:inline-block}.h1{font-family:var(--font-sans);font-size:var(--fs-4xl);line-height:var(--lh-tight);letter-spacing:var(--tr-tight);font-weight:700;color:var(--fg)}.h2{font-family:var(--font-sans);font-size:var(--fs-3xl);line-height:var(--lh-snug);letter-spacing:var(--tr-snug);font-weight:600;color:var(--fg)}.h3{font-family:var(--font-sans);font-size:var(--fs-2xl);line-height:var(--lh-snug);letter-spacing:var(--tr-snug);font-weight:600;color:var(--fg)}.h4{font-family:var(--font-sans);font-size:var(--fs-xl);line-height:var(--lh-snug);font-weight:600;color:var(--fg)}.h5{font-family:var(--font-sans);font-size:var(--fs-lg);line-height:var(--lh-snug);font-weight:600;color:var(--fg)}.eyebrow{font-family:var(--font-sans);font-size:var(--fs-xs);letter-spacing:var(--tr-eyebrow);text-transform:uppercase;font-weight:600;color:var(--fg-muted)}.hand{font-family:var(--font-hand);font-weight:600;color:var(--fg);line-height:1}.body{font-family:var(--font-sans);font-size:var(--fs-base);line-height:var(--lh-base);font-weight:400;color:var(--fg)}.body-lg{font-family:var(--font-sans);font-size:var(--fs-md);line-height:var(--lh-base);font-weight:400;color:var(--fg)}.body-sm{font-family:var(--font-sans);font-size:var(--fs-sm);line-height:var(--lh-base);color:var(--fg)}.caption{font-family:var(--font-sans);font-size:var(--fs-xs);line-height:var(--lh-base);color:var(--fg-muted)}.mono{font-family:var(--font-mono);font-size:var(--fs-sm);color:var(--fg)}.quote{font-family:var(--font-sans);font-style:normal;font-weight:500;font-size:var(--fs-2xl);line-height:var(--lh-snug);color:var(--fg)}.surface-product{font-family:var(--font-sans);font-feature-settings:"ss01","cv11"}.surface-product :where(h1,h2,h3,h4,h5,h6),.surface-product :where(.h1,.h2,.h3,.h4,.h5,.h-display){font-family:var(--font-sans);letter-spacing:-.02em;font-weight:600;color:var(--fg)}.surface-product :where(h1,.h1){font-size:var(--fs-3xl);line-height:var(--lh-snug)}.surface-product :where(h2,.h2){font-size:var(--fs-2xl);line-height:var(--lh-snug)}.surface-product :where(h3,.h3){font-size:var(--fs-xl);line-height:var(--lh-snug)}.surface-product :where(h4,.h4){font-size:var(--fs-lg);line-height:var(--lh-snug)}.surface-product :where(h5,.h5){font-size:var(--fs-md);line-height:var(--lh-snug)}.surface-product :where(.num,.stat-val,.tabular,td,.money,time,.timestamp){font-variant-numeric:tabular-nums;font-feature-settings:"tnum" 1,"lnum" 1}.surface-product .editorial-moment{font-family:var(--font-sans);font-style:italic;font-weight:400;color:var(--ink-500);letter-spacing:-.005em}.surface-editorial{font-family:var(--font-sans)}.surface-editorial :where(h1,h2){font-family:var(--font-sans);font-weight:700;letter-spacing:var(--tr-tight)}.surface-editorial :where(h1){font-size:var(--fs-4xl);line-height:var(--lh-tight)}.surface-editorial :where(h2){font-size:var(--fs-3xl);line-height:var(--lh-snug)}.surface-editorial .hand,.surface-editorial em.hand{font-family:var(--font-hand);font-style:normal;font-weight:600}.tabular-nums{font-variant-numeric:tabular-nums;font-feature-settings:"tnum" 1,"lnum" 1}.proportional-nums{font-variant-numeric:proportional-nums;font-feature-settings:"pnum" 1}.num-display{font-family:var(--font-sans);font-weight:600;letter-spacing:-.025em;font-variant-numeric:tabular-nums}*{box-sizing:border-box}html,body{margin:0;background:var(--bg);color:var(--fg);font-family:var(--font-sans);font-size:var(--fs-base);line-height:var(--lh-base);-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}::selection{background:var(--pastel-butter);color:var(--ink-900)}#root{height:100dvh;display:flex}.app-shell{display:flex;width:100%;height:100%;background:var(--bg);overflow:hidden}.sidebar{width:220px;flex-shrink:0;background:var(--paper-50);border-right:1px solid var(--line);display:flex;flex-direction:column;height:100%;overflow-y:auto}.sidebar-brand{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-6) var(--space-4) var(--space-4);border-bottom:1px solid var(--line)}.sidebar-brand img{width:32px;height:32px;object-fit:contain}.sidebar-brand-text{font-size:var(--fs-sm);font-weight:var(--fw-semibold);color:var(--ink-700);line-height:1.2}.sidebar-brand-sub{font-size:var(--fs-xs);color:var(--ink-500);letter-spacing:var(--tr-eyebrow);text-transform:uppercase}.sidebar-nav{flex:1;padding:var(--space-4) var(--space-3);display:flex;flex-direction:column;gap:var(--space-1)}.nav-link{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-2) var(--space-3);border-radius:var(--r-md);font-size:var(--fs-sm);font-weight:var(--fw-medium);color:var(--ink-700);text-decoration:none;transition:background var(--dur-fast) var(--ease-out),color var(--dur-fast) var(--ease-out);cursor:pointer;border:none;background:none;width:100%;text-align:left}.nav-link:hover{background:var(--paper-200);color:var(--ink-900)}.nav-link.active{background:var(--pastel-sky);color:var(--sky-ink);font-weight:var(--fw-semibold)}.nav-section-label{font-size:var(--fs-xs);letter-spacing:var(--tr-eyebrow);text-transform:uppercase;color:var(--ink-300);padding:var(--space-4) var(--space-3) var(--space-1)}.sidebar-footer{padding:var(--space-4);border-top:1px solid var(--line);display:flex;flex-direction:column;gap:var(--space-2)}.sidebar-user{font-size:var(--fs-xs);color:var(--ink-500);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.main-content{flex:1;overflow-y:auto;display:flex;flex-direction:column}.page{flex:1;padding:var(--space-8) var(--space-10);max-width:960px}.page-header{margin-bottom:var(--space-8)}.page-title{font-size:var(--fs-2xl);font-weight:var(--fw-semibold);color:var(--fg);letter-spacing:-.02em;margin:0 0 var(--space-1)}.page-subtitle{font-size:var(--fs-sm);color:var(--fg-muted);margin:0}.save-indicator{position:fixed;top:var(--space-4);right:var(--space-4);background:var(--pastel-sky);color:var(--sky-ink);font-size:var(--fs-xs);font-weight:var(--fw-semibold);padding:var(--space-2) var(--space-4);border-radius:var(--r-pill);border:1px solid var(--line);z-index:100;box-shadow:var(--shadow-stamp)}.card{background:var(--paper-50);border:1px solid var(--line);border-radius:var(--r-lg);box-shadow:var(--shadow-1);transition:box-shadow var(--dur-base) var(--ease-out)}.card:hover{box-shadow:var(--shadow-2)}.card-body{padding:var(--space-6)}.member-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:var(--space-4)}.member-card{background:var(--paper-50);border:1px solid var(--line);border-radius:var(--r-lg);box-shadow:var(--shadow-1);padding:var(--space-6);cursor:pointer;transition:box-shadow var(--dur-base) var(--ease-out),transform var(--dur-base) var(--ease-out);display:flex;flex-direction:column;align-items:center;gap:var(--space-3);text-decoration:none;color:inherit}.member-card:hover{box-shadow:var(--shadow-2);transform:translateY(-1px)}.member-avatar{width:48px;height:48px;border-radius:var(--r-pill);display:flex;align-items:center;justify-content:center;font-weight:var(--fw-bold);font-size:var(--fs-lg)}.member-name{font-size:var(--fs-sm);font-weight:var(--fw-semibold);color:var(--fg)}.member-count{font-size:var(--fs-xs);color:var(--fg-muted);font-variant-numeric:tabular-nums}.room-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:var(--space-3)}.room-card{background:var(--paper-50);border:1px solid var(--line);border-radius:var(--r-lg);box-shadow:var(--shadow-1);padding:var(--space-4);cursor:pointer;transition:box-shadow var(--dur-base) var(--ease-out),background var(--dur-fast) var(--ease-out);text-align:center;text-decoration:none;color:inherit;display:flex;flex-direction:column;align-items:center;gap:var(--space-2)}.room-card:hover{background:var(--paper-200);box-shadow:var(--shadow-2)}.room-card.has-tasks{border-color:var(--pastel-sky)}.room-name{font-size:var(--fs-xs);font-weight:var(--fw-semibold);color:var(--fg);line-height:1.3}.room-count{font-size:var(--fs-xs);color:var(--fg-muted);font-variant-numeric:tabular-nums}.floor-plan-wrap{background:var(--paper-50);border:1px solid var(--line);border-radius:var(--r-lg);box-shadow:var(--shadow-1);padding:var(--space-6);margin-bottom:var(--space-8)}.floor-plan-title{font-size:var(--fs-sm);font-weight:var(--fw-semibold);color:var(--fg-muted);letter-spacing:var(--tr-eyebrow);text-transform:uppercase;margin-bottom:var(--space-4)}.floor-plan-canvas{position:relative;background:var(--paper-200);border-radius:var(--r-md);border:1px solid var(--line);width:700px;height:580px;margin:0 auto;overflow:hidden}.fp-room{position:absolute;background:var(--paper-50);border:1.5px solid var(--ink-300);border-radius:var(--r-sm);cursor:pointer;transition:background var(--dur-fast) var(--ease-out),border-color var(--dur-fast) var(--ease-out),box-shadow var(--dur-fast) var(--ease-out);display:flex;align-items:center;justify-content:center}.fp-room:hover{background:var(--pastel-sky);border-color:var(--sky-ink);box-shadow:var(--shadow-stamp)}.fp-room.has-tasks{border-color:var(--sky-ink);background:color-mix(in srgb,var(--pastel-sky) 30%,var(--paper-50))}.fp-room-label{font-size:10px;font-weight:var(--fw-semibold);color:var(--ink-700);text-align:center;line-height:1.2;padding:2px;pointer-events:none}.fp-room:hover .fp-room-label{color:var(--sky-ink)}.fp-room-count{position:absolute;top:3px;right:4px;font-size:9px;font-weight:var(--fw-bold);color:var(--sky-ink);font-variant-numeric:tabular-nums}.progress-bar{height:4px;background:var(--paper-300);border-radius:var(--r-pill);overflow:hidden;margin-top:var(--space-2)}.progress-fill{height:100%;border-radius:var(--r-pill);background:var(--pastel-sky);border:1px solid var(--sky-ink);transition:width var(--dur-slow) var(--ease-out)}.progress-fill.complete{background:var(--pastel-mint);border-color:var(--mint-ink)}.task-section-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-4);padding-bottom:var(--space-3);border-bottom:1px solid var(--line)}.task-section-title{font-size:var(--fs-lg);font-weight:var(--fw-semibold);color:var(--fg);display:flex;align-items:center;gap:var(--space-3)}.task-count-badge{font-size:var(--fs-xs);font-weight:var(--fw-semibold);color:var(--fg-muted);font-variant-numeric:tabular-nums;background:var(--paper-200);border:1px solid var(--line);border-radius:var(--r-pill);padding:2px var(--space-2)}.task-list{display:flex;flex-direction:column;gap:2px}.task-item{display:flex;align-items:flex-start;gap:var(--space-3);padding:var(--space-2) var(--space-3);border-radius:var(--r-md);cursor:pointer;transition:background var(--dur-fast) var(--ease-out);group:task-item}.task-item:hover{background:var(--paper-200)}.task-item.done{opacity:.55}.task-check{flex-shrink:0;margin-top:2px;color:var(--ink-300);transition:color var(--dur-fast)}.task-item.done .task-check{color:var(--mint-ink)}.task-item:hover .task-check{color:var(--sky-ink)}.task-text{flex:1;font-size:var(--fs-sm);color:var(--fg);line-height:var(--lh-base)}.task-item.done .task-text{text-decoration:line-through;color:var(--fg-muted)}.task-delete{flex-shrink:0;opacity:0;background:none;border:none;cursor:pointer;color:var(--danger-ink);padding:2px;border-radius:var(--r-sm);transition:opacity var(--dur-fast);display:flex;align-items:center}.task-item:hover .task-delete{opacity:1}.task-delete:hover{background:var(--pastel-rose)}.add-task-form{display:flex;gap:var(--space-2);margin-top:var(--space-4);padding-top:var(--space-4);border-top:1px solid var(--line)}.add-task-input{flex:1;padding:var(--space-2) var(--space-3);border:1px solid var(--line);border-radius:var(--r-md);background:var(--paper-50);font-family:var(--font-sans);font-size:var(--fs-sm);color:var(--fg);outline:none;transition:border-color var(--dur-fast)}.add-task-input:focus{border-color:var(--sky-ink)}.add-task-input::placeholder{color:var(--fg-subtle)}.btn{display:inline-flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-4);border-radius:var(--r-md);font-family:var(--font-sans);font-size:var(--fs-sm);font-weight:var(--fw-medium);cursor:pointer;transition:background var(--dur-fast) var(--ease-out),color var(--dur-fast);border:1px solid transparent;text-decoration:none}.btn-primary{background:var(--pastel-sky);color:var(--sky-ink);border-color:var(--sky-ink)}.btn-primary:hover{background:var(--sky-ink);color:var(--paper-50)}.btn-ghost{background:transparent;color:var(--fg-muted);border-color:var(--line)}.btn-ghost:hover{background:var(--paper-200);color:var(--fg)}.btn-danger{background:var(--pastel-rose);color:var(--rose-ink);border-color:var(--rose-ink)}.btn-danger:hover{background:var(--rose-ink);color:var(--paper-50)}.empty-state{padding:var(--space-12) var(--space-6);text-align:center;color:var(--fg-muted)}.empty-state p{margin:0;font-size:var(--fs-sm);font-style:italic}.overview-grid{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-4);margin-bottom:var(--space-8)}.overview-card{background:var(--paper-50);border:1px solid var(--line);border-radius:var(--r-lg);box-shadow:var(--shadow-1);padding:var(--space-6);cursor:pointer;transition:box-shadow var(--dur-base) var(--ease-out);text-decoration:none;color:inherit;display:flex;align-items:center;gap:var(--space-4)}.overview-card:hover{box-shadow:var(--shadow-2)}.overview-card-icon{width:48px;height:48px;border-radius:var(--r-lg);display:flex;align-items:center;justify-content:center;flex-shrink:0}.overview-card-text h3{margin:0 0 var(--space-1);font-size:var(--fs-md);font-weight:var(--fw-semibold);color:var(--fg)}.overview-card-text p{margin:0;font-size:var(--fs-xs);color:var(--fg-muted)}.stat-row{display:flex;gap:var(--space-4);margin-bottom:var(--space-8)}.stat-card{background:var(--paper-50);border:1px solid var(--line);border-radius:var(--r-lg);box-shadow:var(--shadow-1);padding:var(--space-4) var(--space-5);flex:1}.stat-label{font-size:var(--fs-xs);letter-spacing:var(--tr-eyebrow);text-transform:uppercase;color:var(--fg-muted);margin-bottom:var(--space-1)}.stat-value{font-size:var(--fs-2xl);font-weight:var(--fw-bold);color:var(--fg);font-variant-numeric:tabular-nums;letter-spacing:-.02em}.back-link{display:inline-flex;align-items:center;gap:var(--space-2);font-size:var(--fs-sm);color:var(--fg-muted);text-decoration:none;margin-bottom:var(--space-6);cursor:pointer;background:none;border:none;padding:0;transition:color var(--dur-fast)}.back-link:hover{color:var(--fg)}.color-dot{width:10px;height:10px;border-radius:var(--r-pill);border:1px solid rgba(0,0,0,.1);flex-shrink:0}.auth-screen{min-height:100dvh;display:flex;align-items:center;justify-content:center;background:var(--bg)}.auth-card{background:var(--paper-50);border:1px solid var(--line);border-radius:var(--r-xl);box-shadow:var(--shadow-3);padding:var(--space-12) var(--space-10);text-align:center;max-width:380px;width:100%}.auth-mark{width:56px;height:56px;object-fit:contain;margin-bottom:var(--space-4)}.auth-title{font-size:var(--fs-xl);font-weight:var(--fw-semibold);color:var(--fg);margin:0 0 var(--space-2)}.auth-subtitle{font-size:var(--fs-sm);color:var(--fg-muted);margin:0 0 var(--space-8)}.auth-denied{background:var(--pastel-rose);border:1px solid var(--rose-ink);border-radius:var(--r-md);padding:var(--space-3) var(--space-4);color:var(--rose-ink);font-size:var(--fs-sm);margin-bottom:var(--space-4)}
