:root{--bg: #f2f2f7;--bg-elevated: rgba(255, 255, 255, .9);--bg-elevated-strong: rgba(255, 255, 255, 1);--border: rgba(0, 0, 0, .06);--border-strong: rgba(0, 0, 0, .12);--accent: #007aff;--accent-soft: rgba(0, 122, 255, .1);--text: #111827;--text-soft: #6b7280;--danger: #ff3b30;--shadow-soft: 0 18px 40px rgba(15, 23, 42, .18);--radius-xl: 26px;--radius-lg: 20px;--radius-md: 14px;--radius-pill: 999px;--blur-backdrop: 24px}*{box-sizing:border-box}body{margin:0;font-family:-apple-system,system-ui,BlinkMacSystemFont,SF Pro Text,Segoe UI,sans-serif;background:radial-gradient(circle at 0 0,#fff 0,#e5e7eb 40%,#e2e8f0,#cbd5f5);color:var(--text);-webkit-font-smoothing:antialiased;font-size:16px}#app{min-height:100vh;display:flex;flex-direction:column}header{padding:.7rem 1rem .4rem;display:flex;align-items:center;justify-content:space-between;gap:.75rem;position:sticky;top:0;z-index:10;backdrop-filter:blur(18px);-webkit-backdrop-filter:blur(18px);background:linear-gradient(to bottom,#f2f2f7f5,#f2f2f7e6,#f2f2f7b3);border-bottom:1px solid rgba(148,163,184,.18)}.app-title-block{display:flex;align-items:center;gap:.5rem;min-width:0}.app-icon{width:30px;height:30px;border-radius:11px;background:radial-gradient(circle at 20% 0,#fff,#bae6ff 45%,#60a5fa);box-shadow:0 6px 16px #0f172a40,inset 0 0 0 1px #ffffffe6;display:flex;align-items:center;justify-content:center;font-size:17px}header h1{margin:0;font-size:1.1rem;font-weight:600;color:#111827;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.status-bar{display:flex;gap:.45rem;font-size:.72rem;flex-wrap:wrap;align-items:center;justify-content:flex-end;color:var(--text-soft)}.status-chip{padding:.16rem .6rem;border-radius:var(--radius-pill);border:1px solid rgba(148,163,184,.35);background:#ffffffdb;backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);display:inline-flex;align-items:center;gap:.28rem;white-space:nowrap}.badge-dot{width:.5rem;height:.5rem;border-radius:999px;background:#34c759}.badge-dot.offline{background:#ff9500}main{flex:1;padding:.8rem .9rem .9rem;display:flex;flex-direction:column;gap:.9rem;max-width:1100px;width:100%;margin:0 auto}.layout{display:grid;grid-template-columns:minmax(0,3fr);gap:.8rem}@media(min-width:900px){.layout{grid-template-columns:minmax(0,7fr) minmax(280px,4fr);align-items:flex-start}}.panel{border-radius:var(--radius-xl);border:1px solid var(--border);background:var(--bg-elevated);backdrop-filter:blur(var(--blur-backdrop));-webkit-backdrop-filter:blur(var(--blur-backdrop));box-shadow:var(--shadow-soft);padding:.85rem .95rem .9rem}.panel-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:.4rem;gap:.4rem}.panel-title{font-size:.9rem;font-weight:500;color:var(--text)}.panel-section-title{font-size:.8rem;font-weight:500;color:var(--text);margin-bottom:.25rem}.camera-shell{position:relative;border-radius:var(--radius-lg);overflow:hidden;background:#000;border:1px solid rgba(15,23,42,.18);aspect-ratio:3 / 4;max-height:min(78vh,640px);margin:.3rem auto .7rem;box-shadow:0 10px 26px #0f172a5c,0 0 0 1px #94a3b84d}.camera-shell video{width:100%;height:100%;object-fit:cover;background:#000}.camera-overlay-gradient{position:absolute;inset:0;background:linear-gradient(to top,rgba(15,23,42,.68),transparent 40%),radial-gradient(circle at 10% 0%,rgba(15,23,42,.4),transparent 50%);pointer-events:none;mix-blend-mode:soft-light}.camera-overlay-ui{position:absolute;inset:0;display:flex;flex-direction:column;justify-content:space-between;padding:.55rem .55rem .7rem;pointer-events:none}.camera-overlay-top,.camera-overlay-bottom{display:flex;justify-content:space-between;align-items:center;gap:.5rem}.camera-chip{pointer-events:auto;font-size:.75rem;padding:.24rem .7rem;border-radius:var(--radius-pill);border:1px solid rgba(15,23,42,.4);background:#0f172abf;color:#e5e7eb;display:inline-flex;align-items:center;gap:.3rem;backdrop-filter:blur(18px);-webkit-backdrop-filter:blur(18px)}.camera-chip-dot{width:.45rem;height:.45rem;border-radius:999px;background:#34c759}.camera-chip-label{max-width:160px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.camera-actions-right{display:flex;gap:.45rem;align-items:center}.icon-btn{pointer-events:auto;width:2.3rem;height:2.3rem;border-radius:var(--radius-pill);border:1px solid rgba(148,163,184,.6);background:#0f172ae6;color:#e5e7eb;display:inline-flex;align-items:center;justify-content:center;font-size:1.05rem;cursor:pointer;backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);transition:transform .08s ease,background .12s ease,border-color .12s ease,box-shadow .12s ease;box-shadow:0 8px 18px #0f172a73,0 0 0 1px #0f172ae6}.icon-btn:hover{background:#0f172af5;border-color:#d1d5dbe6;box-shadow:0 10px 20px #0f172aa6,0 0 0 1px #0f172a}.icon-btn:active{transform:translateY(1px) scale(.97);box-shadow:0 6px 14px #0f172acc,0 0 0 1px #0f172a}.capture-button-shell{pointer-events:auto;display:inline-flex;align-items:center;justify-content:center;width:3.7rem;height:3.7rem;border-radius:999px;border:4px solid rgba(243,244,246,.95);background:radial-gradient(circle at 30% 0,#fff,#e5e7eb);box-shadow:0 10px 24px #0f172a8c,0 0 0 1px #94a3b8e6;cursor:pointer;transition:transform .08s ease,box-shadow .08s ease}.capture-button-shell:active{transform:translateY(1px) scale(.97);box-shadow:0 6px 16px #0f172ab3,0 0 0 1px #94a3b8}.capture-button-inner{width:2.5rem;height:2.5rem;border-radius:999px;background:radial-gradient(circle at 30% 0,#ffdfdf,#ff3b30);box-shadow:0 0 0 1px #94a3b8b3,0 0 16px #f87171e6}.camera-footer-row{display:flex;align-items:center;justify-content:space-between;gap:.5rem;font-size:.75rem;color:var(--text-soft);margin-top:-.2rem}.camera-footer-row span{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.error-box{border-radius:var(--radius-md);border:1px solid rgba(255,59,48,.3);background:#fff4f4f5;color:#7f1d1d;font-size:.78rem;padding:.45rem .6rem;margin-top:.45rem;display:flex;align-items:flex-start;gap:.35rem}.error-dot{margin-top:.1rem;width:.45rem;height:.45rem;border-radius:999px;background:#ff3b30}.side-panel{display:flex;flex-direction:column;gap:.7rem}.stack-section+.stack-section{border-top:1px solid rgba(148,163,184,.22);padding-top:.6rem;margin-top:.1rem}.field{display:flex;flex-direction:column;gap:.2rem;margin-bottom:.45rem}.field label{font-size:.8rem;color:var(--text-soft)}select,button,input{font-family:inherit}select,.btn{border-radius:14px;border:1px solid var(--border-strong);background:var(--bg-elevated-strong);color:var(--text);padding:.45rem .6rem;font-size:.85rem;outline:none;width:100%}select:focus,.btn:focus-visible{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}.btn{cursor:pointer;text-align:center;display:inline-flex;justify-content:center;align-items:center;gap:.35rem;border-radius:999px;padding-inline:.8rem;border-color:transparent;background:linear-gradient(135deg,#0a84ff,#409cff);color:#fff;font-weight:500}.btn-sm{font-size:.8rem;padding-block:.32rem;padding-inline:.8rem}.btn-ghost{background:#ffffffe6;border-color:#94a3b8a6;color:var(--text-soft)}.btn-ghost:hover{background:#fff;color:var(--text)}.hint{font-size:.78rem;color:var(--text-soft)}.gallery{margin-top:.2rem}.gallery-header-row{display:flex;justify-content:space-between;align-items:center;gap:.5rem;margin-bottom:.35rem}.gallery-summary{font-size:.78rem;color:var(--text-soft);margin-bottom:.3rem}.months-row{display:flex;gap:.35rem;align-items:center;margin-bottom:.1rem}.months-input{max-width:5rem;border-radius:14px;border:1px solid var(--border-strong);background:var(--bg-elevated-strong);color:var(--text);padding:.35rem .5rem;font-size:.8rem;outline:none}.months-input:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}.cleanup-result{font-size:.75rem;color:var(--text-soft);min-height:1em}.gallery-body{display:flex;gap:.45rem;margin-top:.35rem}.session-list{width:155px;max-width:40%;border-radius:var(--radius-lg);border:1px solid rgba(148,163,184,.28);background:#fffffffa;padding:.4rem;max-height:40vh;overflow:auto;font-size:.78rem}.session-empty{font-size:.78rem;color:var(--text-soft);padding:.3rem .2rem}.session-item{padding:.26rem .4rem;border-radius:13px;margin-bottom:.24rem;cursor:pointer;border:1px solid transparent;background:#f8fafcf2;display:flex;flex-direction:column;gap:.08rem;transition:background .12s ease,border-color .12s ease,transform .08s ease}.session-item:hover{background:#fff;border-color:#94a3b899;transform:translateY(-.5px)}.session-item.active{background:#007aff1a;border-color:#007affe6;box-shadow:0 0 0 1px #007aff80}.session-title{font-weight:500;color:var(--text)}.session-meta{font-size:.72rem;color:var(--text-soft)}.gallery-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(110px,1fr));gap:.35rem;max-height:40vh;overflow:auto;padding-right:.15rem;flex:1}.photo-card{background:#fffffffa;border-radius:16px;border:1px solid rgba(148,163,184,.35);padding:.22rem;display:flex;flex-direction:column;gap:.2rem;font-size:.75rem;box-shadow:0 2px 6px #94a3b840}.photo-card img{width:100%;border-radius:12px;object-fit:cover;aspect-ratio:3 / 4;background:#020617}.photo-meta{color:var(--text-soft)}.delete-button{border-radius:999px;border:1px solid rgba(255,59,48,.4);background:#ffefeffa;color:#b91c1c;padding:.18rem .5rem;font-size:.7rem;cursor:pointer;align-self:flex-start}.delete-button:hover{background:#ffe4e6}footer{font-size:.7rem;color:var(--text-soft);padding:.5rem 1rem .7rem;border-top:1px solid rgba(148,163,184,.24);background:#f2f2f7f5;display:flex;justify-content:space-between;gap:.5rem;flex-wrap:wrap}footer code{font-size:.7rem;padding:.04rem .28rem;border-radius:6px;background:#0f172a0f}.modal-overlay{position:fixed;inset:0;background:#0006;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);z-index:100;display:flex;align-items:flex-end;justify-content:center;opacity:0;visibility:hidden;transition:opacity .2s ease,visibility .2s ease}.modal-overlay.visible{opacity:1;visibility:visible}@media(min-width:600px){.modal-overlay{align-items:center}}.modal-dialog{background:var(--bg-elevated-strong);border-radius:var(--radius-xl) var(--radius-xl) 0 0;border:1px solid var(--border);border-bottom:none;width:100%;max-width:480px;max-height:85vh;overflow:hidden;display:flex;flex-direction:column;box-shadow:var(--shadow-soft);transform:translateY(100%);transition:transform .25s ease}.modal-overlay.visible .modal-dialog{transform:translateY(0)}@media(min-width:600px){.modal-dialog{border-radius:var(--radius-xl);border-bottom:1px solid var(--border);max-height:80vh;transform:translateY(20px) scale(.95)}.modal-overlay.visible .modal-dialog{transform:translateY(0) scale(1)}}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:.8rem 1rem;border-bottom:1px solid var(--border);flex-shrink:0}.modal-title{font-size:1rem;font-weight:600;color:var(--text)}.modal-close{width:2rem;height:2rem;border-radius:var(--radius-pill);border:1px solid var(--border-strong);background:var(--bg-elevated);color:var(--text-soft);display:flex;align-items:center;justify-content:center;font-size:1.1rem;cursor:pointer;transition:background .12s ease,color .12s ease}.modal-close:hover{background:var(--bg);color:var(--text)}.modal-body{flex:1;overflow-y:auto;padding:.8rem 1rem}.modal-footer{display:flex;gap:.5rem;padding:.8rem 1rem;border-top:1px solid var(--border);flex-shrink:0}.modal-footer .btn{flex:1}.settings-section{margin-bottom:1rem}.settings-section:last-child{margin-bottom:0}.settings-section-title{font-size:.75rem;font-weight:600;color:var(--text-soft);text-transform:uppercase;letter-spacing:.03em;margin-bottom:.5rem}.settings-row{display:flex;align-items:center;justify-content:space-between;gap:.75rem;padding:.5rem 0;border-bottom:1px solid rgba(148,163,184,.15)}.settings-row:last-child{border-bottom:none}.settings-label{flex:1;min-width:0}.settings-label-text{font-size:.85rem;color:var(--text)}.settings-label-hint{font-size:.72rem;color:var(--text-soft);margin-top:.1rem}.settings-control{flex-shrink:0;display:flex;align-items:center;gap:.4rem}.settings-input{width:5rem;border-radius:10px;border:1px solid var(--border-strong);background:var(--bg-elevated-strong);color:var(--text);padding:.35rem .5rem;font-size:.8rem;outline:none;text-align:right}.settings-input:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}.settings-select{min-width:7rem;border-radius:10px;border:1px solid var(--border-strong);background:var(--bg-elevated-strong);color:var(--text);padding:.35rem .5rem;font-size:.8rem;outline:none}.settings-select:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}.settings-unit{font-size:.75rem;color:var(--text-soft);min-width:2.5rem}.toggle{position:relative;width:3rem;height:1.75rem;border-radius:var(--radius-pill);background:#94a3b866;border:1px solid rgba(148,163,184,.3);cursor:pointer;transition:background .2s ease,border-color .2s ease}.toggle.active{background:var(--accent);border-color:var(--accent)}.toggle-knob{position:absolute;top:2px;left:2px;width:1.35rem;height:1.35rem;border-radius:var(--radius-pill);background:#fff;box-shadow:0 2px 4px #0003;transition:transform .2s ease}.toggle.active .toggle-knob{transform:translate(1.25rem)}.settings-btn-header{width:2rem;height:2rem;border-radius:var(--radius-pill);border:1px solid rgba(148,163,184,.35);background:#ffffffdb;backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);display:inline-flex;align-items:center;justify-content:center;font-size:1rem;cursor:pointer;transition:background .12s ease,border-color .12s ease}.settings-btn-header:hover{background:#fff;border-color:#94a3b899}@media(max-width:720px){header{align-items:flex-start;padding-bottom:.45rem}.status-bar{justify-content:flex-start}.gallery-body{flex-direction:column}.session-list{max-width:100%;width:100%;max-height:120px;border-radius:16px}.camera-footer-row{flex-direction:column;align-items:flex-start}}
