:root{--color-bg: #F5F1EA;--color-bg-elev: #FBF8F2;--color-surface: #FFFFFF;--color-border: #E5DDCF;--color-border-soft: #EDE6D9;--color-text: #2B2520;--color-text-muted: #6E655B;--color-text-soft: #9A8F81;--color-accent: #8B6F47;--color-accent-hover: #775D39;--color-accent-soft: #EFE5D4;--color-accent-contrast: #FFFFFF;--color-success: #5C7F4F;--color-warn: #C49A3E;--color-danger: #B5523C;--color-info: #4A6C82;--color-prio-muss: #B5523C;--color-prio-soll: #8B6F47;--color-prio-nice: #6E8B7B;--font-serif: "Fraunces", "Georgia", serif;--font-sans: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--shadow-sm: 0 1px 2px rgba(43, 37, 32, .06);--shadow-md: 0 4px 12px rgba(43, 37, 32, .08);--shadow-lg: 0 10px 30px rgba(43, 37, 32, .12);--radius-sm: 6px;--radius-md: 12px;--radius-lg: 18px;--radius-xl: 24px;--space-1: 4px;--space-2: 8px;--space-3: 12px;--space-4: 16px;--space-5: 24px;--space-6: 32px;--space-7: 48px;--space-8: 64px;--nav-h: 64px;--container-max: 1100px;--t-fast: .12s cubic-bezier(.4, 0, .2, 1);--t-med: .22s cubic-bezier(.4, 0, .2, 1)}*,*:before,*:after{box-sizing:border-box}html{-webkit-text-size-adjust:100%}body{margin:0;font-family:var(--font-sans);font-size:15px;line-height:1.5;color:var(--color-text);background:var(--color-bg);-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;min-height:100vh;padding-top:var(--nav-h);padding-bottom:env(safe-area-inset-bottom);overscroll-behavior-y:contain;-webkit-tap-highlight-color:transparent}@media (max-width: 720px){body{padding-bottom:calc(64px + env(safe-area-inset-bottom))}}h1,h2,h3,h4{font-family:var(--font-serif);font-weight:500;letter-spacing:-.01em;color:var(--color-text);margin:0 0 var(--space-3)}h1{font-size:34px;line-height:1.15}h2{font-size:24px;line-height:1.2}h3{font-size:19px;line-height:1.3}h4{font-size:16px;line-height:1.35;font-family:var(--font-sans);font-weight:600}p{margin:0 0 var(--space-3)}a{color:var(--color-accent);text-decoration:none}a:hover{color:var(--color-accent-hover);text-decoration:underline}button{font:inherit;cursor:pointer;border:0;background:none;color:inherit;padding:0}input,textarea,select{font:inherit;color:var(--color-text)}img{max-width:100%;display:block}.container{max-width:var(--container-max);margin:0 auto;padding:var(--space-4) var(--space-4) var(--space-7);width:100%;box-sizing:border-box}@media (min-width: 720px){.container{padding:var(--space-6) var(--space-5) var(--space-8)}}.page-header{display:flex;justify-content:space-between;align-items:flex-end;gap:var(--space-4);margin-bottom:var(--space-5);flex-wrap:wrap}.page-header>div:first-child{min-width:0;flex:1 1 280px}.page-header h1{margin:0;overflow-wrap:break-word;word-break:normal;hyphens:none}.page-header .subtitle{color:var(--color-text-muted);font-size:14px;margin-top:var(--space-1)}@media (max-width: 640px){.page-header{flex-direction:column;align-items:stretch;gap:var(--space-3);margin-bottom:var(--space-4)}.page-header>div:first-child{flex:1 1 auto}.page-header h1{font-size:26px}.page-header .subtitle{font-size:13px}.page-header .row-wrap .btn{flex:1 1 auto}}.stack>*+*{margin-top:var(--space-3)}.stack-lg>*+*{margin-top:var(--space-5)}.row{display:flex;gap:var(--space-3);align-items:center}.row-wrap{display:flex;gap:var(--space-3);flex-wrap:wrap}.grow{flex:1}.muted{color:var(--color-text-muted)}.soft{color:var(--color-text-soft)}.tiny{font-size:12px}.small{font-size:13px}.right{text-align:right}.center{text-align:center}.hidden{display:none!important}.empty-state{text-align:center;color:var(--color-text-soft);padding:var(--space-6) var(--space-4);font-family:var(--font-serif);font-style:italic}.nav{position:fixed;top:0;left:0;right:0;height:calc(var(--nav-h) + env(safe-area-inset-top));background:#fbf8f2d9;-webkit-backdrop-filter:saturate(180%) blur(20px);backdrop-filter:saturate(180%) blur(20px);border-bottom:1px solid var(--color-border-soft);z-index:100;display:flex;align-items:center;padding:env(safe-area-inset-top) var(--space-4) 0;gap:var(--space-5)}.nav-brand{font-family:var(--font-serif);font-weight:500;font-size:20px;letter-spacing:-.01em;color:var(--color-text);display:inline-flex;align-items:center;gap:8px;text-decoration:none}.nav-brand:hover{text-decoration:none;color:var(--color-text)}.nav-mark{width:28px;height:28px;display:inline-block}.nav-links{display:flex;gap:var(--space-1);overflow-x:auto;flex:1;scrollbar-width:none}.nav-links::-webkit-scrollbar{display:none}.nav-link{padding:8px 14px;border-radius:999px;color:var(--color-text-muted);font-size:14px;font-weight:500;white-space:nowrap;transition:color var(--t-fast),background var(--t-fast)}.nav-link:hover{color:var(--color-text);background:var(--color-bg);text-decoration:none}.nav-link.active{background:var(--color-accent);color:var(--color-accent-contrast)}.nav-user{display:flex;gap:var(--space-2);align-items:center;color:var(--color-text-soft);font-size:13px;margin-left:auto}.nav-burger{display:none;width:40px;height:40px;border-radius:var(--radius-md);align-items:center;justify-content:center}@media (max-width: 860px){.nav-links,.nav-burger,.nav-user .nav-link{display:none}}.tabbar{display:none}@media (max-width: 720px){.tabbar{position:fixed;bottom:0;left:0;right:0;z-index:100;display:flex;justify-content:space-around;align-items:stretch;background:#fbf8f2eb;-webkit-backdrop-filter:saturate(180%) blur(20px);backdrop-filter:saturate(180%) blur(20px);border-top:1px solid var(--color-border-soft);padding-bottom:env(safe-area-inset-bottom);height:calc(64px + env(safe-area-inset-bottom));overflow-x:auto;scrollbar-width:none}.tabbar::-webkit-scrollbar{display:none}.tab-link{flex:1 0 auto;min-width:64px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;padding:8px 6px;color:var(--color-text-soft);font-size:10px;text-decoration:none;transition:color var(--t-fast)}.tab-link:hover{text-decoration:none;color:var(--color-text-muted)}.tab-link.active{color:var(--color-accent)}.tab-icon{font-size:22px;line-height:1}.tab-label{white-space:nowrap;font-weight:500}}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-2);padding:10px 18px;min-height:40px;border-radius:var(--radius-md);font-weight:500;font-size:14px;transition:all var(--t-fast);border:1px solid transparent;text-decoration:none;-webkit-tap-highlight-color:transparent}.btn:active{transform:scale(.97)}@media (max-width: 720px){.btn{min-height:44px;padding:12px 18px}.btn-sm{min-height:36px;padding:8px 14px}}.btn-primary{background:var(--color-accent);color:var(--color-accent-contrast)}.btn-primary:hover{background:var(--color-accent-hover);text-decoration:none}.btn-secondary{background:var(--color-surface);color:var(--color-text);border-color:var(--color-border)}.btn-secondary:hover{background:var(--color-bg-elev);text-decoration:none}.btn-ghost{color:var(--color-text-muted)}.btn-ghost:hover{color:var(--color-text);text-decoration:none}.btn-danger{background:var(--color-danger);color:#fff}.btn-danger:hover{background:#933f2e}.btn-sm{padding:6px 12px;font-size:13px}.btn-icon{padding:8px;border-radius:var(--radius-md)}.card{background:var(--color-surface);border:1px solid var(--color-border-soft);border-radius:var(--radius-lg);padding:var(--space-5);box-shadow:var(--shadow-sm);display:flex;flex-direction:column;gap:var(--space-4);overflow:hidden;min-width:0}@media (max-width: 720px){.card{padding:var(--space-4);border-radius:var(--radius-md)}}.card-header{display:flex;justify-content:space-between;align-items:center;gap:var(--space-3);flex-wrap:wrap;margin:0}.card-header h3,.card-header h4{margin:0;line-height:1.3}.card>*{margin:0}.field{display:flex;flex-direction:column;gap:var(--space-2);margin-bottom:var(--space-4)}.field label{font-size:13px;color:var(--color-text-muted);font-weight:500}.field input[type=text],.field input[type=email],.field input[type=number],.field input[type=date],.field input[type=password],.field input[type=url],.field select,.field textarea{padding:10px 12px;border:1px solid var(--color-border);border-radius:var(--radius-md);background:var(--color-surface);font-size:16px;font-family:inherit;transition:border-color var(--t-fast),box-shadow var(--t-fast);width:100%;box-sizing:border-box;-webkit-appearance:none;appearance:none}.field select{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 12 12'%3E%3Cpath fill='%238B6F47' d='M3 4l3 3 3-3z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center;padding-right:32px}.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--color-accent);box-shadow:0 0 0 3px #8b6f4726}.field textarea{resize:vertical;min-height:80px}.field-row{display:flex;gap:var(--space-3);flex-wrap:wrap}.field-row>.field{flex:1;min-width:140px}.badge{display:inline-flex;align-items:center;padding:3px 10px;border-radius:999px;font-size:12px;font-weight:500;background:var(--color-accent-soft);color:var(--color-accent)}.badge-muss{background:#f3dcd5;color:var(--color-prio-muss)}.badge-soll{background:var(--color-accent-soft);color:var(--color-prio-soll)}.badge-nice{background:#dce7e0;color:var(--color-prio-nice)}.badge-offen{background:#eee7d8;color:var(--color-warn)}.badge-erledigt{background:#d9e4d3;color:var(--color-success)}.badge-in_arbeit{background:#d7e3ec;color:var(--color-info)}.modal-backdrop{position:fixed;inset:0;background:#2b252073;backdrop-filter:blur(2px);z-index:1000;display:flex;align-items:center;justify-content:center;padding:var(--space-4);animation:fade-in .15s ease-out}@keyframes fade-in{0%{opacity:0}to{opacity:1}}.modal{background:var(--color-bg-elev);border-radius:var(--radius-xl);max-width:560px;width:100%;max-height:90vh;overflow:auto;padding:var(--space-5);box-shadow:var(--shadow-lg);animation:pop-in .2s cubic-bezier(.34,1.56,.64,1)}@keyframes pop-in{0%{transform:scale(.95);opacity:0}to{transform:scale(1);opacity:1}}.modal h2{margin-top:0}.modal-actions{display:flex;justify-content:flex-end;gap:var(--space-3);margin-top:var(--space-5);flex-wrap:wrap}@media (max-width: 640px){.modal-backdrop{padding:0;align-items:flex-end}.modal{max-width:100%;width:100%;max-height:92vh;border-radius:var(--radius-xl) var(--radius-xl) 0 0;padding:var(--space-5) var(--space-4) calc(var(--space-5) + env(safe-area-inset-bottom));animation:slide-up .28s cubic-bezier(.32,.72,0,1)}@keyframes slide-up{0%{transform:translateY(100%)}to{transform:translateY(0)}}.modal:before{content:"";display:block;width:40px;height:4px;background:var(--color-border);border-radius:2px;margin:-8px auto var(--space-3)}.modal-actions{position:sticky;bottom:0;background:var(--color-bg-elev);margin:var(--space-4) calc(-1 * var(--space-4)) 0;padding:var(--space-3) var(--space-4);border-top:1px solid var(--color-border-soft)}.modal-actions .btn{flex:1;min-width:0}}#toast-root{position:fixed;top:calc(var(--nav-h) + 16px + env(safe-area-inset-top));right:16px;z-index:2000;display:flex;flex-direction:column;gap:var(--space-2);pointer-events:none}.toast{background:var(--color-text);color:var(--color-bg-elev);padding:12px 18px;border-radius:var(--radius-md);box-shadow:var(--shadow-md);font-size:14px;opacity:0;transform:translateY(-8px);transition:opacity var(--t-med),transform var(--t-med);pointer-events:auto}.toast.in{opacity:1;transform:translateY(0)}.toast.success{background:var(--color-success);color:#fff}.toast.error{background:var(--color-danger);color:#fff}.grid{display:grid;gap:var(--space-4)}.grid-2{grid-template-columns:repeat(2,1fr)}.grid-3{grid-template-columns:repeat(3,1fr)}@media (max-width: 720px){.grid-2,.grid-3{grid-template-columns:1fr}}.list-item{display:flex;justify-content:space-between;align-items:center;gap:var(--space-3);padding:var(--space-3) var(--space-4);background:var(--color-surface);border:1px solid var(--color-border-soft);border-radius:var(--radius-md);transition:background var(--t-fast),border-color var(--t-fast),transform var(--t-fast);cursor:pointer;flex-wrap:wrap;min-width:0;-webkit-tap-highlight-color:transparent}.list-item:active{transform:scale(.99)}.list-item .grow{min-width:0;flex:1 1 60%}.list-item .title,.list-item .meta{word-wrap:break-word;overflow-wrap:anywhere}@media (max-width: 720px){.list-item{padding:var(--space-3)}}.list-item:hover{background:var(--color-bg-elev);border-color:var(--color-border)}.list-item .title{font-weight:500}.list-item .meta{color:var(--color-text-soft);font-size:13px}.moodboard-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:var(--space-2)}.mb-img{position:relative;aspect-ratio:1/1;background:var(--color-bg) center / cover no-repeat;border-radius:var(--radius-md);cursor:zoom-in}.mb-img.selected{outline:4px solid var(--color-accent);outline-offset:-4px}.mb-img .mb-chk{position:absolute;top:6px;left:6px;width:26px;height:26px;border-radius:50%;background:#ffffffe6;color:transparent;border:2px solid rgba(43,37,32,.3);font-size:16px;font-weight:700;line-height:1;display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity var(--t-fast),background var(--t-fast),color var(--t-fast),border-color var(--t-fast)}.mb-img:hover .mb-chk,.mb-img.selected .mb-chk{opacity:1}.mb-img.selected .mb-chk{background:var(--color-accent);color:#fff;border-color:var(--color-accent)}@media (hover: none){.mb-img .mb-chk{opacity:1}}.bulk-bar{position:sticky;top:0;z-index:5;background:var(--color-bg-elev);padding:var(--space-3);border-radius:var(--radius-md);border:1px solid var(--color-border);display:flex;justify-content:space-between;align-items:center;gap:var(--space-3);flex-wrap:wrap}.bulk-count{font-weight:500;color:var(--color-accent)}.bulk-actions{display:flex;gap:var(--space-2);flex-wrap:wrap}@media (max-width: 480px){.bulk-bar{flex-direction:column;align-items:stretch}.bulk-actions{justify-content:center}.bulk-actions .btn{flex:1}}.mb-img .mb-menu{position:absolute;top:6px;right:6px;width:32px;height:32px;border-radius:50%;background:#2b2520cc;color:#fff;font-size:22px;font-weight:600;line-height:1;display:flex;align-items:center;justify-content:center;opacity:.6;transition:opacity var(--t-fast),background var(--t-fast)}.mb-img:hover .mb-menu{opacity:1}.mb-img .mb-menu:hover{background:var(--color-accent)}@media (hover: none){.mb-img .mb-menu{opacity:1}}.mb-menu-popover{position:absolute;width:220px;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);box-shadow:var(--shadow-lg);padding:var(--space-2);z-index:2200;display:flex;flex-direction:column;gap:2px}.mb-menu-popover button{text-align:left;padding:10px 12px;border-radius:var(--radius-sm);font-size:14px;cursor:pointer;background:none;color:var(--color-text);transition:background var(--t-fast)}.mb-menu-popover button:hover{background:var(--color-bg-elev)}.mb-menu-popover button.danger{color:var(--color-danger)}.mb-menu-popover button.danger:hover{background:#f8e0da}.mb-menu-popover b{font-weight:600;color:var(--color-accent)}.mb-thumb{width:56px;height:56px;flex-shrink:0;border-radius:var(--radius-sm);overflow:hidden;background:var(--color-bg) center / cover no-repeat;display:grid;gap:1px;align-items:stretch}.mb-thumb>span{background:var(--color-bg) center / cover no-repeat;display:block}.mb-thumb.mb-thumb-collage-2{grid-template-columns:1fr 1fr}.mb-thumb.mb-thumb-collage-3{grid-template-columns:2fr 1fr;grid-template-rows:1fr 1fr}.mb-thumb.mb-thumb-collage-3>span:first-child{grid-row:1 / 3}.mb-thumb.mb-thumb-collage-4{grid-template-columns:1fr 1fr;grid-template-rows:1fr 1fr}.mb-thumb.mb-thumb-empty{display:flex;align-items:center;justify-content:center;color:var(--color-text-soft);font-size:22px;font-family:var(--font-serif)}.moodboard-cover{position:relative;display:grid;aspect-ratio:4/3;gap:2px;background:var(--color-bg);overflow:hidden}.moodboard-cover>span{background:var(--color-bg) center / cover no-repeat;display:block}.moodboard-cover.collage-2{grid-template-columns:1fr 1fr}.moodboard-cover.collage-3{grid-template-columns:2fr 1fr;grid-template-rows:1fr 1fr}.moodboard-cover.collage-3>span:first-child{grid-row:1 / 3}.moodboard-cover.collage-4{grid-template-columns:1fr 1fr;grid-template-rows:1fr 1fr}.moodboard-cover.empty{display:flex;align-items:center;justify-content:center;color:var(--color-text-soft);font-size:48px;font-family:var(--font-serif)}.technik-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--space-4);align-items:start}@media (max-width: 860px){.technik-grid{grid-template-columns:1fr}}details.acc{margin-top:var(--space-4)}details.acc:first-child{margin-top:0}details.acc>summary{list-style:none;cursor:pointer;display:flex;align-items:center;gap:var(--space-3);padding:var(--space-2) 0;user-select:none}details.acc>summary::-webkit-details-marker{display:none}.acc-chev{display:inline-flex;align-items:center;justify-content:center;width:28px;height:28px;font-size:22px;color:var(--color-accent);background:var(--color-accent-soft);border-radius:50%;line-height:1;transition:transform var(--t-fast);flex-shrink:0}details.acc>summary:hover .acc-chev{background:var(--color-accent);color:#fff}details[open].acc>summary .acc-chev{transform:rotate(90deg)}.acc-title{font-family:var(--font-serif);font-weight:500;font-size:22px;color:var(--color-text);line-height:1.25}.acc-count{font-family:var(--font-sans);font-size:13px;color:var(--color-text-soft);font-weight:400}.acc-content{padding-top:var(--space-3)}.floor-section{margin-top:var(--space-5)}.floor-section:first-child{margin-top:0}.floor-title{font-family:var(--font-serif);font-weight:500;font-size:20px;margin:0 0 var(--space-3);color:var(--color-text);display:flex;align-items:baseline;gap:var(--space-3)}.floor-title .count{font-family:var(--font-sans);font-size:13px;color:var(--color-text-soft);font-weight:400}.tile-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:var(--space-3)}@media (max-width: 480px){.tile-grid{grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:var(--space-2)}}.tile{background:var(--color-surface);border:1px solid var(--color-border-soft);border-radius:var(--radius-lg);overflow:hidden;cursor:pointer;transition:transform var(--t-fast),box-shadow var(--t-fast)}.tile:hover{transform:translateY(-2px);box-shadow:var(--shadow-md)}.tile .tile-img{aspect-ratio:4 / 3;background:var(--color-bg) center / cover no-repeat}.tile .tile-body{padding:var(--space-3)}.tile .tile-title{font-weight:500;margin:0;font-size:14px}.tile .tile-meta{color:var(--color-text-soft);font-size:12px;margin-top:2px}.upload-zone{display:block;width:100%;border:2px dashed var(--color-border);border-radius:var(--radius-lg);padding:var(--space-5);text-align:center;color:var(--color-text-muted);cursor:pointer;transition:border-color var(--t-fast),background var(--t-fast);background:var(--color-bg-elev);box-sizing:border-box}.upload-zone:hover{border-color:var(--color-accent);background:var(--color-accent-soft);color:var(--color-accent)}.upload-zone.dragging{border-color:var(--color-accent);background:var(--color-accent-soft)}.auth-screen{min-height:calc(100vh - var(--nav-h));display:flex;align-items:center;justify-content:center;padding:var(--space-5)}.auth-card{background:var(--color-surface);border-radius:var(--radius-xl);padding:var(--space-6);max-width:400px;width:100%;box-shadow:var(--shadow-md);text-align:center;box-sizing:border-box}@media (max-width: 480px){.auth-card{padding:var(--space-5) var(--space-4)}}.auth-card h1{font-family:var(--font-serif);font-size:28px;margin-bottom:var(--space-2)}.auth-card .subtitle{color:var(--color-text-muted);margin-bottom:var(--space-5);font-size:14px}.map{width:100%;height:360px;border-radius:var(--radius-lg);overflow:hidden;border:1px solid var(--color-border-soft)}@media (max-width: 720px){.map{height:240px}}.card{overflow-x:hidden}.budget-table-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch;margin:0 calc(-1 * var(--space-5));padding:0 var(--space-5)}@media (max-width: 720px){.budget-table-wrap{margin:0 calc(-1 * var(--space-4));padding:0 var(--space-4)}}.budget-table{width:100%;min-width:480px;border-collapse:collapse;font-size:14px}.budget-table th,.budget-table td{text-align:left;padding:10px 12px;border-bottom:1px solid var(--color-border-soft)}.budget-table th{font-weight:500;color:var(--color-text-muted);font-size:12px;text-transform:uppercase;letter-spacing:.03em}.budget-table td.num{text-align:right;font-variant-numeric:tabular-nums}.budget-table tfoot td{font-weight:600}.budget-table td.num-edit{position:relative;transition:background var(--t-fast)}.budget-table td.num-edit:hover{background:var(--color-accent-soft)}.budget-table input.inline-num,.budget-table input.inline-text{width:100%;border:1px solid var(--color-accent);border-radius:var(--radius-sm);padding:4px 8px;font:inherit;font-variant-numeric:tabular-nums;text-align:right;background:var(--color-surface);outline:none;box-shadow:0 0 0 3px #8b6f4726}.budget-table input.inline-text{text-align:left}.budget-table .b-label{border-radius:var(--radius-sm);padding:2px 4px;margin:-2px -4px}.budget-table .b-label:hover{background:var(--color-accent-soft)}.page-header code{font-family:SF Mono,Menlo,monospace;font-size:12px;background:var(--color-accent-soft);color:var(--color-accent);padding:1px 6px;border-radius:4px}.comments-section{margin-top:var(--space-5);padding-top:var(--space-4);border-top:1px solid var(--color-border-soft)}.comment{padding:var(--space-3) 0;border-bottom:1px solid var(--color-border-soft)}.comment:last-child{border-bottom:0}.comment .c-meta{font-size:12px;color:var(--color-text-soft);margin-bottom:4px}.comment .c-text{white-space:pre-wrap}.comment-badge{display:inline-flex;align-items:center;gap:4px;padding:2px 8px;border-radius:999px;background:var(--color-accent-soft);color:var(--color-accent);font-size:12px;font-weight:500;position:relative}.comment-badge.unread{background:var(--color-danger);color:#fff;animation:pulse 2s infinite}.comment-badge .cb-icon{font-size:11px}.comment-badge .cb-dot{width:6px;height:6px;background:#fff;border-radius:50%}@keyframes pulse{0%,to{opacity:1}50%{opacity:.7}}.notif-panel{background:var(--color-surface);border:1px solid var(--color-border-soft);border-left:3px solid var(--color-danger);border-radius:var(--radius-lg);padding:var(--space-4)}.notif-panel.empty{border-left-color:var(--color-success);opacity:.85}.notif-head{display:flex;align-items:center;gap:var(--space-3);margin-bottom:var(--space-3)}.notif-head h3{margin:0}.notif-head .notif-count{background:var(--color-danger);color:#fff;padding:2px 10px;border-radius:999px;font-size:12px;font-weight:600}.notif-list{display:flex;flex-direction:column;gap:var(--space-2)}.notif-item{display:flex;gap:var(--space-3);padding:var(--space-2) var(--space-3);border-radius:var(--radius-md);cursor:pointer;transition:background var(--t-fast);align-items:flex-start}.notif-item:hover{background:var(--color-bg-elev)}.notif-item.unread{background:#fbece8}.notif-item.unread:hover{background:#f7e1dc}.notif-item .ni-type{flex-shrink:0;font-size:11px;text-transform:uppercase;letter-spacing:.03em;color:var(--color-text-soft);padding:2px 8px;border-radius:4px;background:var(--color-bg);min-width:90px;text-align:center}@media (max-width: 480px){.notif-item .ni-type{min-width:70px;font-size:10px}.notif-item{flex-direction:column;gap:var(--space-1)}.notif-item .ni-type{align-self:flex-start}.notif-item .ni-preview{white-space:normal}}.notif-item.unread .ni-type{color:var(--color-danger);font-weight:600}.notif-item .ni-body{flex:1;min-width:0}.notif-item .ni-entity{font-weight:500;font-size:14px}.notif-item .ni-preview{color:var(--color-text-muted);font-size:13px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.notif-item .ni-meta{font-size:12px;color:var(--color-text-soft);margin-top:2px}.dash-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--space-4)}@media (max-width: 720px){.dash-grid{grid-template-columns:repeat(2,1fr)}}.dash-tile{background:var(--color-surface);border-radius:var(--radius-lg);padding:var(--space-4);border:1px solid var(--color-border-soft)}.dash-tile .label{color:var(--color-text-muted);font-size:12px;text-transform:uppercase;letter-spacing:.04em}.dash-tile .value{font-family:var(--font-serif);font-size:32px;font-weight:500;margin-top:4px;color:var(--color-text)}.lightbox-backdrop{position:fixed;inset:0;background:#14100ceb;backdrop-filter:blur(8px);z-index:2000;display:flex;align-items:center;justify-content:center;padding:env(safe-area-inset-top) env(safe-area-inset-right) env(safe-area-inset-bottom) env(safe-area-inset-left)}body.lb-open{overflow:hidden}.lb-stage{max-width:min(95vw,1600px);max-height:88vh;display:flex;align-items:center;justify-content:center}.lb-img{max-width:100%;max-height:88vh;object-fit:contain;border-radius:var(--radius-md);box-shadow:0 16px 60px #0009;background:#111}.lb-close,.lb-nav{position:absolute;color:#fff;background:#ffffff1a;border-radius:50%;width:48px;height:48px;display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:32px;line-height:1;transition:background var(--t-fast)}.lb-close{top:max(16px,env(safe-area-inset-top));right:max(16px,env(safe-area-inset-right));font-size:28px}.lb-prev{left:max(16px,env(safe-area-inset-left))}.lb-next{right:max(16px,env(safe-area-inset-right))}.lb-prev,.lb-next{top:50%;transform:translateY(-50%)}.lb-close:hover,.lb-nav:hover{background:#fff3}.lb-caption{position:absolute;bottom:max(16px,env(safe-area-inset-bottom));left:0;right:0;text-align:center;color:#ffffffd9;font-size:13px;text-shadow:0 1px 4px rgba(0,0,0,.8);padding:0 80px;pointer-events:none}@media (max-width: 640px){.lb-close,.lb-nav{width:40px;height:40px;font-size:24px}.lb-caption{padding:0 56px}}.doc-overlay{position:fixed;inset:0;background:#14100cf5;z-index:2000;display:flex;flex-direction:column;padding:max(16px,env(safe-area-inset-top)) max(16px,env(safe-area-inset-right)) max(16px,env(safe-area-inset-bottom)) max(16px,env(safe-area-inset-left))}.doc-topbar{display:flex;align-items:center;justify-content:space-between;gap:var(--space-3);padding-bottom:var(--space-3);color:#fff}.doc-title{font-family:var(--font-serif);font-size:16px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;flex:1}.doc-actions{display:flex;gap:var(--space-2)}.doc-actions .btn{color:#fff}.doc-actions .btn-secondary{background:#ffffff26;border-color:transparent}.doc-actions .btn-secondary:hover{background:#ffffff40}.doc-actions .btn-ghost:hover{background:#ffffff26}.doc-frame{flex:1 1 auto;min-height:0;width:100%;height:100%;border:0;border-radius:var(--radius-md);background:#fff;box-shadow:0 16px 60px #0009}.doc-fallback{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--space-4);height:100%;padding:var(--space-5);color:var(--color-text);font-family:var(--font-sans)}.offline-banner{position:fixed;top:var(--nav-h);left:0;right:0;background:var(--color-warn);color:#fff;text-align:center;padding:6px;font-size:13px;z-index:99}
