@font-face{font-family:Geist;src:url(/fonts/Geist-Variable.woff2)format("woff2");font-weight:100 900;font-style:normal;font-display:swap}@font-face{font-family:Geist Mono;src:url(/fonts/GeistMono-Variable.woff2)format("woff2");font-weight:100 900;font-style:normal;font-display:swap}*{box-sizing:border-box}html,body{height:100%;margin:0;padding:0}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-family:Geist,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif}code,pre,.mono{font-family:Geist Mono,monospace}
:root{--background:#000;--foreground:#fff;--accents-1:#111;--accents-2:#333;--accents-3:#444;--accents-4:#666;--accents-5:#888;--accents-6:#999;--accents-7:#eaeaea;--accents-8:#fafafa;--geist-success:#0070f3;--geist-error:#e00;--geist-warning:#f5a623;--success:#22c55e;--error:#ef4444;--border-radius:8px;--font-sans:-apple-system,BlinkMacSystemFont,"Segoe UI","Roboto","Oxygen","Ubuntu","Cantarell","Fira Sans","Droid Sans","Helvetica Neue",sans-serif}[data-theme=light]{--background:#fff;--foreground:#000;--accents-1:#fafafa;--accents-2:#eaeaea;--accents-3:#d4d4d4;--accents-4:#999;--accents-5:#666;--accents-6:#444;--accents-7:#333;--accents-8:#111}
*{box-sizing:border-box}::selection{background-color:#007aff4d!important}::selection{background-color:#007aff4d!important}html{background:var(--background);height:100%}body,#root{max-width:100vw;height:100%;margin:0;padding:0;overflow-x:hidden}body{font-family:var(--font-sans);background:var(--background);color:var(--foreground)}.app{flex-direction:column;max-width:100vw;height:100dvh;display:flex;overflow:hidden}.calculator-layout-content .app{max-width:100%;height:100%}@media (max-width:1199px){.app{overflow-y:auto}}.loading{justify-content:center;align-items:center;min-height:100dvh;display:flex}.loading-spinner{color:var(--accents-5);font-size:1rem}.scenario-loading{flex:1;justify-content:center;align-items:center;height:100%;display:flex}
.app-main{z-index:1;flex:1;min-height:0;position:relative}.horizontal-scroll{flex-direction:column;height:100%;display:flex}@media (max-width:1199px){.horizontal-scroll{padding-bottom:env(safe-area-inset-bottom)}}@media (min-width:1200px){.app-main{overflow:hidden}.horizontal-scroll{-webkit-overflow-scrolling:touch;flex-direction:row;height:100%;overflow:auto hidden}.horizontal-scroll::-webkit-scrollbar{height:8px}.horizontal-scroll::-webkit-scrollbar-track{background:var(--accents-1)}.horizontal-scroll::-webkit-scrollbar-thumb{background:var(--accents-3);border-radius:4px}.horizontal-scroll::-webkit-scrollbar-thumb:hover{background:var(--accents-4)}}.panel{flex-direction:column;flex-shrink:0;width:100%;display:flex}@media (min-width:1200px){.panel{border-right:1px solid var(--accents-2);height:100%;overflow:hidden}.panel:last-child{border-right:none}.panel-inputs,.panel-financing{width:480px}.panel-metrics{width:720px}.panel-charts{width:700px}.panel-tilgungsplan{width:500px}}.panel-title{text-transform:uppercase;letter-spacing:.05em;color:var(--accents-6);background:var(--background);border-bottom:1px solid var(--accents-2);flex-shrink:0;margin:0;padding:16px 24px;font-family:Geist Mono,monospace;font-size:.875rem;font-weight:600}.panel-content{flex-direction:column;flex:1;gap:24px;min-height:0;padding:24px;display:flex;overflow:hidden auto}@media (min-width:1200px){.panel-content::-webkit-scrollbar{width:6px}.panel-content::-webkit-scrollbar-track{background:0 0}.panel-content::-webkit-scrollbar-thumb{background:var(--accents-3);border-radius:3px}.panel-content::-webkit-scrollbar-thumb:hover{background:var(--accents-4)}}
.app-header{background:var(--background);border-bottom:1px solid var(--accents-2);z-index:200;flex-direction:column;flex-shrink:0;display:flex;position:sticky;top:0}.header-top{box-sizing:border-box;flex-wrap:nowrap;align-items:center;gap:0;width:100%;max-width:100%;min-height:64px;padding:12px 24px;display:flex;overflow:hidden}.header-metrics-inline{flex:1;justify-content:flex-end;display:flex}.header-metrics-bar{background:var(--background);border-bottom:1px solid var(--accents-2);box-sizing:border-box;width:100%;max-width:100%;padding:12px 24px;display:none}.header-actions{flex:1;align-items:center;gap:0;display:flex}.header-actions .landing-avatar-btn{line-height:0}.header-actions .landing-avatar{width:32px;height:32px}.header-button{border:1px solid var(--accents-3);color:var(--accents-5);cursor:pointer;background:0 0;border-radius:9999px;align-items:center;gap:8px;padding:8px 16px;font-size:.875rem;font-weight:500;transition:all .2s ease-out;display:flex}.header-button:hover{color:var(--foreground);border-color:var(--accents-4)}.icon-wrapper{display:inline-flex;position:relative}.status-badge{border:2px solid var(--background);border-radius:50%;width:8px;height:8px;position:absolute;top:-4px;right:-4px}.status-badge--saved{background:var(--success)}.status-badge--unsaved{background:var(--geist-warning)}.status-badge--not-saved{background:var(--error)}.header-button.save-button{justify-content:center;min-width:150px}.header-button.copied{color:var(--success);border-color:var(--success);animation:.3s ease-out copiedPulse}.header-button.copied svg{animation:.4s ease-out copiedCheck}.header-button.copied .button-text{animation:.3s ease-out copiedText}@keyframes copiedPulse{0%{transform:scale(1)}50%{transform:scale(1.05)}to{transform:scale(1)}}@keyframes copiedCheck{0%{opacity:0;transform:scale(0)rotate(-45deg)}50%{opacity:1;transform:scale(1.2)rotate(0)}to{opacity:1;transform:scale(1)rotate(0)}}@keyframes copiedText{0%{opacity:0;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}@keyframes cloudSaving{0%,to{opacity:1}50%{opacity:.4}}.saving-animation{animation:1s ease-in-out infinite cloudSaving}.header-button.share-button{justify-content:center;min-width:120px;margin-left:0;transition:all .2s ease-out}@media (max-width:900px){.header-button.share-button{min-width:auto}}.logo{align-items:center;gap:12px;display:flex}.logo h1{margin:0;font-size:1.25rem;font-weight:600}.header-metric{flex-direction:column;align-items:flex-start;display:flex}.header-buttons{flex:1;align-items:center;gap:0;display:flex}.header-metrics{flex-wrap:nowrap;flex:1;align-items:center;gap:16px;display:flex}.header-icon-group{flex-shrink:0;align-items:center;gap:4px;display:flex}.sync-indicator{width:32px;height:32px;color:var(--accents-4);justify-content:center;align-items:center;display:flex}.sync-indicator-success{color:var(--success)}.sync-indicator-error{color:var(--error)}.header-buttons-mobile{display:none}@media (max-width:1023px){.header-buttons-desktop{display:none}.header-buttons-mobile{justify-content:flex-end;gap:4px;display:flex}.header-cloud-toggle{display:none}.header-top{justify-content:space-between;min-height:48px;position:relative}.header-left{gap:8px}.header-title{pointer-events:none;max-width:50%;font-size:1rem;font-weight:600;position:absolute;left:50%;transform:translate(-50%)}.header-title-editable{pointer-events:auto}.header-actions{flex:none}}.header-metric .label{color:var(--accents-5);text-transform:uppercase;letter-spacing:.05em;white-space:nowrap;text-overflow:ellipsis;font-size:.75rem;overflow:hidden}.header-metric .value{font-variant-numeric:tabular-nums;white-space:nowrap;font-family:Geist Mono,monospace;font-size:1.125rem;font-weight:600}.header-metric.positive .value{color:var(--success)}.header-metric.negative .value{color:var(--error)}.header-left{align-items:center;gap:12px;min-width:0;height:100%;display:flex;overflow:hidden}.back-button{width:32px;height:32px;color:var(--accents-5);cursor:pointer;background:0 0;border:none;border-radius:8px;justify-content:center;align-items:center;padding:0;transition:all .15s;display:flex}.back-button:hover{color:var(--foreground);background:var(--accents-2)}.header-title{color:var(--foreground);white-space:nowrap;text-overflow:ellipsis;min-width:0;margin:0;font-size:1.75rem;font-weight:600;overflow:hidden}.header-title-editable{cursor:pointer;border-radius:6px;align-items:center;gap:8px;min-width:0;margin:-4px -8px;padding:4px 8px;transition:background .15s;display:flex;overflow:hidden}.header-title-editable:hover{background:var(--accents-2)}.header-title-editable .edit-icon{opacity:0;color:var(--accents-5);transition:opacity .15s}.header-title-editable:hover .edit-icon{opacity:1}.header-name-input{background:var(--accents-2);border:1px solid var(--accents-4);color:var(--foreground);border-radius:6px;outline:none;width:100%;min-width:0;padding:4px 12px;font-size:1.75rem;font-weight:600}.header-name-input:focus{border-color:var(--geist-success)}.theme-toggle{width:32px;height:32px;color:var(--accents-5);cursor:pointer;background:0 0;border:none;border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;padding:0;transition:all .15s;display:flex}.theme-toggle:hover{color:var(--foreground);background:var(--accents-2)}
.card{background:var(--background);border:1px solid var(--accents-2);border-radius:var(--border-radius);flex-shrink:0;position:relative;overflow:visible}.card:has(.info-tooltip-wrapper:hover){z-index:10}.card-header{border-bottom:1px solid var(--accents-2);justify-content:space-between;align-items:center;padding:16px 20px;display:flex}.card-header.collapsible{cursor:pointer}.card-header.collapsible:hover{background:var(--accents-2)}.card-header h3{text-transform:uppercase;letter-spacing:.05em;color:var(--accents-6);margin:0;font-family:Geist Mono,monospace;font-size:.875rem;font-weight:600}.card-header-content{align-items:center;gap:8px;margin-left:auto;display:flex}.collapse-icon{color:var(--accents-5);font-size:1.25rem}.card-content{padding:20px;overflow:visible}.card-content h4{text-transform:uppercase;letter-spacing:.05em;color:var(--accents-5);margin:24px 0 12px;font-size:.75rem;font-weight:600}.card-content h4:first-child{margin-top:0}.metric-card{background:var(--background);border:1px solid var(--accents-3);border-radius:6px;align-items:center;gap:16px;padding:16px;display:flex}.metric-card.positive{border-color:var(--success);background:#22c55e1a}.metric-card.negative{border-color:var(--error);background:#ef44441a}.metric-icon{color:var(--accents-5)}.metric-card.positive .metric-icon{color:var(--success)}.metric-card.negative .metric-icon{color:var(--error)}.metric-content{flex-direction:column;gap:4px;display:flex}.metric-label{color:var(--accents-5);text-transform:uppercase;letter-spacing:.05em;font-size:.75rem}.metric-value{font-variant-numeric:tabular-nums;font-family:Geist Mono,monospace;font-size:1.125rem;font-weight:600}.metric-detail{color:var(--accents-5);margin-top:4px;font-size:.75rem;line-height:1.4}
.form-grid{grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:16px;display:grid}.input-field{flex-direction:column;gap:6px;display:flex}.input-field label{color:var(--accents-5);align-items:center;gap:4px;font-size:.75rem;display:flex}.info-tooltip-wrapper{cursor:help;align-items:center;display:inline-flex;position:relative}.info-tooltip-wrapper .info-icon{color:var(--accents-4);transition:color .15s}.info-tooltip-wrapper:hover .info-icon{color:var(--foreground)}.info-tooltip{background:var(--foreground);color:var(--background);white-space:pre-line;opacity:0;visibility:hidden;z-index:1000;pointer-events:none;border-radius:6px;min-width:200px;max-width:280px;padding:8px 12px;font-size:.7rem;line-height:1.4;transition:opacity .15s,visibility .15s;position:absolute;bottom:calc(100% + 8px);left:50%;transform:translate(-50%);box-shadow:0 4px 12px #00000026}.info-tooltip:after{content:"";border:6px solid #0000;border-top-color:var(--foreground);position:absolute;top:100%;left:50%;transform:translate(-50%)}.info-tooltip-wrapper:hover .info-tooltip{opacity:1;visibility:visible}.info-tooltip-wrapper:hover{z-index:1000}.input-wrapper{background:var(--background);border:1px solid var(--accents-3);border-radius:6px;align-items:center;transition:border-color .15s;display:flex;overflow:hidden}.input-wrapper:focus-within{border-color:var(--foreground)}.input-wrapper input{color:var(--foreground);font-variant-numeric:tabular-nums;background:0 0;border:none;outline:none;flex:1;min-width:0;padding:10px 12px;font-size:.875rem}.input-wrapper input::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}.input-wrapper input::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}.input-wrapper input[type=number]{-moz-appearance:textfield}.input-wrapper .suffix{background:var(--accents-2);color:var(--accents-5);border-left:1px solid var(--accents-3);padding:10px 12px;font-size:.875rem}.input-wrapper.has-error,.input-wrapper.has-error:focus-within{border-color:var(--error)}.input-wrapper.has-warning,.input-wrapper.has-warning:focus-within{border-color:var(--geist-warning)}.input-error{color:var(--error);margin-top:4px;font-size:.75rem;display:block}.input-warning{color:var(--geist-warning);margin-top:4px;font-size:.75rem;display:block}.field-error label{color:var(--error)}.field-warning label{color:var(--geist-warning)}.display-field{flex-direction:column;gap:6px;display:flex}.display-field label{color:var(--accents-5);font-size:.75rem}.display-field .value{background:var(--accents-2);font-variant-numeric:tabular-nums;color:var(--accents-7);border-radius:6px;padding:10px 12px;font-size:.875rem}.display-field.positive .value{color:var(--success)}.display-field.negative .value{color:var(--error)}.summary-row{border-top:1px solid var(--accents-2);flex-wrap:wrap;gap:16px;margin-top:16px;padding-top:16px;display:flex}.summary-row:first-child{border-top:none;margin-top:0;padding-top:0}.summary-row>*{flex:140px;min-width:140px}.summary-row.highlight{background:var(--background);border-radius:0 0 var(--border-radius)var(--border-radius);border-top:none;margin:16px -20px -20px;padding:16px 20px}.icon-button{width:32px;height:32px;color:var(--accents-5);cursor:pointer;background:0 0;border:none;border-radius:6px;justify-content:center;align-items:center;transition:all .15s;display:flex}.icon-button:hover{background:var(--accents-2);color:var(--foreground)}.icon-button.danger{color:var(--accents-5)}.icon-button.danger:hover{background:var(--geist-error);color:var(--background)}.notes-field{grid-column:1/-1}.notes-textarea{background:var(--background);border:1px solid var(--accents-3);width:100%;color:var(--foreground);resize:vertical;box-sizing:border-box;border-radius:6px;outline:none;padding:10px 12px;font-family:inherit;font-size:.875rem;transition:border-color .15s}.notes-textarea:focus{border-color:var(--foreground)}.notes-textarea::placeholder{color:var(--accents-4)}
.loan-card{background:var(--background);border:1px solid var(--accents-3);border-radius:6px;margin-top:16px;padding:16px}.loan-card:first-of-type{margin-top:0}.loan-card.loan-disabled{opacity:.5;border-style:dashed}.loan-card.loan-disabled .form-grid{pointer-events:none}.loan-header{justify-content:space-between;align-items:center;margin-bottom:16px;display:flex}.loan-name-input{min-width:0;color:var(--foreground);background:0 0;border:none;outline:none;flex:1;padding:4px 0;font-size:.875rem;font-weight:600}.loan-name-input:focus{border-bottom:1px solid var(--accents-3)}.loan-toggle{cursor:pointer;flex-shrink:0;width:36px;height:20px;display:inline-block;position:relative}.loan-toggle input{opacity:0;width:0;height:0}.loan-toggle-slider{background-color:var(--accents-3);border-radius:20px;transition:background-color .2s;position:absolute;inset:0}.loan-toggle-slider:before{content:"";background-color:var(--foreground);border-radius:50%;width:14px;height:14px;transition:transform .2s;position:absolute;bottom:3px;left:3px}.loan-toggle input:checked+.loan-toggle-slider{background-color:var(--success)}.loan-toggle input:checked+.loan-toggle-slider:before{transform:translate(16px)}.loan-toggle:hover .loan-toggle-slider{background-color:var(--accents-4)}.loan-toggle input:checked:hover+.loan-toggle-slider{background-color:#1ea54c}.loan-header-actions{flex-shrink:0;align-items:center;gap:8px;display:flex}.pill-toggle{cursor:pointer;border:1px solid var(--accents-3);background:var(--accents-1);color:var(--accents-5);-webkit-user-select:none;user-select:none;border-radius:20px;align-items:center;gap:6px;padding:6px 12px;font-size:.75rem;font-weight:500;transition:all .2s;display:inline-flex}.pill-toggle:hover{border-color:var(--accents-4);background:var(--accents-2)}.pill-toggle.active{color:var(--success);background:#22c55e26;border-color:#22c55e4d}.pill-toggle.active:hover{background:#22c55e33;border-color:#22c55e66}.pill-toggle input{display:none}.pill-toggle.disabled{cursor:default;opacity:.6}.pill-toggle-icon{justify-content:center;align-items:center;width:14px;height:14px;display:flex}.pill-toggle-group{border:1px solid var(--accents-3);background:0 0;border-radius:20px;gap:0;padding:3px;display:inline-flex;position:relative}.pill-toggle-group .pill-indicator{background:var(--foreground);z-index:0;border-radius:16px;height:calc(100% - 6px);transition:left .25s cubic-bezier(.4,0,.2,1),width .25s cubic-bezier(.4,0,.2,1);position:absolute;top:3px}.pill-toggle-group .pill-toggle{z-index:1;color:var(--accents-5);background:0 0;border:none;border-radius:16px;padding:4px 12px;font-size:.7rem;transition:color .2s;position:relative}.pill-toggle-group .pill-toggle:hover{background:0 0}.pill-toggle-group .pill-toggle.active{color:var(--background);background:0 0}.pill-toggle-group .pill-toggle.active:hover{background:0 0}.pill-toggle.details-toggle{color:var(--accents-5);background:0 0;border:none;align-items:center;gap:4px;padding:6px 14px;transition:all .2s;display:flex}.pill-toggle.details-toggle:hover{background:var(--foreground);border-color:var(--foreground);color:var(--background)}.pill-toggle.details-toggle .chevron{justify-content:center;align-items:center;margin-left:4px;font-size:1.25rem;line-height:1;display:inline-flex;transform:rotate(90deg)}.pill-toggle.details-toggle .chevron.expanded{transform:rotate(-90deg)}.add-loan-button{border:1px dashed var(--accents-3);width:100%;color:var(--accents-5);cursor:pointer;box-sizing:border-box;background:0 0;border-radius:6px;justify-content:center;align-items:center;gap:8px;margin-top:16px;padding:12px;font-size:.875rem;transition:all .15s;display:flex}.add-loan-button:hover{background:var(--accents-2);border-color:var(--accents-4);color:var(--foreground)}.financing-options{margin-top:16px}
.metrics-section{flex-direction:column;gap:24px;display:flex}.metrics-row{grid-template-columns:minmax(320px,1fr) minmax(320px,1fr);gap:24px;display:grid}@media (max-width:720px){.metrics-row{grid-template-columns:1fr}}.metrics-grid{grid-template-columns:1fr;gap:16px;display:grid}.cashflow-table{flex-direction:column;display:flex}.cashflow-row{border-bottom:1px solid var(--accents-2);justify-content:space-between;padding:10px 0;font-size:.875rem;display:flex}.cashflow-row:last-child{border-bottom:none}.cashflow-row .value{font-variant-numeric:tabular-nums;font-weight:500}.cashflow-row .value.positive{color:var(--success)}.cashflow-row .value.negative{color:var(--error)}.cashflow-row.subtotal{border-top:1px solid var(--accents-3);margin-top:4px;padding-top:14px;font-weight:500}.cashflow-row.total{background:var(--background);margin:8px -20px -20px;padding:14px 20px;font-weight:600}
.charts-section,.tilgungsplan-section{flex-direction:column;gap:24px;display:flex}.chart-container{width:calc(100% + 26px);height:300px;margin-left:-26px}.chart-expandable{grid-template-rows:0fr;transition:grid-template-rows .3s ease-out;display:grid}.chart-expandable>.chart-expandable-inner{min-height:0;overflow:hidden}.chart-expandable.expanded{grid-template-rows:1fr}.chart-toggle-container{justify-content:flex-start;margin-bottom:12px;display:flex}.chart-actions{justify-content:flex-end;align-items:center;gap:12px;margin-top:12px;display:flex}.chart-info{color:var(--accents-5);margin-right:auto;font-family:Geist Mono,monospace;font-size:.75rem}.chart-info-icon{color:var(--accents-4);cursor:help;align-items:center;display:flex;position:relative}.chart-tooltip{background:var(--foreground);width:280px;color:var(--background);z-index:10;border-radius:6px;padding:8px 12px;font-family:Geist,sans-serif;font-size:.75rem;line-height:1.4;display:none;position:absolute;bottom:calc(100% + 8px);right:0}.chart-info-icon:hover .chart-tooltip{display:block}.chart-loading{height:200px;color:var(--accents-5);justify-content:center;align-items:center;font-size:.875rem;display:flex}
.table-container{overflow-x:auto}.data-table{border-collapse:collapse;width:100%;font-size:.75rem}.data-table th,.data-table td{text-align:right;white-space:nowrap;padding:8px 12px}.data-table th{background:var(--background);color:var(--accents-6);text-transform:uppercase;letter-spacing:.03em;font-family:Geist Mono,monospace;font-weight:600;position:sticky;top:0}.data-table th:first-child,.data-table td:first-child{text-align:left;background:var(--background);position:sticky;left:0}.data-table th:first-child{background:var(--background)}.data-table td.positive{color:var(--success)}.data-table td.negative{color:var(--error)}.data-table tr.loan-continuation td,.data-table tr.year-start td{padding-top:2px;padding-bottom:2px}.data-table td.loan-name{color:var(--accents-5);font-size:.7rem}.data-table td.year-cell{font-family:Geist Mono,monospace}.data-table tr.loan-odd td,.data-table tr.row-odd td{background:var(--accents-1)}[data-theme=light] .data-table tr.loan-odd td,[data-theme=light] .data-table tr.row-odd td{background:var(--accents-2)}
.home-screen{padding:24px 32px;padding-bottom:calc(24px + env(safe-area-inset-bottom));height:100%;position:relative;overflow-y:auto}.drop-overlay{z-index:1000;pointer-events:none;background:#000000b3;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.drop-overlay-content{background:var(--accents-1);border:2px dashed var(--accents-5);color:var(--foreground);border-radius:16px;flex-direction:column;align-items:center;gap:16px;padding:48px 64px;font-size:1.25rem;font-weight:500;display:flex}.scenarios-grid{grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:12px;display:grid}.add-scenario-card{border:2px dashed var(--accents-3);border-radius:var(--border-radius);min-height:120px;color:var(--accents-5);cursor:pointer;background:0 0;justify-content:center;align-items:center;transition:all .2s;display:flex}.add-scenario-card:hover{border-color:var(--geist-success);color:var(--geist-success)}.add-scenario-card:hover .add-icon{background:var(--geist-success);color:#fff}.add-scenario-card .add-icon{background:var(--accents-2);border-radius:50%;justify-content:center;align-items:center;width:48px;height:48px;transition:all .2s;display:flex}.scenario-card{background:var(--background);border:1px solid var(--accents-2);border-radius:var(--border-radius);cursor:pointer;text-align:left;flex-direction:column;width:100%;padding:0;transition:border-color .2s;display:flex;overflow:hidden}.scenario-card:hover{border-color:var(--accents-4)}.scenario-card-header{justify-content:space-between;align-items:flex-start;padding:12px 14px 0;display:flex}.scenario-card-name{color:var(--foreground);text-overflow:ellipsis;white-space:nowrap;flex:1;min-width:0;font-size:.875rem;font-weight:600;overflow:hidden}.scenario-card-actions{flex-shrink:0;margin-left:8px}.scenario-card-rename-input{background:var(--accents-2);border:1px solid var(--accents-4);width:100%;color:var(--foreground);border-radius:4px;outline:none;padding:2px 6px;font-size:.875rem;font-weight:600}.scenario-card-rename-input:focus{border-color:var(--geist-success)}.scenario-card-address{color:var(--accents-5);text-overflow:ellipsis;white-space:nowrap;padding:0 14px 8px;font-size:.6875rem;display:block;overflow:hidden}.scenario-card-metrics{border-top:1px solid var(--accents-2);gap:0;margin:auto 14px 0;padding:8px 0 0;display:flex}.scenario-card-metric{flex-direction:column;flex:1;gap:2px;padding:6px 0 12px;display:flex}.scenario-card-metric .label{color:var(--accents-5);text-transform:uppercase;letter-spacing:.05em;font-family:Geist Mono,monospace;font-size:.625rem;font-weight:500}.scenario-card-metric .value{font-variant-numeric:tabular-nums;color:var(--foreground);font-family:Geist Mono,monospace;font-size:.8125rem;font-weight:600}.scenario-card-metric .value.positive{color:var(--success)}.scenario-card-metric .value.negative{color:var(--error)}.home-section-divider{margin-top:24px;margin-bottom:12px}.card-menu{background:var(--background);border:1px solid var(--accents-2);z-index:10;transform-origin:100% 0;border-radius:8px;min-width:140px;margin-top:4px;padding:4px;animation:.15s ease-out dropdownFadeIn;position:absolute;top:100%;right:0;overflow:hidden;box-shadow:0 4px 16px #0000001f}.card-menu-item{width:100%;color:var(--accents-5);cursor:pointer;text-align:left;background:0 0;border:none;border-radius:6px;align-items:center;gap:8px;padding:8px 12px;font-size:.8125rem;transition:all .15s;display:flex}.card-menu-item:hover{background:var(--accents-2);color:var(--foreground)}.card-menu-item.danger{color:var(--error)}.card-menu-item.danger:hover{background:#ef44441a}.empty-state{text-align:center;color:var(--accents-5);flex-direction:column;justify-content:center;align-items:center;padding:64px 24px;display:flex}.empty-state h2{color:var(--accents-6);margin:24px 0 12px;font-size:1.25rem;font-weight:600}.empty-state p{max-width:400px;margin:0}.sort-select{border:1px solid var(--accents-3);color:var(--foreground);cursor:pointer;white-space:nowrap;background:0 0;border-radius:6px;align-items:center;gap:6px;padding:6px 10px;font-size:.8125rem;font-weight:500;transition:all .15s;display:flex}.sort-select:hover{border-color:var(--accents-4)}.sort-select svg{color:var(--accents-5);flex-shrink:0}@media (max-width:768px){.home-screen{padding:20px 16px}.sort-select span{display:none}.scenarios-grid{grid-template-columns:1fr}}
@keyframes dropdownFadeIn{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.dropdown{position:relative}.dropdown-trigger{cursor:pointer}.dropdown-menu{background:var(--background);border:1px solid var(--accents-2);z-index:9999;border-radius:8px;width:fit-content;padding:4px;animation:.15s ease-out dropdownFadeIn;box-shadow:0 4px 16px #0000001f}.dropdown-align-left{transform-origin:0 0}.dropdown-align-right{transform-origin:100% 0}.dropdown-item{width:100%;color:var(--accents-5);cursor:pointer;text-align:left;white-space:nowrap;box-sizing:border-box;background:0 0;border:none;border-radius:6px;align-items:center;gap:8px;padding:8px 12px;font-size:.8125rem;transition:all .15s;display:flex}.dropdown-item:hover{background:var(--accents-2);color:var(--foreground)}.dropdown-item.danger{color:var(--error)}.dropdown-item.danger:hover{background:#ef444414}.dropdown-item.active{color:var(--foreground)}.dropdown-item-icon{flex-shrink:0;align-items:center;display:flex}.error-boundary{background:var(--accents-1);border:1px solid var(--accents-2);border-radius:var(--border-radius);justify-content:center;align-items:center;min-height:200px;padding:24px;display:flex}.error-boundary-content{text-align:center;flex-direction:column;align-items:center;gap:12px;max-width:300px;display:flex}.error-boundary-icon{color:var(--geist-warning)}.error-boundary-title{color:var(--foreground);margin:0;font-size:1rem;font-weight:600}.error-boundary-message{color:var(--accents-5);margin:0;font-size:.875rem;line-height:1.4}.error-boundary-button{background:var(--accents-2);border:1px solid var(--accents-3);color:var(--foreground);cursor:pointer;border-radius:6px;align-items:center;gap:6px;margin-top:8px;padding:8px 16px;font-size:.875rem;transition:background .15s,border-color .15s;display:flex}.error-boundary-button:hover{background:var(--accents-3);border-color:var(--accents-4)}@keyframes backdropFadeIn{0%{opacity:0}to{opacity:1}}@keyframes dialogSlideIn{0%{opacity:0;transform:scale(.95)translateY(-10px)}to{opacity:1;transform:scale(1)translateY(0)}}.share-dialog-backdrop{z-index:10000;background:#0009;justify-content:center;align-items:center;padding:16px;animation:.15s ease-out backdropFadeIn;display:flex;position:fixed;inset:0}.share-dialog{background:var(--background);border:1px solid var(--accents-3);border-radius:12px;width:100%;max-width:480px;animation:.2s ease-out dialogSlideIn;overflow:hidden;box-shadow:0 8px 32px #0006}.share-dialog-header{border-bottom:1px solid var(--accents-2);justify-content:space-between;align-items:center;padding:16px 20px;display:flex}.share-dialog-header h3{color:var(--foreground);margin:0;font-size:1rem;font-weight:600}.share-dialog-close{width:32px;height:32px;color:var(--accents-5);cursor:pointer;background:0 0;border:none;border-radius:6px;justify-content:center;align-items:center;transition:all .15s;display:flex}.share-dialog-close:hover{background:var(--accents-2);color:var(--foreground)}.share-dialog-content{padding:20px}.share-dialog-input-wrapper{gap:8px;display:flex}.share-dialog-input{background:var(--accents-1);border:1px solid var(--accents-3);color:var(--foreground);border-radius:6px;outline:none;flex:1;min-width:0;padding:10px 12px;font-family:Geist Mono,monospace;font-size:.875rem}.share-dialog-input:focus{border-color:var(--geist-success)}.share-dialog-copy{background:var(--foreground);color:var(--background);cursor:pointer;white-space:nowrap;border:none;border-radius:6px;align-items:center;gap:6px;padding:10px 16px;font-size:.875rem;font-weight:500;transition:all .15s;display:flex}.share-dialog-copy:hover{opacity:.9}.share-dialog-copy.copied{background:var(--success);color:#fff}@media (max-width:480px){.share-dialog-input-wrapper{flex-direction:column}.share-dialog-copy{justify-content:center}}.import-dialog{max-width:420px}.import-dialog-text{color:var(--accents-6);margin:0 0 8px;font-size:.9rem;line-height:1.5}.import-dialog-name{background:var(--accents-1);border:1px solid var(--accents-3);color:var(--foreground);border-radius:6px;margin:0 0 16px;padding:10px 14px;font-size:.9rem;font-weight:500}.import-dialog-buttons{gap:12px;margin-top:20px;display:flex}.import-dialog-btn{cursor:pointer;border:none;border-radius:6px;flex:1;justify-content:center;align-items:center;gap:8px;padding:12px 16px;font-size:.875rem;font-weight:500;transition:all .15s;display:flex}.import-dialog-btn-update{background:var(--geist-success);color:#fff}.import-dialog-btn-update:hover{filter:brightness(1.1)}.import-dialog-btn-create{background:var(--accents-2);color:var(--foreground)}.import-dialog-btn-create:hover{background:var(--accents-3)}.import-dialog-btn-danger{background:var(--geist-error);color:#fff}.import-dialog-btn-danger:hover{filter:brightness(1.1)}.import-dialog-btn:disabled{opacity:.5;cursor:not-allowed}@media (max-width:480px){.import-dialog-buttons{flex-direction:column}}.cloud-disable-warning{color:var(--geist-warning);justify-content:center;margin-bottom:16px;display:flex}.cloud-toggle,.cloud-toggle-icon{position:relative}.cloud-toggle-slash{background:currentColor;border-radius:1px;width:24px;height:2px;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)rotate(-45deg)}.cloud-sync-overlay{background:color-mix(in srgb,var(--background)70%,transparent);-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);z-index:10000;color:var(--accents-5);flex-direction:column;justify-content:center;align-items:center;gap:20px;font-size:1rem;animation:.2s ease-out forwards overlayFadeIn;display:flex;position:fixed;inset:0}.cloud-sync-overlay.closing{animation:.2s ease-out forwards overlayFadeOut}@keyframes overlayFadeIn{0%{opacity:0;-webkit-backdrop-filter:blur();backdrop-filter:blur()}to{opacity:1;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}}@keyframes overlayFadeOut{0%{opacity:1;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}to{opacity:0;-webkit-backdrop-filter:blur();backdrop-filter:blur()}}.cloud-sync-spinner{border:3px solid var(--accents-3);border-top-color:var(--geist-success);border-radius:50%;width:40px;height:40px;animation:.8s linear infinite spin}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.sync-animation{animation:1s linear infinite spin}.dialog-overlay{-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);z-index:10000;background:#0009;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.dialog-content{background:var(--background);border:1px solid var(--accents-2);border-radius:12px;width:90%;max-width:360px;padding:24px}.dialog-title{color:var(--foreground);margin:0 0 8px;font-size:1rem;font-weight:600}.dialog-text{color:var(--accents-5);margin:0 0 20px;font-size:.8125rem}.dialog-actions{justify-content:flex-end;gap:8px;display:flex}.dialog-btn-secondary{border:1px solid var(--accents-3);background:var(--background);color:var(--foreground);cursor:pointer;border-radius:6px;padding:6px 14px;font-size:.8125rem;font-weight:500;transition:border-color .2s}.dialog-btn-secondary:hover{border-color:var(--foreground)}.dialog-btn-danger{border:1px solid var(--error);background:var(--error);color:#fff;cursor:pointer;border-radius:6px;padding:6px 14px;font-size:.8125rem;font-weight:500;transition:opacity .2s}.dialog-btn-danger:hover{opacity:.9}.create-scenario-dialog{max-width:400px}.dialog-header{justify-content:space-between;align-items:center;margin-bottom:16px;display:flex}.dialog-header .dialog-title{margin:0}.dialog-close{width:28px;height:28px;color:var(--accents-5);cursor:pointer;background:0 0;border:none;border-radius:6px;justify-content:center;align-items:center;display:flex}.dialog-close:hover{background:var(--accents-2);color:var(--foreground)}.create-scenario-options{flex-direction:column;gap:10px;display:flex}.create-scenario-option{border:1px solid var(--accents-2);background:var(--background);color:var(--foreground);cursor:pointer;text-align:left;border-radius:10px;flex-direction:column;align-items:flex-start;gap:6px;padding:16px;transition:border-color .15s,background .15s;display:flex}.create-scenario-option:hover{border-color:var(--accents-4);background:var(--accents-1)}.create-scenario-option-locked{opacity:.5;cursor:not-allowed}.create-scenario-option-locked:hover{border-color:var(--accents-2);background:var(--background)}.create-scenario-option-title{align-items:center;gap:6px;font-size:.875rem;font-weight:600;display:flex}.create-scenario-option-crown{color:var(--geist-warning)}.create-scenario-option-desc{color:var(--accents-4);font-size:.75rem}.create-scenario-progress{flex-direction:column;align-items:center;gap:12px;padding:24px 0;display:flex}.create-scenario-status{color:var(--accents-5);margin:0;font-size:.8125rem}.create-scenario-status-error{color:var(--error)}.create-scenario-retry{border:1px solid var(--accents-3);background:var(--background);color:var(--foreground);cursor:pointer;border-radius:6px;padding:6px 14px;font-size:.8125rem}.create-scenario-retry:hover{border-color:var(--foreground)}
.settings-backdrop{z-index:10000;background:#0009;justify-content:center;align-items:center;animation:.15s ease-out backdropFadeIn;display:flex;position:fixed;inset:0}.settings-dialog{background:var(--background);border:1px solid var(--accents-2);border-radius:12px;flex-direction:column;width:680px;max-width:95vw;height:480px;max-height:85vh;animation:.2s ease-out dialogSlideIn;display:flex;overflow:hidden;box-shadow:0 4px 24px #0003}.settings-header{border-bottom:1px solid var(--accents-2);flex-shrink:0;justify-content:space-between;align-items:center;padding:16px 20px;display:flex}.settings-header h3{color:var(--foreground);margin:0;font-size:1rem;font-weight:500}.settings-close{width:32px;height:32px;color:var(--accents-5);cursor:pointer;background:0 0;border:none;border-radius:6px;justify-content:center;align-items:center;transition:all .15s;display:flex}.settings-close:hover{background:var(--accents-2);color:var(--foreground)}.settings-body{flex:1;min-height:0;display:flex;overflow:hidden}.settings-nav{border-right:1px solid var(--accents-2);flex-direction:column;flex-shrink:0;gap:2px;width:180px;padding:8px;display:flex;position:relative;overflow-y:auto}.settings-nav-highlight{display:none}.settings-nav-item{z-index:1;box-sizing:border-box;height:36px;color:var(--accents-5);cursor:pointer;text-align:left;background:0 0;border:none;border-radius:6px;align-items:center;gap:10px;padding:8px 12px;font-size:.8125rem;font-weight:500;transition:all .15s;display:flex;position:relative}.settings-nav-item:hover,.settings-nav-item.active{color:var(--foreground);background:var(--accents-2)}.settings-version{color:var(--accents-4);margin-top:auto;padding:12px;font-size:.75rem}.settings-main{flex-direction:column;flex:1;min-width:0;min-height:0;display:flex;overflow:hidden}.settings-scroll{flex:1;min-height:0;padding:20px 24px;overflow:hidden auto}.settings-section-header{margin-bottom:20px}.settings-section-header h4{color:var(--foreground);margin:0 0 4px;font-size:.875rem;font-weight:500}.settings-section-header p{color:var(--accents-4);margin:0;font-size:.75rem}.settings-fields{flex-direction:column;gap:16px;min-width:0;max-width:100%;display:flex}.settings-field{flex-direction:column;gap:6px;display:flex}.settings-field label{color:var(--accents-5);font-size:.8125rem;font-weight:500}.settings-input-wrapper{align-items:center;gap:8px;display:flex}.settings-input{box-sizing:border-box;background:var(--background);border:1px solid var(--accents-3);width:100%;color:var(--foreground);border-radius:6px;outline:none;flex:1;padding:8px 12px;font-size:.875rem;transition:border-color .15s}.settings-input:focus{border-color:var(--foreground)}.settings-input::placeholder{color:var(--accents-4)}.settings-input-readonly{background:var(--accents-1);color:var(--accents-5);cursor:not-allowed}.settings-unit{color:var(--accents-4);min-width:40px;font-size:.8125rem}.settings-hint{color:var(--accents-4);font-size:.75rem;line-height:1.4}.settings-hint a{color:var(--accents-5);text-underline-offset:2px;text-decoration:underline}.settings-hint a:hover{color:var(--foreground)}.settings-actions{border-top:1px solid var(--accents-2);flex-shrink:0;justify-content:flex-end;gap:8px;padding:16px 24px;display:flex}.settings-btn-cancel,.settings-btn-save{cursor:pointer;border:none;border-radius:6px;padding:8px 16px;font-size:.8125rem;font-weight:500;transition:all .15s}.settings-btn-cancel{border:1px solid var(--accents-3);color:var(--foreground);background:0 0}.settings-btn-cancel:hover{border-color:var(--accents-4);background:var(--accents-1)}.settings-btn-save{background:var(--foreground);color:var(--background)}.settings-btn-save:hover{opacity:.9}.theme-options{gap:8px;display:flex}.theme-option{border:1px solid var(--accents-3);color:var(--accents-5);cursor:pointer;background:0 0;border-radius:8px;flex-direction:column;flex:1;align-items:center;gap:6px;min-width:70px;padding:12px 20px;transition:all .15s;display:flex}.theme-option:hover{border-color:var(--accents-4);color:var(--foreground)}.theme-option.active{border-color:var(--foreground);color:var(--foreground)}.theme-option span{font-size:.8125rem;font-weight:500}@media (max-width:600px){.settings-dialog{border-radius:0;width:100%;max-width:100vw;height:100%;max-height:100dvh}.settings-body{flex-direction:column}.settings-nav{border-right:none;border-bottom:1px solid var(--accents-2);flex-direction:row;flex-shrink:0;width:auto;overflow-x:auto}.settings-nav-item{white-space:nowrap}.settings-nav-item.active{background:var(--accents-2)}.theme-options{flex-direction:column}.theme-option{flex-direction:row;justify-content:flex-start;padding:10px 14px}}
@media (max-width:900px){.header-button .button-text{display:none}.header-button{padding:8px 12px}.header-button.save-button{min-width:auto}}@media (max-width:1023px){.header-metrics-inline{display:none}.header-metrics-bar{justify-content:flex-end;display:flex}.header-metrics-bar .header-metrics{flex-wrap:wrap;justify-content:flex-end;max-width:100%}.header-metrics-bar .header-metric{align-items:flex-end;margin-right:16px}.header-metrics-bar .header-metric:last-child{margin-right:0}}@media (max-width:768px){.header-top{padding:12px 16px}.panel{flex-shrink:0;width:100%;height:auto}.panel-inputs,.panel-financing,.panel-metrics,.panel-charts,.panel-tilgungsplan{width:100%}.home-screen{overflow:auto}.home-content{padding:24px 16px}.scenarios-grid{grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:16px}.header-metrics-bar{justify-content:center}.header-metrics-bar .header-metrics{text-align:center;grid-template-columns:repeat(3,1fr);justify-items:center;gap:12px 8px;width:100%;display:grid}.header-metrics-bar .header-metric{align-items:center;margin:0}}@media (max-width:480px){.header-top{padding:12px}.header-button{padding:8px 10px}.header-metrics-bar .header-metric .label{font-size:.65rem}.header-metrics-bar .header-metric .value{font-size:.9rem}.home-screen{min-height:100dvh;overflow:auto}.home-content{padding:16px;overflow:visible}.scenarios-grid{grid-template-columns:1fr;gap:16px}.add-scenario-card{min-height:80px}.section-header{margin-top:24px}.scenario-card{width:100%;max-width:100%}.scenario-card-header{padding:12px 8px 0 12px}.scenario-card-header .scenario-name{font-size:1rem}.scenario-card-content{padding:4px 12px 12px}.scenario-metric .label{font-size:.7rem}.scenario-metric .value{font-size:.8rem}.scenario-card-footer{padding:10px 12px}.scenario-date{font-size:.7rem}}@media (max-width:360px){.header-metrics-bar .header-metrics{grid-template-columns:repeat(2,1fr)}}
.chat-bubble{bottom:calc(32px + env(safe-area-inset-bottom));background:var(--foreground);width:52px;height:52px;color:var(--background);cursor:pointer;z-index:9998;opacity:1;border:none;border-radius:50%;justify-content:center;align-items:center;padding:0;transition:transform .3s cubic-bezier(.4,0,.2,1),opacity .2s;display:flex;position:fixed;right:32px;box-shadow:0 4px 12px #0000004d}.chat-bubble:hover{transform:scale(1.08);box-shadow:0 6px 20px #0006}.chat-bubble-hidden{opacity:0;pointer-events:none;transform:scale(.5)}.chat-window{bottom:calc(24px + env(safe-area-inset-bottom));background:var(--background);border:1px solid var(--accents-3);z-index:9998;transform-origin:100% 100%;border-radius:12px;flex-direction:column;width:400px;max-width:calc(100vw - 48px);height:560px;max-height:calc(100dvh - 48px);transition:transform .3s cubic-bezier(.4,0,.2,1),opacity .3s;display:flex;position:fixed;right:24px;overflow:hidden;box-shadow:0 8px 32px #0006}.chat-window-open{opacity:1;pointer-events:auto;transform:scale(1)}.chat-window-closed{opacity:0;pointer-events:none;transform:scale(.4)}.chat-header{border-bottom:1px solid var(--accents-2);flex-shrink:0;justify-content:space-between;align-items:center;padding:12px 16px;display:flex}.chat-title{color:var(--foreground);font-size:14px;font-weight:600}.chat-header-actions{gap:4px;display:flex}.chat-header-btn{color:var(--accents-5);cursor:pointer;background:0 0;border:none;border-radius:4px;align-items:center;padding:4px;transition:color .15s,background .15s;display:flex}.chat-header-btn:hover{color:var(--foreground);background:var(--accents-2)}.chat-messages{scrollbar-width:thin;scrollbar-color:var(--accents-3)transparent;flex-direction:column;flex:1;gap:12px;padding:16px;display:flex;overflow-y:auto}.chat-messages::-webkit-scrollbar{width:6px}.chat-messages::-webkit-scrollbar-track{background:0 0}.chat-messages::-webkit-scrollbar-thumb{background:var(--accents-3);border-radius:3px}.chat-messages::-webkit-scrollbar-thumb:hover{background:var(--accents-4)}.chat-setup{height:100%;color:var(--accents-5);text-align:center;flex-direction:column;justify-content:center;align-items:center;gap:12px;padding:24px;display:flex}.chat-setup p{margin:0;font-size:14px}.chat-setup-btn{background:var(--foreground);color:var(--background);cursor:pointer;border:none;border-radius:6px;align-items:center;gap:6px;padding:8px 16px;font-size:13px;font-weight:500;transition:opacity .15s;display:flex}.chat-setup-btn:hover{opacity:.85}.chat-empty{height:100%;color:var(--accents-5);text-align:center;flex-direction:column;justify-content:center;align-items:center;gap:8px;padding:24px;display:flex}.chat-empty p{color:var(--foreground);margin:0;font-size:14px}.chat-hint{opacity:.7;font-size:12px}.chat-msg{max-width:85%;animation:.15s ease-out chatMsgIn}.chat-msg-user{align-self:flex-end}.chat-msg-assistant{align-self:flex-start}.chat-msg-content{white-space:pre-wrap;word-break:break-word;border-radius:10px;padding:8px 12px;font-size:14px;line-height:1.5}.chat-msg-user .chat-msg-content{background:var(--foreground);color:var(--background);border-bottom-right-radius:4px}.chat-msg-assistant .chat-msg-content{background:var(--accents-2);color:var(--foreground);border-bottom-left-radius:4px}.chat-error{color:var(--error);background:#ef44441a;border-radius:6px;padding:8px 12px;font-size:13px}.chat-input-area{border-top:1px solid var(--accents-2);flex-shrink:0;align-items:flex-end;gap:8px;padding:12px 16px;display:flex}.chat-input{resize:none;border:1px solid var(--accents-3);background:var(--accents-1);color:var(--foreground);border-radius:8px;flex:1;max-height:100px;padding:8px 12px;font-family:inherit;font-size:14px;line-height:1.4;overflow-y:auto}.chat-input::placeholder{color:var(--accents-4)}.chat-input:focus{border-color:var(--accents-5);outline:none}.chat-send-btn{background:var(--foreground);color:var(--background);cursor:pointer;border:none;border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;transition:opacity .15s;display:flex}.chat-send-btn:hover:not(:disabled){opacity:.85}.chat-send-btn:disabled{opacity:.3;cursor:default}@keyframes chatMsgIn{0%{opacity:0;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}@media (max-width:480px){.chat-window-open{border:none;border-radius:0;width:100%;max-width:100%;height:100%;max-height:100%;bottom:0;right:0}}
.auth-dialog{max-height:calc(100dvh - 32px);overflow-y:auto}.auth-section{box-sizing:border-box;flex-direction:column;gap:16px;max-width:100%;display:flex}.auth-description{color:var(--accents-5);margin:0;font-size:.875rem}.auth-google-btn{box-sizing:border-box;border:1px solid var(--accents-3);background:var(--background);width:100%;max-width:100%;color:var(--foreground);cursor:pointer;border-radius:8px;justify-content:center;align-items:center;gap:10px;padding:10px 16px;font-size:.875rem;font-weight:500;transition:border-color .15s,background .15s;display:flex}.auth-google-btn:hover:not(:disabled){border-color:var(--accents-5);background:var(--accents-1)}.auth-google-btn:disabled{opacity:.6;cursor:not-allowed}.auth-divider{color:var(--accents-4);align-items:center;gap:12px;font-size:.75rem;display:flex}.auth-divider:before,.auth-divider:after{content:"";background:var(--accents-2);flex:1;height:1px}.auth-email-form{flex-direction:column;gap:12px;display:flex}.auth-error{color:var(--error);margin:0;font-size:.8rem}.auth-submit-btn{box-sizing:border-box;background:var(--foreground);width:100%;color:var(--background);cursor:pointer;border:none;border-radius:8px;justify-content:center;align-items:center;gap:8px;padding:10px 16px;font-size:.875rem;font-weight:500;transition:opacity .15s;display:flex}.auth-submit-btn:hover:not(:disabled){opacity:.85}.auth-submit-btn:disabled{opacity:.6;cursor:not-allowed}.auth-mode-toggle{color:var(--accents-5);cursor:pointer;text-align:center;background:0 0;border:none;padding:0;font-size:.8rem}.auth-mode-toggle:hover{color:var(--foreground)}.auth-guest-btn{border:1px solid var(--accents-2);color:var(--accents-5);cursor:pointer;box-sizing:border-box;background:0 0;border-radius:6px;width:100%;padding:8px 16px;font-size:.8rem;transition:color .15s,border-color .15s}.auth-guest-btn:hover{color:var(--foreground);border-color:var(--accents-4)}.auth-user-info{align-items:center;gap:12px;display:flex}.auth-avatar{border-radius:50%;width:40px;height:40px}.auth-user-details{flex-direction:column;gap:2px;display:flex}.auth-user-name{color:var(--foreground);font-size:.875rem;font-weight:500}.auth-user-email{color:var(--accents-5);font-size:.75rem}.auth-sync-status{background:var(--accents-1);border:1px solid var(--accents-2);border-radius:8px;flex-direction:column;gap:8px;padding:12px;display:flex}.auth-sync-label{color:var(--accents-5);align-items:center;gap:6px;font-size:.8rem;display:flex}.auth-sync-btn{border:1px solid var(--accents-3);background:var(--background);color:var(--foreground);cursor:pointer;border-radius:6px;align-items:center;gap:6px;width:fit-content;padding:6px 12px;font-size:.8rem;transition:border-color .15s;display:flex}.auth-sync-btn:hover:not(:disabled){border-color:var(--accents-5)}.auth-sync-btn:disabled{opacity:.6;cursor:not-allowed}.auth-signout-btn{border:1px solid var(--accents-3);background:var(--background);color:var(--foreground);cursor:pointer;border-radius:8px;align-items:center;gap:8px;width:fit-content;padding:8px 14px;font-size:.8rem;transition:border-color .15s,color .15s;display:flex}.auth-signout-btn:hover{border-color:var(--error);color:var(--error)}@keyframes auth-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.auth-spin{animation:1s linear infinite auth-spin}
.premium-section{flex-direction:column;gap:16px;display:flex}.premium-features-list{flex-direction:column;gap:8px;display:flex}.premium-feature-item{border:1px solid var(--accents-2);background:var(--background);border-radius:8px;align-items:center;gap:12px;padding:10px 12px;transition:border-color .15s;display:flex}.premium-feature-item:hover{border-color:var(--accents-4)}.premium-feature-active{border-color:var(--geist-success);background:var(--accents-1)}.premium-feature-icon{background:var(--accents-1);width:32px;height:32px;color:var(--foreground);border-radius:6px;flex-shrink:0;justify-content:center;align-items:center;display:flex}.premium-feature-check{background:var(--geist-success);width:24px;height:24px;color:var(--background);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;display:flex}.premium-feature-text{flex-direction:column;gap:2px;min-width:0;display:flex;overflow:hidden}.premium-feature-title{color:var(--foreground);font-size:.875rem;font-weight:500}.premium-feature-desc{color:var(--accents-5);font-size:.8rem;line-height:1.4}.premium-cta-btn{background:var(--foreground);color:var(--background);cursor:pointer;border:none;border-radius:6px;padding:8px 14px;font-size:.8125rem;font-weight:500;transition:opacity .15s}.premium-cta-btn:hover{opacity:.85}.premium-hint{text-align:center;color:var(--accents-4);margin:0;font-size:.75rem}.premium-active-badge{background:var(--accents-1);border:1px solid var(--geist-success);color:var(--geist-success);border-radius:8px;align-items:center;gap:8px;width:fit-content;padding:8px 16px;font-size:.875rem;font-weight:600;display:flex}.premium-since{color:var(--accents-5);margin:0;font-size:.8rem}.premium-manage-btn{border:1px solid var(--accents-3);background:var(--background);width:fit-content;color:var(--foreground);cursor:pointer;border-radius:8px;padding:8px 16px;font-size:.8rem;font-weight:500;transition:all .15s}.premium-manage-btn:hover{border-color:var(--accents-5);background:var(--accents-1)}.premium-manage-btn:disabled{opacity:.5;cursor:not-allowed}.premium-canceling{color:var(--geist-warning);margin:0;font-size:.8rem}
.landing{min-height:100dvh;background:var(--background);-webkit-overflow-scrolling:touch;min-height:-webkit-fill-available;padding:0 24px;padding-top:env(safe-area-inset-top);padding-bottom:env(safe-area-inset-bottom);flex-direction:column;align-items:center;display:flex;position:relative;overflow:hidden auto}.landing-topbar{z-index:10;background:var(--background);justify-content:flex-end;align-items:center;gap:12px;width:100%;max-width:1100px;padding:16px 0;display:flex;position:sticky;top:0}.landing-dashboard-btn{color:var(--foreground);background:var(--background);border:1px solid var(--accents-3);cursor:pointer;border-radius:6px;padding:6px 14px;font-size:.8125rem;font-weight:500;transition:border-color .2s}.landing-dashboard-btn:hover{border-color:var(--foreground)}.landing-signin-btn{color:var(--foreground);background:var(--background);border:1px solid var(--accents-3);cursor:pointer;border-radius:6px;padding:6px 14px;font-size:.8125rem;font-weight:500;transition:border-color .2s}.landing-signin-btn:hover{border-color:var(--foreground)}.landing-avatar-btn{cursor:pointer;background:0 0;border:none;border-radius:50%;padding:0;line-height:0}.landing-avatar{border:1px solid var(--accents-3);object-fit:cover;border-radius:50%;width:32px;height:32px}.landing-grid-bg{background-image:radial-gradient(circle,var(--accents-3)1px,transparent 1px);opacity:.5;pointer-events:none;background-size:32px 32px;height:100%;min-height:100%;position:absolute;inset:0;-webkit-mask-image:radial-gradient(80% 60% at 50% 40%,#000 20%,#0000 100%);mask-image:radial-gradient(80% 60% at 50% 40%,#000 20%,#0000 100%)}.landing-hero{text-align:center;flex-direction:column;align-items:center;width:100%;max-width:720px;padding:120px 0 80px;display:flex;position:relative}.landing-headline{letter-spacing:-.04em;margin:0 0 24px;font-size:4.5rem;font-weight:700;line-height:1.1}.landing-headline-gradient{background:linear-gradient(135deg,var(--foreground)0%,var(--accents-5)100%);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text}.landing-subtitle{color:var(--accents-5);max-width:540px;margin:0 0 40px;font-size:1.25rem;line-height:1.6}.landing-cta-group{align-items:center;gap:12px;display:flex}.landing-cta-primary{background:var(--foreground);color:var(--background);cursor:pointer;border:none;border-radius:9999px;align-items:center;gap:8px;padding:12px 24px;font-size:1rem;font-weight:500;transition:opacity .15s,transform .15s;display:inline-flex}.landing-cta-primary:hover{opacity:.9;transform:translateY(-1px)}.landing-cta-secondary{color:var(--foreground);border:1px solid var(--accents-3);cursor:pointer;background:0 0;border-radius:9999px;align-items:center;gap:8px;padding:12px 24px;font-size:1rem;font-weight:500;transition:border-color .15s,transform .15s;display:inline-flex}.landing-cta-secondary:hover{border-color:var(--accents-5);transform:translateY(-1px)}.landing-features{width:100%;max-width:1100px;padding:40px 0 80px;position:relative}.landing-section-title{text-transform:uppercase;letter-spacing:.1em;color:var(--accents-5);text-align:center;margin:0 0 40px;font-size:1rem;font-weight:500}.landing-features-grid{grid-template-columns:repeat(3,1fr);gap:16px;display:grid}.landing-feature-card{background:var(--background);border:1px solid var(--accents-2);border-radius:12px;flex-direction:column;padding:24px;transition:border-color .2s,box-shadow .2s;display:flex}.landing-feature-card:hover{border-color:var(--accents-4);box-shadow:0 0 0 1px var(--accents-3),0 8px 24px #0003}.landing-feature-icon{background:var(--accents-1);width:40px;height:40px;color:var(--accents-6);border-radius:8px;justify-content:center;align-items:center;margin-bottom:16px;display:flex}.landing-feature-title{color:var(--foreground);margin:0 0 8px;font-size:1rem;font-weight:600}.landing-feature-desc{color:var(--accents-5);margin:0;font-size:.875rem;line-height:1.5}.landing-bottom-cta{flex-direction:column;align-items:center;gap:20px;padding:60px 0 80px;display:flex;position:relative}.landing-bottom-text{color:var(--accents-5);margin:0;font-size:1.125rem}.landing-footer{border-top:1px solid var(--accents-2);box-sizing:border-box;flex-direction:column;align-items:flex-start;gap:12px;width:100%;max-width:1100px;margin-top:auto;padding:48px 0;display:flex;position:relative}.landing-footer-links{gap:24px;display:flex}.landing-footer-link{color:var(--accents-5);cursor:pointer;background:0 0;border:none;padding:0;font-family:inherit;font-size:.875rem;text-decoration:none;transition:color .15s}.landing-footer-link:hover{color:var(--foreground)}.landing-footer-vercel,.landing-footer-copyright{color:var(--accents-4);margin:0;font-size:.75rem}.legal-page{background:var(--background);min-height:100dvh;color:var(--foreground);padding:80px 24px;padding-bottom:calc(80px + env(safe-area-inset-bottom));justify-content:center;display:flex}.legal-page-content{width:100%;max-width:640px}.legal-page-content h1{margin:24px 0 16px;font-size:2rem;font-weight:700}.legal-page-content h2{color:var(--foreground);margin:32px 0 8px;font-size:1.25rem;font-weight:600}.legal-page-content p{color:var(--accents-5);margin:0 0 16px;font-size:1rem;line-height:1.7}.legal-page-back{color:var(--accents-5);cursor:pointer;background:0 0;border:none;padding:0;font-family:inherit;font-size:.875rem;text-decoration:none;transition:color .15s}.legal-page-back:hover{color:var(--foreground)}@media (max-width:1200px){.landing-features-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width:768px){.landing-hero{padding:80px 0 60px}.landing-headline{font-size:3rem}.landing-subtitle{font-size:1.1rem}.landing-features-grid{grid-template-columns:1fr}.landing-cta-group{box-sizing:border-box;flex-direction:column;width:100%;padding:0 24px}.landing-cta-primary,.landing-cta-secondary{justify-content:center;width:100%}}
.sidebar-hamburger{color:var(--accents-5);cursor:pointer;background:0 0;border:none;border-radius:6px;padding:8px;line-height:0;transition:all .15s;display:none}.sidebar-hamburger:hover{color:var(--foreground);background:var(--accents-1)}@media (max-width:1023px){.sidebar-hamburger{display:block}}.sidebar-backdrop{display:none}.sidebar{background:var(--background);border-right:1px solid var(--accents-2);flex-direction:column;width:240px;min-width:240px;height:100%;display:none;position:relative;overflow:hidden}.sidebar-indicator{background:var(--foreground);z-index:2;pointer-events:none;border-radius:0 1px 1px 0;width:2px;transition:transform .2s cubic-bezier(.4,0,.2,1),height .2s cubic-bezier(.4,0,.2,1),opacity .15s;position:absolute;top:0;left:0}.sidebar-header{padding:14px 12px 10px;padding-top:max(14px,env(safe-area-inset-top));justify-content:space-between;align-items:center;display:flex}.sidebar-header-actions{align-items:center;gap:4px;display:flex}.sidebar-profile-btn{width:28px;height:28px;color:var(--accents-5);cursor:pointer;background:0 0;border:none;border-radius:6px;justify-content:center;align-items:center;padding:0;transition:all .15s;display:flex}.sidebar-profile-btn:hover{color:var(--foreground);background:var(--accents-1)}.sidebar-avatar{width:24px;height:24px}.sidebar-brand-group{flex-direction:column;display:flex}.sidebar-plan{color:var(--accents-4);padding:0 4px;font-size:.75rem;font-weight:400}.sidebar-brand{letter-spacing:-.02em;color:var(--foreground);cursor:pointer;background:0 0;border:none;padding:0 4px;font-size:1.0625rem;font-weight:600}.sidebar-close{color:var(--accents-5);cursor:pointer;background:0 0;border:none;border-radius:6px;padding:6px;line-height:0;transition:all .15s;display:none}.sidebar-close:hover{color:var(--foreground);background:var(--accents-1)}.sidebar-nav{box-sizing:border-box;flex-direction:column;flex:1;min-width:0;padding:4px 8px 0;display:flex;overflow:hidden}.sidebar-top-actions{flex-direction:column;gap:1px;margin-bottom:12px;display:flex}.sidebar-nav-card{color:var(--foreground);cursor:pointer;box-sizing:border-box;background:0 0;border:none;border-radius:6px;outline:none;align-items:center;gap:10px;width:100%;max-width:100%;padding:7px 8px;font-size:.875rem;font-weight:400;transition:background .15s;display:flex}.sidebar-nav-card:hover,.sidebar-nav-card.active{background:var(--accents-1)}.sidebar-scenarios{flex-direction:column;flex:1;gap:1px;min-width:0;margin:0;padding:0;display:flex;overflow:hidden auto}.sidebar-scenarios::-webkit-scrollbar{width:4px}.sidebar-scenarios::-webkit-scrollbar-track{background:0 0}.sidebar-scenarios::-webkit-scrollbar-thumb{background:var(--accents-3);border-radius:2px}.sidebar-scenario-item{width:100%;max-width:100%;color:var(--foreground);text-align:left;cursor:pointer;box-sizing:border-box;background:0 0;border:none;border-radius:6px;outline:none;align-items:center;min-width:0;padding:7px 8px;font-size:.875rem;transition:background .15s;display:flex;overflow:hidden}.sidebar-scenario-item:hover,.sidebar-scenario-item.active{background:var(--accents-1)}.sidebar-scenario-content{flex-direction:column;flex:1;gap:2px;min-width:0;display:flex}.sidebar-scenario-name{text-overflow:ellipsis;white-space:nowrap;line-height:1.4;overflow:hidden}.sidebar-scenario-kpi{color:var(--accents-5);font-variant-numeric:tabular-nums;text-overflow:ellipsis;white-space:nowrap;font-size:.75rem;line-height:1.3;overflow:hidden}.sidebar-scenario-kpi .positive{color:var(--success)}.sidebar-scenario-kpi .negative{color:var(--error)}.sidebar-divider{background:var(--accents-2);height:1px;margin:8px 0}@media (min-width:1024px){.sidebar{display:flex}}@media (max-width:1023px){.sidebar-backdrop{z-index:999;background:#0009;display:block;position:fixed;inset:0}.sidebar{z-index:1000;transition:transform .2s;display:flex;position:fixed;top:0;bottom:0;left:0;transform:translate(-100%);box-shadow:0 0 24px #0006}.sidebar.sidebar-open{transform:translate(0)}.sidebar-close{display:block}}.calculator-layout{width:100%;height:100dvh;display:flex;overflow:hidden}.calculator-layout-content{flex-direction:column;flex:1;min-width:0;height:100%;display:flex;position:relative;overflow:hidden}.calculator-layout-content>.cloud-sync-overlay{z-index:100;position:absolute}.sidebar-footer{padding:12px 16px;padding-bottom:max(12px,env(safe-area-inset-bottom));border-top:1px solid var(--accents-2);align-items:center;gap:8px;display:flex}.sidebar-signin-btn{border:1px solid var(--accents-2);color:var(--foreground);cursor:pointer;background:0 0;border-radius:6px;align-items:center;gap:6px;padding:6px 12px;font-size:.8125rem;font-weight:500;transition:all .15s;display:flex}.sidebar-signin-btn:hover{background:var(--accents-1);border-color:var(--accents-3)}.sidebar-theme-toggle{cursor:pointer;width:28px;height:28px;color:var(--accents-5);background:0 0;border:none;border-radius:6px;outline:none;justify-content:center;align-items:center;transition:all .15s;display:flex}.sidebar-theme-toggle:hover{color:var(--foreground);background:var(--accents-1)}
.portfolio-dashboard{padding:24px 32px;padding-bottom:calc(24px + env(safe-area-inset-bottom));height:100%;overflow-y:auto}.portfolio-empty{text-align:center;height:60vh;color:var(--accents-5);flex-direction:column;justify-content:center;align-items:center;display:flex}.portfolio-empty h2{color:var(--foreground);margin-bottom:8px;font-size:1.25rem;font-weight:600}.portfolio-empty-hint{color:var(--accents-4);max-width:320px;font-size:.8125rem}.portfolio-title{color:var(--foreground);margin:0 0 16px;font-size:1.25rem;font-weight:600}.portfolio-kpi-grid{grid-template-columns:repeat(3,1fr);gap:12px;margin-bottom:24px;display:grid}.portfolio-kpi-card{border:1px solid var(--accents-2);border-radius:var(--border-radius);background:var(--background);flex-direction:column;gap:8px;padding:16px;display:flex;box-shadow:0 1px 3px #0000000f}.portfolio-kpi-label{text-transform:uppercase;letter-spacing:.04em;color:var(--accents-5);font-family:Geist Mono,monospace;font-size:.6875rem;font-weight:500}.portfolio-kpi-value{font-variant-numeric:tabular-nums;color:var(--foreground);font-family:Geist Mono,monospace;font-size:1.25rem;font-weight:700;line-height:1.2}.portfolio-kpi-value.positive{color:var(--success)}.portfolio-kpi-value.negative{color:var(--error)}.portfolio-kpi-value.warning{color:var(--warning,#f5a623)}.portfolio-yoy{font-variant-numeric:tabular-nums;color:var(--accents-5);font-family:Geist Mono,monospace;font-size:.6875rem;font-weight:500}.portfolio-yoy.positive{color:var(--success)}.portfolio-yoy.negative{color:var(--error)}.portfolio-yoy.neutral{color:var(--accents-4)}@media (max-width:768px){.portfolio-kpi-grid{grid-template-columns:repeat(2,1fr)}}.portfolio-charts-grid{grid-template-columns:1fr 1fr 1fr;gap:12px;margin-bottom:24px;display:grid}@media (max-width:900px){.portfolio-charts-grid{grid-template-columns:1fr}}.portfolio-chart-section{border:1px solid var(--accents-2);border-radius:var(--border-radius);min-width:0;margin-bottom:0}.portfolio-chart-section .portfolio-section-title{border-bottom:1px solid var(--accents-2);background:var(--background);border-radius:var(--border-radius)var(--border-radius)0 0;margin:0;padding:4px 10px}.portfolio-chart-section .chart-container{box-sizing:border-box;width:100%;height:180px;margin:0 auto;padding:8px 12px 4px}.portfolio-section-title{text-transform:uppercase;letter-spacing:.05em;color:var(--accents-5);margin:0 0 12px;font-family:Geist Mono,monospace;font-size:.6875rem;font-weight:500}.portfolio-properties .portfolio-section-title{margin-bottom:12px}.portfolio-property-list{grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:12px;display:grid}.portfolio-property-card{background:var(--background);border:1px solid var(--accents-2);border-radius:var(--border-radius);cursor:pointer;text-align:left;width:100%;padding:0;transition:border-color .2s;display:block;overflow:hidden}.portfolio-property-card:hover{border-color:var(--accents-4)}.portfolio-property-header{justify-content:space-between;align-items:center;padding:12px 14px 0;display:flex}.portfolio-property-name{color:var(--foreground);text-overflow:ellipsis;white-space:nowrap;font-size:.875rem;font-weight:600;overflow:hidden}.portfolio-property-date{color:var(--accents-5);flex-shrink:0;font-family:Geist Mono,monospace;font-size:.6875rem}.portfolio-property-metrics{border-top:1px solid var(--accents-2);gap:0;margin:8px 14px 0;padding:8px 0 0;display:flex}.portfolio-property-metric{flex-direction:column;flex:1;gap:2px;padding:6px 0 12px;display:flex}.portfolio-property-metric .label{color:var(--accents-5);text-transform:uppercase;letter-spacing:.05em;font-family:Geist Mono,monospace;font-size:.625rem;font-weight:500}.portfolio-property-metric .value{font-variant-numeric:tabular-nums;color:var(--foreground);font-family:Geist Mono,monospace;font-size:.8125rem;font-weight:600}.portfolio-property-metric .value.positive{color:var(--success)}.portfolio-property-metric .value.negative{color:var(--error)}@media (max-width:768px){.portfolio-dashboard{padding:20px 16px}.portfolio-stats-row{gap:24px}.portfolio-hero-value{font-size:1.5rem}.portfolio-property-list{grid-template-columns:1fr}}
.file-attachments{margin-bottom:16px}.file-attachments-title{color:var(--accents-5);text-transform:uppercase;letter-spacing:.05em;margin:0 0 12px;font-size:.8rem;font-weight:600}.file-attachments-locked{background:var(--accents-1);border:1px dashed var(--accents-3);color:var(--accents-4);border-radius:8px;align-items:center;gap:8px;padding:12px;font-size:.8rem;display:flex}.file-list{flex-direction:column;gap:6px;margin-bottom:10px;display:flex}.file-item{background:var(--accents-1);border:1px solid var(--accents-2);border-radius:6px;align-items:center;gap:10px;padding:8px 10px;display:flex}.file-item-icon{color:var(--accents-5);flex-shrink:0;display:flex}.file-item-icon .sync-animation{color:var(--geist-success)}.file-item-info{flex-direction:column;flex:1;gap:1px;min-width:0;display:flex}.file-item-name{color:var(--foreground);white-space:nowrap;text-overflow:ellipsis;font-size:.8rem;font-weight:500;overflow:hidden}.file-item-size{color:var(--accents-4);font-size:.7rem}.file-item-actions{flex-shrink:0;gap:4px;display:flex}.file-item-btn{width:26px;height:26px;color:var(--accents-5);cursor:pointer;background:0 0;border:none;border-radius:4px;justify-content:center;align-items:center;transition:all .15s;display:flex}.file-item-btn:hover{background:var(--accents-2);color:var(--foreground)}.file-item-btn-delete:hover{color:var(--error)}.file-dropzone{border:1px dashed var(--accents-3);color:var(--accents-4);cursor:pointer;border-radius:8px;justify-content:center;align-items:center;gap:8px;padding:14px;font-size:.8rem;transition:all .15s;display:flex}.file-dropzone:hover{border-color:var(--accents-5);color:var(--foreground);background:var(--accents-1)}.file-upload-progress{background:var(--accents-2);border-radius:2px;height:4px;margin-bottom:10px;overflow:hidden}.file-upload-progress-bar{background:var(--geist-success);border-radius:2px;height:100%;transition:width .2s}.file-upload-progress-bar-indeterminate{width:40%;animation:1.2s ease-in-out infinite indeterminate}@keyframes indeterminate{0%{transform:translate(-100%)}to{transform:translate(350%)}}.file-error{color:var(--error);margin:8px 0 0;font-size:.75rem}.file-item-skeleton{background:linear-gradient(90deg,var(--accents-1)25%,var(--accents-2)50%,var(--accents-1)75%);background-size:200% 100%;border-radius:6px;height:40px;animation:1.5s ease-in-out infinite file-shimmer}@keyframes file-shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}
.map-preview{grid-column:1/-1;height:140px;margin-top:8px;margin-bottom:4px}.map-preview a{border:1px solid var(--accents-2);border-radius:8px;height:140px;transition:border-color .15s;display:block;position:relative;overflow:hidden}.map-preview a:hover{border-color:var(--accents-4)}.map-preview-placeholder{border:1px solid var(--accents-2);border-radius:8px;height:140px;position:relative;overflow:hidden}.map-preview-skeleton{background:linear-gradient(90deg,var(--accents-1)25%,var(--accents-2)50%,var(--accents-1)75%);background-size:200% 100%;animation:2.5s ease-in-out infinite skeleton-shimmer;position:absolute;inset:0}@keyframes skeleton-shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.map-preview-img{object-fit:cover;object-position:center 30%;width:100%;height:140px;display:block}.map-preview-img-hidden{opacity:0;position:absolute}

