*{margin:0;padding:0;box-sizing:border-box;-webkit-tap-highlight-color:transparent;outline:0}:root{--bg:#0f0f11;--surface:#1a1a1f;--surface2:#22222a;--border:rgba(255,255,255,0.08);--border-hi:rgba(255,255,255,0.14);--accent:#7c6af7;--accent2:#5db4f0;--accent3:#f472b6;--accent-orange:#ff8c42;--text:#e8e6f0;--text2:#8884a0;--text3:#55536a;--radius:10px;--track:#2a2a35}body{font-family:'SF Pro Display',-apple-system,'Segoe UI',sans-serif;background:var(--bg);color:var(--text);display:flex;height:100vh;overflow:hidden;user-select:none;-webkit-user-select:none;touch-action:none}#sidebar{width:320px;min-width:320px;background:var(--surface);border-right:1px solid var(--border);display:flex;flex-direction:column;overflow:hidden}#sidebar-scroll{flex:1;overflow-y:auto;overflow-x:hidden}#sidebar-resizer{display:none;height:20px;background:var(--surface);border-top:1px solid var(--border);border-bottom:1px solid var(--border);align-items:center;justify-content:center;cursor:ns-resize;flex-shrink:0;z-index:100}#sidebar-resizer::after{content:'';width:36px;height:4px;background:var(--text3);border-radius:2px;transition:background .2s,width .2s}#sidebar-resizer:hover::after{background:var(--text2);width:42px}#sidebar-scroll::-webkit-scrollbar,.drawer-content::-webkit-scrollbar{width:4px}#sidebar-scroll::-webkit-scrollbar-thumb,.drawer-content::-webkit-scrollbar-thumb{background:var(--track);border-radius:4px}#sidebar-scroll::-webkit-scrollbar-thumb:hover,.drawer-content::-webkit-scrollbar-thumb:hover{background:var(--text3)}.sidebar-header{padding:20px 20px 16px;border-bottom:1px solid var(--border)}.header-top{display:flex;justify-content:space-between;align-items:center;margin-bottom:2px}.header-actions{display:flex;align-items:center;gap:8px}.icon-btn{background:0 0;border:none;color:var(--text2);cursor:pointer;padding:6px;border-radius:8px;display:flex;align-items:center;justify-content:center;transition:background .2s,color .2s}.icon-btn:hover{background:var(--surface2);color:var(--accent)}.drawer-backdrop{position:fixed;top:0;left:0;width:100%;height:100%;background:rgba(0,0,0,.5);backdrop-filter:blur(4px);z-index:10000;opacity:0;visibility:hidden;transition:opacity .3s,visibility .3s}.drawer-backdrop.active{opacity:1;visibility:visible}.drawer{position:fixed;top:0;right:0;width:320px;height:100%;background:rgba(26,26,31,.4);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);z-index:10001;transform:translateX(100%);transition:transform .3s cubic-bezier(.4, 0, .2, 1);box-shadow:none;display:flex;flex-direction:column;border-left:1px solid var(--border)}.drawer.active{transform:translateX(0)}.drawer-header{padding:20px;display:flex;justify-content:space-between;align-items:center;border-bottom:1px solid var(--border)}.drawer-header h2{font-size:16px;font-weight:600;color:var(--text1)}.drawer-content{flex:1;overflow-y:auto;padding:20px}.drawer-section{margin-bottom:24px}.drawer-section-title{font-size:11px;text-transform:uppercase;letter-spacing:.1em;color:var(--text1);margin-bottom:12px;font-weight:600}.lang-select-drawer{width:100%;padding:10px 12px;background:var(--surface2);border:1px solid var(--border);border-radius:10px;color:var(--text1);font-size:14px;outline:0;cursor:pointer;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' fill='none' stroke='%23888' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='3 4.5 6 7.5 9 4.5'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center}.lang-select-drawer:focus{border-color:var(--accent)}@media (max-width:480px){.drawer{width:85%}}.sidebar-header h1{font-size:15px;font-weight:600;letter-spacing:.04em;text-transform:uppercase;color:var(--text2)}.sidebar-header p{font-size:11px;color:var(--text3)}.section{padding:16px 20px;border-bottom:1px solid var(--border)}.section-title{font-size:10px;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--text3);margin-bottom:12px;display:flex;align-items:center;gap:7px}.title-pip{width:5px;height:5px;border-radius:50%;flex-shrink:0}.pip-purple{background:var(--accent)}.pip-blue{background:var(--accent2)}.pip-pink{background:var(--accent3)}.pip-green{background:#34d399}.collapsible-header{padding:16px 20px;display:flex;align-items:center;justify-content:space-between;cursor:pointer;background:0 0;transition:background .2s;border-bottom:1px solid var(--border);user-select:none}.collapsible-header:hover{background:rgba(255,255,255,.03)}.collapsible-header:hover .section-title{color:var(--text2)}.chevron{color:var(--text3);transition:transform .3s cubic-bezier(.4, 0, .2, 1)}#manual-bokeh-container.collapsed .chevron{transform:rotate(-90deg)}.collapsible-content{max-height:1000px;overflow:hidden;transition:max-height .4s cubic-bezier(.4, 0, .2, 1),opacity .3s ease;opacity:1}#manual-bokeh-container.collapsed .collapsible-content{max-height:0;opacity:0}#manual-bokeh-container .section{border-bottom:none;padding-top:10px}#manual-bokeh-container .section:last-child{padding-bottom:20px;border-bottom:1px solid var(--border)}.upload-zone{border:1.5px dashed var(--border);border-radius:var(--radius);padding:24px 12px;text-align:center;cursor:pointer;transition:all .2s;background:var(--surface2)}.upload-zone:hover{border-color:var(--accent);background:rgba(124,106,247,.06)}.upload-zone.drag-over{border-color:var(--accent2);background:rgba(93,180,240,.08)}.upload-icon{width:36px;height:36px;margin:0 auto 8px;background:rgba(124,106,247,.15);border-radius:8px;display:flex;align-items:center;justify-content:center}.upload-zone p{font-size:12px;color:var(--text2);line-height:1.5}.upload-zone span{color:var(--accent)}.control-row{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px;gap:10px}.control-label{font-size:12px;color:var(--text2);min-width:80px;flex-shrink:0}.control-value{font-size:12px;color:var(--accent);min-width:36px;text-align:right;font-variant-numeric:tabular-nums;font-weight:500}.control-value.pink{color:var(--accent3)}.control-value.green{color:#34d399}.control-value.blue{color:var(--accent2)}.control-value.orange{color:var(--accent-orange)}input[type=range]{-webkit-appearance:none;appearance:none;flex:1;height:4px;background:var(--track);border-radius:2px;outline:0;cursor:pointer}input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;width:14px;height:14px;background:var(--accent);border-radius:50%;box-shadow:0 0 0 3px rgba(124,106,247,.25);transition:box-shadow .15s}input[type=range]:hover::-webkit-slider-thumb{box-shadow:0 0 0 5px rgba(124,106,247,.3)}input[type=range].pink-range::-webkit-slider-thumb{background:var(--accent3);box-shadow:0 0 0 3px rgba(244,114,182,.25)}input[type=range].pink-range:hover::-webkit-slider-thumb{box-shadow:0 0 0 5px rgba(244,114,182,.3)}input[type=range].green-range::-webkit-slider-thumb{background:#34d399;box-shadow:0 0 0 3px rgba(52,211,153,.25)}input[type=range].purple-range::-webkit-slider-thumb{background:var(--accent);box-shadow:0 0 0 3px rgba(124,106,247,.25)}input[type=range].purple-range:hover::-webkit-slider-thumb{box-shadow:0 0 0 5px rgba(124,106,247,.3)}input[type=range].blue-range::-webkit-slider-thumb{background:var(--accent2);box-shadow:0 0 0 3px rgba(93,180,240,.25)}input[type=range].blue-range:hover::-webkit-slider-thumb{box-shadow:0 0 0 5px rgba(93,180,240,.3)}input[type=range].orange-range::-webkit-slider-thumb{background:var(--accent-orange);box-shadow:0 0 0 3px rgba(255,140,66,.25)}input[type=range].orange-range:hover::-webkit-slider-thumb{box-shadow:0 0 0 5px rgba(255,140,66,.3)}.toggle-row{display:flex;align-items:center;justify-content:space-between;padding:8px 12px;background:var(--surface2);border-radius:var(--radius);margin-bottom:8px;cursor:pointer}.toggle-label{font-size:12px;color:var(--text2)}.toggle{width:36px;height:20px;background:var(--track);border-radius:10px;position:relative;transition:background .2s;flex-shrink:0}.toggle.on{background:var(--accent)}.toggle.pink-toggle.on{background:var(--accent3)}.toggle.green-toggle.on{background:#34d399}.toggle.teal-toggle.on{background:#06b6d4}.toggle::after{content:'';position:absolute;width:14px;height:14px;background:#fff;border-radius:50%;top:3px;left:3px;transition:left .2s}.toggle.on::after{left:19px}.btn{width:100%;padding:10px;border:1px solid var(--border);border-radius:var(--radius);background:var(--surface2);color:var(--text);font-size:13px;cursor:pointer;transition:all .15s;font-family:inherit;margin-bottom:6px}.btn:hover{background:rgba(255,255,255,.06);border-color:rgba(255,255,255,.15)}.btn:disabled{opacity:.45;cursor:not-allowed}.btn.primary{background:var(--accent);border-color:transparent;color:#fff;font-weight:500}.btn.primary:hover{background:#9080ff}.btn.pink{background:var(--accent3);border-color:transparent;color:#fff;font-weight:500}.btn.pink:hover{background:#e879a8}.btn.pink:disabled{opacity:.45}.btn.green{background:#059669;border-color:transparent;color:#fff;font-weight:500}.btn.green:hover{background:#047857}.btn.danger{background:rgba(239,68,68,.15);border-color:rgba(239,68,68,.3);color:#f87171}.btn.danger:hover{background:rgba(239,68,68,.25)}.ai-card{background:rgba(244,114,182,.06);border:1px solid rgba(244,114,182,.18);border-radius:var(--radius);overflow:hidden;margin-bottom:10px}.ai-card-head{padding:9px 12px;border-bottom:1px solid rgba(244,114,182,.12);display:flex;align-items:center;gap:8px}.ai-pill{font-size:9px;font-weight:800;letter-spacing:.1em;padding:2px 7px;border-radius:4px;background:linear-gradient(135deg,var(--accent3),#c084fc);color:#fff;flex-shrink:0}.ai-card-head-title{font-size:11px;color:var(--text2);flex:1}.ai-status-dot{width:7px;height:7px;border-radius:50%;background:var(--text3);transition:background .3s;flex-shrink:0}.ai-status-dot.loading{background:#f59e0b;animation:blink 1s infinite}.ai-status-dot.ready{background:#34d399}.ai-status-dot.error{background:var(--accent3)}@keyframes blink{0%,100%{opacity:1}50%{opacity:.35}}.ai-card-body{padding:10px 12px}.ai-progress-track{height:3px;background:var(--track);border-radius:2px;overflow:hidden;margin-bottom:7px}.ai-progress-fill{height:100%;background:linear-gradient(90deg,var(--accent3),#c084fc);width:0%;transition:width .4s;border-radius:2px}.ai-status-text{font-size:10px;color:var(--text3);line-height:1.55;min-height:14px}.depth-viz{margin:4px 0 10px}.depth-grad-bar{height:18px;border-radius:5px;background:linear-gradient(to left,#118ab2,#06d6a0,#ffd166,#ff8c42,#ff3b5c);position:relative;overflow:hidden}.depth-dof-fill{position:absolute;top:0;height:100%;background:rgba(255,255,255,.22);border-radius:5px;pointer-events:none;transition:left .06s,width .06s;transform:translateX(-50%)}.depth-focus-line{position:absolute;top:-5px;width:3px;height:28px;background:#fff;border-radius:2px;transform:translateX(-50%);box-shadow:0 0 8px rgba(255,255,255,.65);pointer-events:none;transition:left .06s}.depth-viz-labels{display:flex;justify-content:space-between;margin-top:4px;font-size:9px;color:var(--text3);letter-spacing:.04em}.heatmap-wrap{border-radius:7px;overflow:hidden;border:1px solid var(--border);position:relative;margin-top:8px;cursor:default}#heatmap-mini{display:block;width:100%;height:auto}.heatmap-tag{position:absolute;top:5px;left:7px;font-size:8px;font-weight:700;letter-spacing:.09em;text-transform:uppercase;color:rgba(255,255,255,.7);background:rgba(0,0,0,.45);padding:1px 6px;border-radius:3px}.hint{font-size:11px;color:var(--text3);line-height:1.6;padding:8px 12px;background:var(--surface2);border-radius:8px;border-left:2px solid var(--accent3);margin-top:6px}.hint.green-hint{border-left-color:#34d399}.hint.teal-hint{border-left-color:#06b6d4}.subsection-divider{display:flex;align-items:center;gap:8px;margin:14px 0 12px}.subsection-divider-line{flex:1;height:1px;background:var(--border)}.subsection-divider-label{font-size:9px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--text3);display:flex;align-items:center;gap:5px;white-space:nowrap}.edit-mode-card{background:rgba(52,211,153,.05);border:1px solid rgba(52,211,153,.2);border-radius:var(--radius);padding:10px 12px;margin-bottom:10px;font-size:11px;color:#6ee7b7;line-height:1.6;transition:background .2s,border-color .2s,color .2s}.edit-mode-card.inactive{background:rgba(255,255,255,.03);border:1px solid rgba(255,255,255,.07);color:var(--text3)}#action-bar{border-top:1px solid var(--border);padding:12px 20px;background:var(--surface);flex-shrink:0;display:none}.action-bar-inner{display:flex;flex-direction:column;gap:8px}.action-export-row{display:flex;gap:8px;margin-bottom:0}.action-export-row button{flex:1}.action-export-row{display:flex;gap:8px;margin-bottom:0}.action-export-row button{flex:1}.action-compare-row{display:flex;align-items:center;justify-content:space-between;padding:7px 12px;background:var(--surface2);border-radius:var(--radius);cursor:pointer;border:1px solid var(--border);transition:background .15s}.action-compare-row:hover{background:rgba(255,255,255,.05)}.action-compare-label{font-size:12px;color:var(--text2)}.action-export-container{background:rgba(124,106,247,.2);border:1px solid rgba(124,106,247,.3);border-radius:var(--radius);overflow:hidden;transition:background .2s,border-color .2s}.action-export-header{display:flex;align-items:center;justify-content:space-between;padding:8px 12px;cursor:pointer;user-select:none}.action-export-header:hover{background:rgba(124,106,247,.12)}.action-export-content{padding:0 12px 10px;display:flex;flex-direction:column;gap:8px;max-height:500px;opacity:1;transition:max-height .4s cubic-bezier(.4, 0, .2, 1),opacity .3s ease,padding .4s}.action-export-container.collapsed .action-export-content{max-height:0;opacity:0;padding-bottom:0;pointer-events:none}.action-export-container.collapsed .chevron{transform:rotate(-90deg)}.action-format-row{display:flex;align-items:center;justify-content:space-between;padding:4px 0;margin-bottom:0}.format-segmented{position:relative;display:flex;background:rgba(0,0,0,.2);border-radius:6px;padding:2px;width:100px}.format-segmented input{display:none}.format-segmented label{flex:1;text-align:center;font-size:10px;font-weight:700;color:var(--text3);padding:4px 0;cursor:pointer;z-index:1;transition:color .2s;letter-spacing:.05em}.format-segmented input:checked+label{color:#fff}.format-slider{position:absolute;top:2px;left:2px;width:calc(50% - 2px);height:calc(100% - 4px);background:var(--primary);border-radius:4px;transition:transform .2s cubic-bezier(.4, 0, .2, 1);box-shadow:0 2px 4px rgba(0,0,0,.2)}.format-segmented input#fmt-jpg:checked~.format-slider{transform:translateX(0)}.format-segmented input#fmt-png:checked~.format-slider{transform:translateX(100%)}#main{flex:1;display:block;align-items:center;justify-content:center;position:relative;overflow:hidden;background:#0a0a0c}@media (max-width:800px){body{flex-direction:column}#sidebar{width:100%;min-width:100%;height:40vh;order:2}#sidebar-resizer{display:flex}#main{order:1}}#depth-compare-container{display:none;position:absolute;inset:0;flex-direction:row}#depth-compare-container.visible{display:flex}.compare-half{flex:1;position:relative;overflow:hidden}.compare-divider{width:.5px;background:rgba(255,255,255,.2);flex-shrink:0;position:relative;z-index:5}.compare-divider::before{content:'';position:absolute;top:0;bottom:0;left:-4px;right:-4px;background:0 0}.compare-half-inner{position:relative;transform-origin:0 0;will-change:transform}.compare-label-badge{position:absolute;top:12px;left:50%;transform:translateX(-50%);background:rgba(0,0,0,.65);backdrop-filter:blur(8px);border:1px solid var(--border-hi);border-radius:20px;padding:4px 12px;font-size:11px;font-weight:600;color:var(--text2);pointer-events:none;white-space:nowrap;z-index:10;letter-spacing:.04em}.compare-label-badge.depth-label{color:#67e8f9;border-color:rgba(6,182,212,.3)}.compare-label-badge.preview-label{color:#c4b5fd;border-color:rgba(124,106,247,.3)}#viewport{position:absolute;transform-origin:0 0;will-change:transform;left:0;top:0}#canvas-container{position:relative}canvas{display:block}#overlay-canvas{position:absolute;top:0;left:0;width:100%;height:100%;pointer-events:none;z-index:18}#brush-canvas{position:absolute;top:0;left:0;width:100%;height:100%;pointer-events:none;z-index:19;display:none}#compare-brush-canvas{position:absolute;top:0;left:0;width:100%;height:100%;pointer-events:none;z-index:20;display:none}#compare-brush-canvas.visible{display:block}#placeholder{position:absolute;top:0;left:0;width:100%;height:100%;overflow:hidden;z-index:10}.placeholder-content{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);display:flex;flex-direction:column;align-items:center;gap:12px;color:var(--text3);z-index:3;pointer-events:none}.privacy-details{pointer-events:auto;margin-bottom:4px;max-width:320px;font-size:11px;color:rgba(255,255,255,.5);cursor:pointer;transition:opacity .2s}.privacy-details:hover{opacity:.8}.privacy-details summary{outline:0;list-style:none;text-decoration:underline;text-align:center;margin-bottom:6px;font-size:11px;opacity:.7}.privacy-details summary::-webkit-details-marker{display:none}.privacy-content{background:rgba(0,0,0,.4);padding:12px;border-radius:12px;text-align:left;line-height:1.5;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.1);box-shadow:0 10px 30px rgba(0,0,0,.3);margin-bottom:12px;overflow:hidden;max-height:0;opacity:0;transform:translateY(-10px);transition:max-height .4s cubic-bezier(.4, 0, .2, 1),opacity .4s cubic-bezier(.4, 0, .2, 1),transform .4s cubic-bezier(.4, 0, .2, 1)}.privacy-details.is-open .privacy-content{max-height:500px;opacity:1;transform:translateY(0)}.privacy-content p{margin:0 0 8px 0!important;opacity:.9!important;font-size:11px!important;color:#fff!important}.privacy-content p:last-child{margin-bottom:0!important}.placeholder-icon{width:72px;height:72px;border:2px dashed var(--text3);border-radius:16px;display:flex;align-items:center;justify-content:center;opacity:.4}#placeholder p{font-size:13px;opacity:.5}.floating-badge{position:absolute;border-radius:6px;padding:4px 10px;font-size:11px;font-weight:600;letter-spacing:.05em;pointer-events:none;color:#fff;display:none}#preview-badge{top:12px;right:12px;background:rgba(124,106,247,.85)}#compare-badge{top:40px;right:12px;background:rgba(93,180,240,.85)}#depthmode-badge{top:12px;left:12px;background:rgba(244,114,182,.88)}#edit-badge{top:40px;left:12px;background:rgba(245,158,11,.88)}.status-bar{position:absolute;bottom:12px;left:50%;transform:translateX(-50%);background:rgba(0,0,0,.72);backdrop-filter:blur(8px);border:1px solid var(--border);border-radius:20px;padding:5px 14px;font-size:11px;color:var(--text2);white-space:nowrap;pointer-events:none;opacity:0;visibility:hidden;transition:opacity .3s,visibility .3s;z-index:1000000}.status-bar.visible{opacity:1;visibility:visible}#main.panning{cursor:grabbing!important}#main.pan-ready{cursor:grab!important}#main.zoom-ready{cursor:zoom-in!important}#brush-canvas.edit-active{cursor:crosshair!important}#brush-canvas.resize-mode{cursor:ns-resize!important}#brush-canvas.alt-pick{cursor:crosshair!important}#depth-compare-container.edit-active{cursor:crosshair}#depth-compare-container.resize-mode{cursor:ns-resize}#depth-compare-container.alt-pick{cursor:crosshair}#zoom-indicator{position:absolute;bottom:12px;right:12px;background:rgba(0,0,0,.65);backdrop-filter:blur(8px);border:1px solid var(--border);border-radius:16px;padding:4px 11px;font-size:11px;color:var(--text2);pointer-events:none;display:none;font-variant-numeric:tabular-nums;z-index:20}#brush-toolbar{position:absolute;bottom:48px;left:50%;transform:translateX(-50%);background:rgba(15,15,17,.88);backdrop-filter:blur(12px);border:1px solid var(--border-hi);border-radius:14px;padding:8px 12px;display:none;align-items:center;gap:10px;pointer-events:auto;touch-action:auto;z-index:25;box-shadow:0 8px 32px rgba(0,0,0,.5);min-width:480px}#brush-toolbar.visible{display:flex}@media (max-width:800px){#brush-toolbar{bottom:auto;top:5%;min-width:0;width:calc(100% - 20px);max-width:500px;flex-wrap:wrap;justify-content:center;gap:8px;padding:10px}.tb-sep{display:none}.tb-slider-wrap{min-width:100px;flex:1 1 auto}}.tb-sep{width:1px;height:24px;background:var(--border);flex-shrink:0}.tb-dir-btn{padding:5px 10px;border-radius:7px;border:1.5px solid var(--border);background:0 0;color:var(--text2);font-size:11px;font-weight:600;cursor:pointer;transition:all .15s;font-family:inherit;white-space:nowrap;display:flex;align-items:center;gap:6px}.tb-dir-btn.active-depth{border-color:#f59e0b;background:rgba(245,158,11,.15);color:#fbbf24}.tb-dir-btn.active-extended{border-color:#a78bfa;background:rgba(167,139,250,.12);color:#c4b5fd}.tb-depth-swatch{width:12px;height:12px;border-radius:3px;flex-shrink:0;border:1px solid rgba(255,255,255,.2);transition:background .15s}.tb-slider-wrap{display:flex;align-items:center;gap:6px;flex:1}.tb-slider-label{font-size:10px;color:var(--text3);white-space:nowrap;min-width:28px}.tb-slider-val{font-size:10px;color:var(--text2);min-width:26px;text-align:right;font-variant-numeric:tabular-nums}.tb-slider{-webkit-appearance:none;appearance:none;flex:1;height:3px;background:var(--track);border-radius:2px;outline:0;cursor:pointer;min-width:48px}.tb-slider::-webkit-slider-thumb{-webkit-appearance:none;width:12px;height:12px;background:#34d399;border-radius:50%;box-shadow:0 0 0 2px rgba(52,211,153,.3)}@keyframes pulse{0%,100%{opacity:1}50%{opacity:.5}}.processing{animation:pulse 1s infinite}.range-with-bubble{position:relative;flex:1;display:flex;align-items:center}.range-bubble{position:absolute;bottom:calc(100% + 10px);left:0;transform:translateX(-50%);background:rgba(244,114,182,.95);color:#fff;padding:8px 12px;border-radius:8px;font-size:11px;width:max-content;max-width:200px;white-space:normal;pointer-events:none;opacity:0;visibility:hidden;transition:opacity .2s,visibility .2s;z-index:100;box-shadow:0 4px 15px rgba(0,0,0,.4);line-height:1.5;border:1px solid rgba(255,255,255,.2);text-align:center}.range-bubble::after{content:'';position:absolute;top:100%;left:50%;transform:translateX(-50%);border-width:6px;border-style:solid;border-color:rgba(244,114,182,.95) transparent transparent transparent}.range-with-bubble input:active~.range-bubble,.range-with-bubble:hover .range-bubble{opacity:1;visibility:visible}.tooltip-container{position:relative;display:flex;align-items:center;justify-content:center}.tooltip-icon{width:18px;height:18px;background:var(--surface2);border:1px solid var(--border-hi);border-radius:50%;color:var(--text3);font-size:11px;font-weight:700;display:flex;align-items:center;justify-content:center;cursor:help;transition:all .2s}.tooltip-container:hover .tooltip-icon{background:var(--accent3);color:#fff;border-color:transparent}.tooltip-content{position:absolute;bottom:calc(100% + 10px);right:0;width:220px;background:rgba(20,20,25,.95);backdrop-filter:blur(10px);border:1px solid var(--border-hi);border-radius:8px;padding:10px 12px;color:var(--text2);font-size:11px;line-height:1.5;box-shadow:0 8px 24px rgba(0,0,0,.4);pointer-events:none;opacity:0;transform:translateY(10px);transition:all .25s cubic-bezier(.4, 0, .2, 1);z-index:1000}.video-container{position:relative;width:100%;height:100vh;overflow:hidden}.background-video{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);min-width:100%;min-height:100%;object-fit:cover;z-index:-2}.video-container::after{content:'';position:absolute;top:0;left:0;width:100%;height:100%;background:rgba(0,0,0,.7);z-index:-1}.ad-banner{display:none}@media (min-width:1025px){.ad-banner{display:flex;justify-content:center;align-items:center;position:fixed;opacity:0;bottom:0;left:calc(320px + (100vw - 320px)/ 2);transform:translateX(-50%);width:728px;height:90px;background:#1a1a1f;border:1px solid var(--border);z-index:20;overflow:hidden}.ad-placeholder{color:var(--text2);font-family:sans-serif;font-size:14px;font-weight:500;animation:ad-pulse 2s infinite}}@keyframes ad-pulse{0%{opacity:.6;transform:scale(1)}50%{opacity:1;transform:scale(1.05);color:var(--accent3)}100%{opacity:.6;transform:scale(1)}}#ad-sandbox-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background:rgba(0,0,0,.85);backdrop-filter:blur(8px);z-index:100000;display:flex;flex-direction:column;justify-content:center;align-items:center;color:#fff;text-align:center;padding:20px}.ad-sandbox-content{background:var(--surface);border:1px solid var(--border-hi);border-radius:24px;padding:40px;max-width:400px;width:90%;box-shadow:0 20px 50px rgba(0,0,0,.5)}.ad-sandbox-title{font-size:18px;font-weight:600;margin-bottom:16px;color:var(--accent3)}.ad-sandbox-timer{font-size:32px;font-weight:800;margin-bottom:24px;font-variant-numeric:tabular-nums}.ad-sandbox-close{position:absolute;top:20px;right:20px;width:44px;height:44px;background:rgba(255,255,255,.1);border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:20px;font-weight:700;border:1px solid rgba(255,255,255,.2);transition:all .2s;opacity:0;visibility:hidden;pointer-events:none}.ad-sandbox-close.visible{opacity:1;visibility:visible;pointer-events:auto}.ad-sandbox-close:hover{background:rgba(255,255,255,.2);transform:scale(1.1)}.cookie-consent-overlay{position:fixed;bottom:24px;right:24px;width:360px;max-width:calc(100vw - 48px);background:rgba(20,20,25,.45);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border:1px solid rgba(255,255,255,.16);border-radius:20px;padding:20px;box-shadow:0 12px 40px rgba(0,0,0,.5);z-index:99999;display:flex;flex-direction:column;gap:14px;transform:translateY(40px);opacity:0;visibility:hidden;transition:transform .45s cubic-bezier(.16, 1, .3, 1),opacity .45s ease,visibility .45s}.cookie-consent-overlay.show{transform:translateY(0);opacity:1;visibility:visible}.cookie-consent-header{display:flex;align-items:center;gap:10px}.cookie-consent-icon{width:32px;height:32px;background:linear-gradient(135deg,var(--accent),var(--accent2));border-radius:8px;display:flex;align-items:center;justify-content:center;color:#fff;flex-shrink:0;box-shadow:0 4px 12px rgba(124,106,247,.25)}.cookie-consent-title{font-size:14px;font-weight:600;letter-spacing:.5px;color:var(--text);margin:0}.cookie-consent-text{font-size:12px;line-height:1.55;color:var(--text2);margin:0}.cookie-consent-actions{display:flex;gap:10px;margin-top:4px}.cookie-consent-btn{flex:1;padding:10px 12px;border-radius:10px;font-size:12px;font-weight:600;cursor:pointer;transition:all .2s cubic-bezier(.4, 0, .2, 1);text-align:center;user-select:none}.cookie-consent-btn.decline{background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.1);color:var(--text2)}.cookie-consent-btn.decline:hover{background:rgba(255,255,255,.1);border-color:rgba(255,255,255,.2);color:var(--text)}.cookie-consent-btn.accept{background:linear-gradient(135deg,var(--accent),#9080ff);border:none;color:#fff;box-shadow:0 4px 12px rgba(124,106,247,.3)}.cookie-consent-btn.accept:hover{transform:translateY(-1px);box-shadow:0 6px 16px rgba(124,106,247,.45)}.cookie-consent-btn.accept:active{transform:translateY(0)}@media (max-width:480px){.cookie-consent-overlay{bottom:16px;left:16px;right:16px;width:auto;max-width:none;padding:16px}}.oss-list-drawer{display:flex;flex-direction:column;gap:10px}.oss-item{background:var(--surface2);border:1px solid var(--border);border-radius:var(--radius);padding:12px;display:flex;flex-direction:column;gap:4px;transition:all .25s cubic-bezier(.4, 0, .2, 1)}.oss-item:hover{border-color:var(--accent);background:rgba(124,106,247,.05);transform:translateY(-1px);box-shadow:0 4px 12px rgba(0,0,0,.15)}.oss-name{font-size:13px;font-weight:600;color:var(--text);letter-spacing:.3px}.oss-desc{font-size:11px;color:var(--text2);line-height:1.5}.about-me-drawer{background:rgba(255,255,255,.05);padding:16px;border-radius:12px;border:1px solid rgba(255,255,255,.1)}.about-me-text{font-size:13px;color:var(--text2);line-height:1.6}.contact-email-link{display:inline-flex;align-items:center;gap:8px;color:var(--accent);text-decoration:none;font-size:14px;font-weight:500;transition:opacity .2s}.contact-email-link:hover{opacity:.8}