:root{color-scheme:light;font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;background:#faf8f2;color:#1f2937;--background: #faf8f2;--surface: rgba(255, 255, 255, .9);--surface-solid: #ffffff;--surface-soft: rgba(250, 246, 236, .9);--primary: #b6862d;--primary-hover: #9b6f20;--primary-soft: #fbf1dc;--primary-border: #ead1a0;--on-primary: #fffaf0;--secondary: #6c5d45;--text: #1f2937;--muted: #6b7280;--border: #e5d8bf;--highlight: #f4ecdd;--danger: #b42318;--danger-soft: #fff1f0;--success: #027a48;--success-soft: #ecfdf3;--shadow: 0 1px 2px rgba(70, 52, 23, .08)}*{box-sizing:border-box}html,body,#root{min-height:100%;margin:0}body{overflow-x:hidden;background:var(--background)}button,input,textarea{font:inherit}button{cursor:pointer}button:disabled{cursor:not-allowed;opacity:.55}.screen{position:relative;min-height:100dvh;overflow:hidden;background:var(--background)}.app-screen,.detail-screen{display:grid;grid-template-rows:auto 1fr}.background{position:fixed;inset:0;z-index:0;pointer-events:none}.background img{width:100%;height:100%;object-fit:cover;opacity:.22;filter:saturate(.95) contrast(.95)}.background div{position:absolute;inset:0;background:linear-gradient(180deg,#fffcf6cc,#faf8f2e6),var(--background);-webkit-backdrop-filter:blur(1px);backdrop-filter:blur(1px)}.login-screen .background img,.install-screen .background img{opacity:.28}.login-screen .background div,.install-screen .background div{background:linear-gradient(135deg,#fffcf6c2,#faf8f2e6),var(--background)}.login-shell,.install-shell,.top-bar,.scroll-shell,.footer-nav,.album-action-nav,.date-rail{position:relative;z-index:1}.login-shell,.install-shell{display:grid;min-height:100dvh;width:min(100%,1120px);margin:0 auto;padding:32px 24px}.login-shell{place-content:center;gap:28px}.install-shell{align-content:center;gap:22px}.login-hero,.install-hero{display:grid;justify-items:center;gap:14px;text-align:center}.login-logo{width:min(46vw,280px);height:auto}.install-logo{width:min(54vw,280px);height:auto}.login-hero h1,.install-hero h1,.section h1,.info-card h1{margin:0;color:var(--text);font-size:34px;line-height:40px;font-weight:750}.login-hero p,.install-hero p,.section p,.info-card p{margin:0;color:var(--muted);font-size:16px;line-height:24px}.install-hero h1,.install-hero p{max-width:720px}.install-actions{display:flex;flex-wrap:wrap;gap:10px;width:100%}.install-actions .primary-button,.install-actions .secondary-button{min-width:min(100%,180px)}.install-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}.install-card,.form-card,.state-card,.info-card,.actions-card,.account-card,.settings-panel,.modal-card{border:1px solid var(--border);background:var(--surface);box-shadow:var(--shadow)}.install-card{display:grid;gap:12px;border-radius:8px;padding:20px}.install-card-icon{display:grid;place-items:center;width:44px;height:44px;border:1px solid var(--primary-border);border-radius:8px;color:var(--primary);background:var(--primary-soft);font-weight:800}.install-card h2,.form-card h2,.modal-card h2,.form-heading h2,.section h2,.search-section h2{margin:0;color:var(--text);font-size:22px;line-height:28px;font-weight:750}.install-card ol{display:grid;gap:8px;margin:0;padding-left:20px;color:var(--secondary);font-size:15px;line-height:22px}.install-card li::marker{color:var(--primary);font-weight:800}.form-card{display:grid;gap:14px;width:100%;padding:22px;border-radius:8px}.login-card{gap:18px;max-width:520px;margin:0 auto}.form-heading{display:grid;gap:8px}.form-heading p{margin:0;color:var(--muted);font-size:15px;line-height:22px}.user-form-card,.user-form-grid{gap:12px}.user-form-grid,.role-picker,.section,.search-section,.photo-result-list,.user-list,.inline-password-form{display:grid}.role-picker{grid-template-columns:repeat(2,minmax(0,1fr));gap:8px}.role-picker button{min-height:44px;border:1px solid var(--border);border-radius:8px;color:var(--secondary);background:var(--surface);font-size:14px;font-weight:750}.role-picker button.active{border-color:var(--primary-border);color:var(--primary);background:var(--primary-soft)}.field{display:grid;gap:8px}.field span{color:var(--text);font-size:14px;font-weight:700}input,textarea{width:100%;min-height:48px;border:1px solid var(--border);border-radius:8px;padding:0 14px;color:var(--text);outline:none;background:var(--surface);font-size:15px}textarea{min-height:112px;padding-top:14px;resize:vertical}input:focus,textarea:focus{border-color:var(--primary-border);box-shadow:0 0 0 3px #b6862d29}input::placeholder,textarea::placeholder{color:#98a2b3}.password-field{display:flex;align-items:center;min-height:48px;border:1px solid var(--border);border-radius:8px;padding-left:14px;padding-right:8px;background:var(--surface)}.password-field:focus-within{border-color:var(--primary-border);box-shadow:0 0 0 3px #b6862d29}.password-field input{min-height:0;border:0;padding:12px 0;background:transparent;box-shadow:none}.password-toggle{display:inline-flex;align-items:center;gap:6px;border:0;padding:8px;color:var(--primary);background:transparent;font-size:14px;font-weight:700}.primary-button,.secondary-button,.more-button{display:inline-flex;min-height:48px;align-items:center;justify-content:center;border:1px solid transparent;border-radius:8px;padding:0 18px;color:var(--on-primary);background:var(--primary);font-weight:750}.primary-button:hover{background:var(--primary-hover)}.secondary-button,.more-button{border-color:var(--border);color:var(--text);background:var(--surface)}.link-button,.text-button{border:0;background:transparent;color:var(--primary);font-size:14px;font-weight:700}.error-text,.success-text,.hint-text,.caption,.empty-list-text{margin:0;font-size:13px;line-height:19px}.error-text{color:var(--danger)}.success-text{color:var(--success)}.hint-text,.caption{color:var(--secondary)}.spinner{width:22px;height:22px;border:3px solid rgba(182,134,45,.18);border-top-color:var(--primary);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.top-bar{display:flex;align-items:center;justify-content:space-between;border-bottom:1px solid var(--border);padding:calc(10px + env(safe-area-inset-top)) 20px 10px;background:#fffcf6db;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.wordmark{color:var(--text);font-size:20px;font-weight:750;letter-spacing:1.8px}.top-bar-spacer,.text-button{min-width:56px}.scroll-shell{display:grid;gap:22px;align-content:start;overflow-y:auto;padding:20px 24px calc(96px + env(safe-area-inset-bottom))}.detail-screen .scroll-shell{padding-bottom:28px}.album-detail-screen .scroll-shell{padding-bottom:calc(104px + env(safe-area-inset-bottom))}.section{gap:16px}.hero-section{gap:8px}.eyebrow,.section>.eyebrow,.month-header span,.info-block span{color:var(--secondary);font-size:12px;font-weight:800;letter-spacing:.7px;text-transform:uppercase}.section h1{font-size:30px;line-height:36px}.meta-line{color:var(--secondary);font-size:14px}.filter-bar{display:flex;align-items:center;gap:10px;min-height:50px;border:1px solid var(--border);border-radius:8px;padding:0 14px;background:var(--surface);box-shadow:var(--shadow)}.filter-bar input{min-height:48px;border:0;border-radius:0;padding:0;background:transparent;box-shadow:none}.filter-chip{border:1px solid var(--primary-border);border-radius:999px;padding:7px 10px;white-space:nowrap;color:var(--primary);background:var(--primary-soft);font-size:12px;font-weight:800}.action-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}.action-card{display:grid;justify-items:start;gap:6px;min-height:104px;border:1px solid var(--border);border-radius:8px;padding:16px;text-align:left;background:var(--surface);box-shadow:var(--shadow)}.action-card.secondary{background:var(--surface-soft)}.action-card span{color:var(--primary);font-size:11px;font-weight:800;letter-spacing:.6px;text-transform:uppercase}.action-card strong{color:var(--text);font-size:18px;line-height:23px;font-weight:750}.action-card small{color:var(--muted);font-size:13px;line-height:19px}.album-grid{display:grid;grid-template-columns:1fr;gap:8px}.explorer-list{gap:6px}.album-tree-item{position:relative;display:grid;gap:4px}.album-parent-row{position:relative;display:grid;grid-template-columns:32px minmax(0,1fr);align-items:center;gap:6px}.album-children-list>.album-tree-item>.album-parent-row:before{content:"";position:absolute;left:-19px;top:50%;width:16px;height:1px;background:#b6862d61}.album-collapse-button,.album-collapse-spacer{display:grid;width:32px;height:32px;place-items:center}.album-collapse-button{border:1px solid transparent;border-radius:8px;color:var(--secondary);background:transparent;font-size:22px;line-height:1}.album-collapse-spacer{position:relative}.album-collapse-spacer:before{content:"";width:6px;height:6px;border-radius:50%;background:#b6862d6b}.album-collapse-button:hover{border-color:var(--border);background:var(--surface-soft)}.album-children-list{position:relative;display:grid;gap:4px;margin-left:16px;padding-left:22px;border-left:1px solid rgba(182,134,45,.28)}.album-tree-status{display:inline-flex;min-height:40px;align-items:center;gap:8px;padding:4px 10px;color:var(--muted);font-size:13px}.album-tree-status .spinner{width:16px;height:16px;border-width:2px}.album-tree-error{margin:0;padding:6px 10px;color:var(--danger);font-size:13px;line-height:18px}.album-card{position:relative;display:grid;grid-template-columns:56px minmax(0,1fr);min-height:76px;overflow:hidden;align-items:center;border:1px solid var(--border);border-radius:8px;padding:10px 12px 10px calc(12px + (var(--album-depth, 0) * 24px));color:var(--text);text-align:left;background:var(--surface);box-shadow:var(--shadow)}.album-child-row{display:grid;grid-template-columns:34px minmax(0,1fr);min-height:44px;align-items:center;border:1px solid transparent;border-radius:8px;padding:6px 10px;color:var(--text);text-align:left;background:transparent}.album-child-row:hover,.album-card:hover,.photo-result-card:hover,.autocomplete-list button:hover{background:var(--surface-soft)}.album-child-row span{width:26px;height:20px;border-radius:5px;background:linear-gradient(#f4dfb2 0 0) 0 6px / 100% 14px no-repeat,linear-gradient(#e6c783 0 0) 0 0 / 16px 9px no-repeat}.album-child-row strong{overflow:hidden;color:var(--text);text-overflow:ellipsis;white-space:nowrap;font-size:14px;font-weight:650}.album-card:before{content:"";display:block;width:44px;height:34px;border-radius:6px;background:linear-gradient(#f4dfb2 0 0) 0 8px / 100% 26px no-repeat,linear-gradient(#e6c783 0 0) 0 0 / 26px 14px no-repeat}.album-card-compact{min-height:72px}.album-card img{grid-column:1;grid-row:1;width:44px;height:44px;border-radius:6px;object-fit:cover}.album-card-overlay{display:none}.album-card-content{position:relative;display:grid;grid-column:2;gap:3px;min-width:0;padding:0}.album-card h3{overflow:hidden;margin:0;color:var(--text);text-overflow:ellipsis;white-space:nowrap;font-size:16px;line-height:22px;font-weight:750}.album-card strong,.album-card p{overflow:hidden;margin:0;color:var(--muted);text-overflow:ellipsis;white-space:nowrap;font-size:13px;line-height:18px;font-weight:500;letter-spacing:0;text-transform:none;text-shadow:none}.state-card{display:grid;justify-items:start;gap:12px;border-radius:8px;padding:22px}.state-card h3{margin:0;color:var(--text);font-size:22px;line-height:28px;font-weight:750}.state-card p{margin:0;color:var(--muted);font-size:15px;line-height:23px}.search-section,.photo-result-list{gap:12px}.photo-result-card{display:flex;align-items:center;gap:12px;border:1px solid var(--border);border-radius:8px;padding:10px;color:var(--text);text-align:left;background:var(--surface);box-shadow:var(--shadow)}.photo-result-card img,.photo-result-card>span{width:70px;height:70px;flex:0 0 auto;border-radius:6px;object-fit:cover;background:var(--highlight)}.photo-result-card div{display:grid;gap:4px;min-width:0}.photo-result-card strong,.photo-result-card small{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.photo-result-card strong{color:var(--text);font-size:16px}.photo-result-card small{color:var(--muted);font-size:13px}.heat-map{position:relative;height:260px;overflow:hidden;border:1px solid var(--border);border-radius:8px;background:linear-gradient(rgba(182,134,45,.08) 1px,transparent 1px),linear-gradient(90deg,rgba(182,134,45,.08) 1px,transparent 1px),#ffffffe0;background-size:36px 36px}.heat-grid{position:absolute;inset:0}.heat-point{position:absolute;border-radius:50%;transform:translate(-50%,-50%);background:radial-gradient(circle,rgba(182,134,45,.52),rgba(182,134,45,.16) 55%,transparent 72%)}.account-card,.settings-panel,.actions-card,.info-card{display:grid;gap:14px;border-radius:8px;padding:20px}.section-row{display:flex;align-items:flex-start;justify-content:space-between;gap:16px}.role-badge{justify-self:start;border:1px solid var(--primary-border);border-radius:999px;padding:6px 10px;color:var(--primary);background:var(--primary-soft);font-size:12px;font-weight:800;letter-spacing:.2px}.logout-button{min-height:40px;border:1px solid #f2b8b5;border-radius:8px;padding:0 14px;color:var(--danger);background:var(--danger-soft);font-size:14px;font-weight:750}.user-list{gap:8px}.user-list-item{display:grid;gap:10px;border:1px solid var(--border);border-radius:8px;padding:12px;background:var(--surface)}.user-row{display:grid;grid-template-columns:auto minmax(0,1fr) auto auto;align-items:center;gap:12px}.user-avatar{display:grid;place-items:center;width:40px;height:40px;border-radius:8px;color:var(--primary);background:var(--primary-soft);font-weight:800}.user-row-main{display:grid;gap:2px;min-width:0}.user-row-main strong,.user-row-main span{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.user-row-main strong{color:var(--text);font-size:15px;font-weight:750}.user-row-main span,.empty-list-text{color:var(--muted)}.mini-action-button{min-height:36px;border:1px solid var(--border);border-radius:8px;padding:0 12px;color:var(--primary);background:var(--surface);font-size:13px;font-weight:750}.inline-password-form{gap:10px;border-top:1px solid var(--border);padding-top:12px}.inline-form-actions{display:flex;flex-wrap:wrap;gap:10px;align-items:center}.inline-form-actions .secondary-button{min-height:44px}.info-block{display:grid;gap:4px;min-width:0;padding-bottom:14px;border-bottom:1px solid var(--border)}.info-block:last-child{border-bottom:0;padding-bottom:0}.info-block strong{overflow-wrap:anywhere;color:var(--text);font-size:16px;line-height:24px;font-weight:600}.footer-nav{position:sticky;bottom:0;display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:8px;border-top:1px solid var(--border);padding:8px 12px calc(12px + env(safe-area-inset-bottom));background:#fffcf6e0;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.footer-nav button{display:grid;gap:3px;min-height:54px;place-items:center;border:1px solid transparent;border-radius:8px;color:var(--muted);background:transparent;font-size:12px;font-weight:700}.footer-nav span{color:inherit;font-size:16px;font-weight:800}.footer-nav .active{border-color:var(--primary-border);color:var(--primary);background:var(--primary-soft)}.album-action-nav{position:sticky;bottom:0;display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;border-top:1px solid var(--border);padding:10px 14px calc(14px + env(safe-area-inset-bottom));background:#fffcf6e6;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.album-action-nav .primary-button,.album-action-nav .secondary-button{min-height:50px}.album-detail-screen .date-rail{bottom:calc(104px + env(safe-area-inset-bottom))}.month-section{display:grid;gap:14px;scroll-margin-top:18px}.month-section.selected{outline:2px solid rgba(182,134,45,.18);outline-offset:8px}.month-header{display:grid;gap:2px}.month-header h3{margin:0;color:var(--text);font-size:22px;line-height:28px;font-weight:750}.month-divider{height:1px;background:var(--border)}.masonry-grid{column-count:2;column-gap:12px}.photo-tile{display:inline-flex;width:100%;margin:0 0 12px;overflow:hidden;align-items:center;justify-content:center;border:0;border-radius:8px;padding:0;color:var(--muted);background:var(--highlight);break-inside:avoid}.photo-tile img{width:100%;height:100%;min-height:inherit;object-fit:cover}.date-rail{position:fixed;top:96px;right:8px;bottom:28px;width:64px;z-index:3}.date-rail-touch{position:absolute;inset:0 0 0 auto;width:52px;touch-action:none}.date-rail-pill{position:absolute;right:14px;display:grid;place-items:center;width:22px;min-height:64px;border:1px solid var(--primary-border);border-radius:999px;color:var(--primary);background:#fbf1dce6;font-size:16px;font-weight:800;line-height:16px;transform:translateY(-50%)}.date-rail-year{position:absolute;right:44px;border:1px solid var(--border);border-radius:999px;padding:4px 8px;color:var(--secondary);background:var(--surface);font-size:10px;font-weight:800;box-shadow:var(--shadow)}.photo-frame{display:flex;min-height:min(58vh,620px);overflow:hidden;align-items:center;justify-content:center;border:1px solid var(--border);border-radius:8px;padding:0;color:var(--muted);background:var(--surface);box-shadow:var(--shadow)}.photo-frame img{width:100%;height:min(58vh,620px);object-fit:contain}.share-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:8px}.share-grid button{min-height:44px;border:1px solid var(--border);border-radius:8px;color:var(--primary);background:var(--surface);font-size:14px;font-weight:700}.modal-backdrop,.fullscreen{position:fixed;inset:0;z-index:10}.modal-backdrop{display:grid;place-items:center;padding:24px;background:#0f172a52}.modal-card{display:grid;gap:12px;width:min(100%,560px);border-radius:8px;padding:22px}.modal-option{display:grid;gap:4px;border:1px solid var(--border);border-radius:8px;padding:14px;color:var(--text);text-decoration:none;background:var(--surface)}.modal-option small{color:var(--muted)}.fullscreen{display:grid;grid-template-rows:auto 1fr;background:#000}.fullscreen>button{justify-self:end;margin:18px 20px 8px;border:0;border-radius:999px;padding:10px 14px;color:#fff;background:#ffffff24;font-weight:700}.fullscreen>div{display:grid;place-items:center;padding:12px 12px 16px}.fullscreen img{max-width:100%;max-height:100%;object-fit:contain}.pick-card{position:relative;display:grid;min-height:196px;overflow:hidden;place-items:center;gap:8px;border:1px dashed #d7bd83;border-radius:8px;padding:18px;text-align:center;background:var(--surface-soft)}.pick-card input{position:absolute;inset:0;opacity:0;cursor:pointer}.pick-card img{width:100%;height:180px;border-radius:8px;object-fit:cover}.pick-card strong{color:var(--text);font-size:18px;font-weight:750}.pick-card span{color:var(--muted);font-size:14px;line-height:20px}.autocomplete-list{display:grid;overflow:hidden;border:1px solid var(--border);border-radius:8px;background:var(--surface-solid);box-shadow:var(--shadow)}.autocomplete-list button{border:0;border-bottom:1px solid var(--border);padding:13px 14px;color:var(--text);text-align:left;background:transparent;font-size:15px;font-weight:600}.autocomplete-list button:last-child{border-bottom:0}@media(min-width:760px){.login-shell{grid-template-columns:minmax(0,1fr) minmax(360px,480px);align-items:center}.login-hero{justify-items:start;text-align:left}.login-logo{width:min(30vw,320px)}.scroll-shell{width:min(100%,1120px);margin:0 auto}.album-grid:not(.explorer-list){grid-template-columns:repeat(2,minmax(0,1fr))}.masonry-grid{column-count:3}}@media(min-width:1100px){.album-grid:not(.explorer-list){grid-template-columns:repeat(3,minmax(0,1fr))}.masonry-grid{column-count:4}}@media(max-width:520px){.login-shell,.install-shell,.scroll-shell{padding-left:16px;padding-right:16px}.install-hero h1,.login-hero h1,.section h1,.info-card h1{font-size:28px;line-height:34px}.install-actions,.install-actions .primary-button,.install-actions .secondary-button{width:100%}.install-grid,.action-grid,.share-grid{grid-template-columns:1fr}.footer-nav{padding-left:8px;padding-right:8px}.footer-nav button{font-size:11px}.user-row{grid-template-columns:auto minmax(0,1fr)}.user-row .role-badge,.mini-action-button{grid-column:2;justify-self:start}}
