:root{--ink:#20262e;--ink-soft:#5b6471;--cream:#faf6ee;--card:#fff;--line:#e7e0d2;--amber:#f59e0b;--amber-deep:#d97706;--teal:#14b8a6;--sky-top:#dfe9f3;--sky-bottom:#f6ead7;--radius:14px;--shadow:0 10px 30px #20262e1f;--sidebar-w:340px}*{box-sizing:border-box}html,body{height:100%;color:var(--ink);background:var(--cream);overscroll-behavior:none;margin:0;font-family:Avenir Next,Avenir,Segoe UI,system-ui,-apple-system,sans-serif}#app{flex-direction:column;height:100%;display:flex}.app-header{background:var(--card);border-bottom:1px solid var(--line);z-index:5;justify-content:space-between;align-items:center;gap:12px;padding:10px 18px;display:flex}.app-title{align-items:center;gap:10px;min-width:0;display:flex}.app-title .bolt{font-size:26px}.app-title h1{letter-spacing:-.01em;margin:0;font-size:17px}.app-title p{color:var(--ink-soft);white-space:nowrap;text-overflow:ellipsis;margin:0;font-size:12px;overflow:hidden}.persona-btn{color:#fff;background:linear-gradient(135deg, var(--amber), var(--amber-deep));cursor:pointer;border:none;border-radius:999px;flex-shrink:0;padding:9px 16px;font-size:13px;font-weight:600;transition:transform .15s;box-shadow:0 3px 10px #d9770659}.persona-btn:hover{transform:translateY(-1px)}.app-main{flex:1;min-height:0;display:flex;position:relative}.scene-wrap{background:linear-gradient(180deg, var(--sky-top) 0%, var(--sky-bottom) 78%, #efe0c8 100%);flex:1;min-width:0;position:relative;overflow:hidden}.scene-wrap canvas{cursor:grab;display:block}.scene-wrap canvas:active{cursor:grabbing}.scene-hint{color:#fff;pointer-events:none;z-index:3;text-align:center;background:#20262ec7;border-radius:999px;max-width:90%;padding:7px 14px;font-size:12.5px;transition:opacity .6s;position:absolute;top:14px;left:50%;transform:translate(-50%)}.scene-hint.fade-out{opacity:0}.sidebar{width:var(--sidebar-w);background:var(--card);border-left:1px solid var(--line);z-index:4;flex-direction:column;display:flex}.sidebar-scroll{flex-direction:column;gap:16px;padding:16px;display:flex;overflow-y:auto}.sheet-toggle{display:none}.summary{flex-direction:column;gap:14px;display:flex}.mode-toggle{background:var(--cream);border:1px solid var(--line);border-radius:999px;grid-template-columns:1fr 1fr;padding:3px;display:grid}.mode-toggle button{color:var(--ink-soft);cursor:pointer;background:0 0;border:none;border-radius:999px;padding:7px 0;font-size:13px;font-weight:600}.mode-toggle button.active{background:var(--ink);color:#fff}.headline{text-align:center;padding:4px 0 2px}.headline-amount{letter-spacing:-.03em;font-size:44px;font-weight:800;line-height:1}.headline-unit{color:var(--ink-soft);margin-left:3px;font-size:17px;font-weight:600}.headline-sub{color:var(--ink-soft);margin-top:7px;font-size:12.5px}.tariff-row{background:var(--cream);border:1px solid var(--line);border-radius:var(--radius);padding:10px 14px}.tariff-row label{color:var(--ink-soft);justify-content:space-between;font-size:13px;display:flex}.tariff-row label b{color:var(--ink)}.tariff-row input[type=range]{width:100%;accent-color:var(--amber);margin:8px 0 2px}.summary h3{text-transform:uppercase;letter-spacing:.08em;color:var(--ink-soft);margin:4px 0 0;font-size:11.5px}.room-row{margin-bottom:9px}.room-row-top{justify-content:space-between;margin-bottom:4px;font-size:13.5px;display:flex}.bar{background:var(--cream);border-radius:4px;height:7px;overflow:hidden}.bar-fill{background:linear-gradient(90deg, var(--amber), var(--amber-deep));border-radius:4px;height:100%;transition:width .45s cubic-bezier(.22,1,.36,1)}.hogs{flex-direction:column;gap:7px;margin:0;padding:0;list-style:none;display:flex}.hogs li{background:var(--cream);border:1px solid var(--line);border-radius:10px;align-items:center;gap:9px;padding:8px 12px;font-size:13.5px;display:flex}.hog-name{text-overflow:ellipsis;white-space:nowrap;flex:1;min-width:0;overflow:hidden}.hogs b small{color:var(--ink-soft);font-weight:500}.empty{color:var(--ink-soft);margin:0;font-size:13px}.all-off{border:1px solid var(--line);color:var(--ink-soft);cursor:pointer;background:0 0;border-radius:10px;padding:9px;font-size:13px}.all-off:hover{background:var(--cream);color:var(--ink)}.supply-note{color:var(--ink-soft);text-align:center;margin:0;font-size:11px}.ad-placeholder{border-radius:var(--radius);background:repeating-linear-gradient(45deg,#fbf8f1,#fbf8f1 12px,#f5f0e4 12px 24px);border:1.5px dashed #cfc6b4;flex-direction:column;justify-content:center;align-items:center;gap:4px;width:100%;margin:0 auto;display:flex}.ad-label{text-transform:uppercase;letter-spacing:.1em;color:var(--ink-soft);font-size:11px}.ad-size{color:#b3a98f;font-size:12px}.mobile-ad{display:none}.tooltip{z-index:50;color:#f3f4f6;pointer-events:none;opacity:0;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#1c2129f2;border-radius:12px;width:250px;padding:12px 14px;font-size:13px;transition:opacity .12s;position:fixed;top:0;left:0}.tooltip.visible{opacity:1}.tip-head{justify-content:space-between;align-items:center;gap:8px;margin-bottom:8px;font-size:14px;display:flex}.badge{text-transform:uppercase;letter-spacing:.06em;border-radius:999px;padding:3px 8px;font-size:10px;font-weight:700}.badge-always{color:#5eead4;background:#14b8a640}.badge-on{color:#fcd34d;background:#f59e0b47}.badge-off{color:#cbd5e1;background:#94a3b840}.tip-grid{grid-template-columns:auto 1fr;gap:4px 12px;display:grid}.tip-grid span{color:#9ca3af}.tip-grid b{text-align:right}.tip-fact{color:#d1d5db;border-top:1px solid #ffffff1f;margin-top:9px;padding-top:8px;font-size:12px;font-style:italic}.tip-hint{color:#93c5fd;margin-top:7px;font-size:11px}.overlay{z-index:100;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);background:#20262e73;justify-content:center;align-items:center;padding:20px;transition:opacity .4s;display:flex;position:fixed;inset:0}.overlay.fade-out{opacity:0;pointer-events:none}.intro-card,.persona-card{background:var(--card);box-shadow:var(--shadow);text-align:center;border-radius:22px;width:100%;max-width:420px;padding:34px 30px;position:relative}.intro-emoji,.persona-emoji{font-size:52px}.intro-card h2,.persona-card h2{letter-spacing:-.02em;margin:14px 0 10px;font-size:23px}.intro-card p,.persona-card p{color:var(--ink-soft);margin:0 0 20px;font-size:14.5px;line-height:1.55}.progress{background:var(--cream);border-radius:3px;height:6px;margin-bottom:16px;overflow:hidden}.progress-fill{background:linear-gradient(90deg, var(--amber), var(--amber-deep));border-radius:3px;width:0;height:100%;transition:width .25s}.intro-start,.share-btn{color:#fff;background:linear-gradient(135deg, var(--amber), var(--amber-deep));cursor:pointer;border:none;border-radius:999px;padding:13px 28px;font-size:15px;font-weight:700;transition:transform .15s;box-shadow:0 4px 14px #d9770666}.intro-start:hover:not(:disabled),.share-btn:hover{transform:translateY(-1px)}.intro-start:disabled{opacity:.55;cursor:wait}.persona-stat{margin-bottom:20px;font-size:30px;font-weight:800}.persona-stat span{color:var(--ink-soft);margin-left:4px;font-size:14px;font-weight:600}.modal-close{color:var(--ink-soft);cursor:pointer;background:0 0;border:none;font-size:26px;line-height:1;position:absolute;top:12px;right:16px}.toast{color:#fff;opacity:0;pointer-events:none;z-index:6;text-align:center;background:#1c2129eb;border-radius:999px;max-width:88%;padding:10px 18px;font-size:13.5px;transition:opacity .25s,transform .25s;position:absolute;bottom:18px;left:50%;transform:translate(-50%,12px)}.toast.visible{opacity:1;transform:translate(-50%)}.boot-error{text-align:center;max-width:420px;color:var(--ink-soft);margin:40px auto;font-size:15px}@media (width<=880px){.app-header{padding:8px 12px}.app-title .bolt{font-size:20px}.app-title h1{white-space:nowrap;font-size:15px}.app-title p{display:none}.persona-btn{padding:7px 12px;font-size:12px}.app-main{flex-direction:column}.scene-wrap{flex:1;min-height:46vh}.mobile-ad{background:var(--card);border-top:1px solid var(--line);padding:8px 12px;display:block}.mobile-ad .ad-placeholder{min-height:70px!important}.sidebar{border-left:none;border-top:1px solid var(--line);border-radius:18px 18px 0 0;width:100%;max-height:42vh;transition:max-height .3s cubic-bezier(.22,1,.36,1);box-shadow:0 -8px 24px #20262e1f}.sidebar:not(.open){max-height:132px}.sidebar:not(.open) .sidebar-scroll{overflow:hidden}.sidebar.open{max-height:72vh}.sheet-toggle{cursor:pointer;background:0 0;border:none;justify-content:center;align-items:center;width:100%;padding:10px 0 4px;display:flex}.sheet-grip{background:var(--line);border-radius:3px;width:44px;height:5px;display:block}.sidebar-scroll{padding:4px 16px 16px}.headline-amount{font-size:36px}.sidebar-ad{display:none}}
