*,:before,:after{box-sizing:border-box}body{color:#333;-webkit-font-smoothing:antialiased;background:#f8f9fa;margin:0;font-family:Arial,Hiragino Sans,ヒラギノ角ゴ ProN,游ゴシック,YuGothic,メイリオ,Meiryo,sans-serif;font-size:16px;line-height:1.6}#root{flex-direction:column;min-height:100svh;display:flex}.app-header{color:#333;z-index:100;background:#fff;border-bottom:2px solid #30d36c;padding:0 16px;position:sticky;top:0}.header-content{flex-wrap:wrap;align-items:center;gap:16px;max-width:1200px;margin:0 auto;padding:8px 0;display:flex}.app-logo{flex-shrink:0;align-items:center;display:flex}.app-logo img{width:auto;height:32px}.nav-links{gap:4px;display:flex}.nav-links a{color:#555;border-radius:9999px;padding:6px 12px;font-size:14px;text-decoration:none;transition:background .2s,color .2s}.nav-links a:hover{color:#2c934e;background:#e6f7ed}.nav-links a.active{color:#fff;background:#2c934e;font-weight:600}.user-info{align-items:center;gap:8px;margin-left:auto;font-size:13px;display:flex}.user-avatar{border-radius:50%;width:28px;height:28px}.user-name{white-space:nowrap}.btn-guide{color:#2c934e;background:#e6f7ed;border-color:#c3e8d0}.btn-guide:hover{color:#2c934e;background:#d0f0dc}.guide-bar{color:#2c934e;background:#e6f7ed;padding:12px 16px;font-size:13px;line-height:1.7;position:relative}.guide-steps{flex-direction:column;gap:4px;max-width:1200px;margin:0 auto;padding-left:20px;display:flex}.guide-steps li::marker{color:#2c934e;font-weight:700}.guide-close{position:absolute;top:8px;right:12px}.main-content{flex:1;width:100%;max-width:1200px;margin:0 auto;padding:20px 16px}.loading{color:#666;justify-content:center;align-items:center;height:100svh;font-size:18px;display:flex}.btn{cursor:pointer;white-space:nowrap;border:1px solid #0000;border-radius:9999px;justify-content:center;align-items:center;gap:6px;padding:8px 16px;font-size:14px;font-weight:500;transition:all .2s;display:inline-flex}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{color:#fff;background:#2c934e;border-color:#2c934e}.btn-primary:hover:not(:disabled){background:#3e9308}.btn-outline{color:#2c934e;background:0 0;border-color:#ccc}.btn-outline:hover:not(:disabled){background:#f0f0f0}.btn-danger{color:#fff;background:#dc3545;border-color:#dc3545}.btn-danger:hover:not(:disabled){background:#c82333}.btn-large{padding:12px 32px;font-size:16px}.btn-sm{padding:4px 10px;font-size:13px}.btn-xs{padding:2px 8px;font-size:12px}.login-page{justify-content:center;align-items:center;min-height:100svh;padding:20px;display:flex}.login-card{text-align:center;background:#fff;border-radius:12px;width:100%;max-width:480px;padding:40px;box-shadow:0 4px 24px #00000014}.login-logo{width:auto;height:48px;margin-bottom:16px}.login-card h1{color:#2c934e;margin:0 0 12px;font-size:22px}.login-card p{color:#666;margin:0 0 8px;font-size:14px}.login-note{margin-bottom:24px!important}.browse-layout{grid-template-columns:1fr;gap:16px;display:grid;position:relative}.browse-layout.with-suggest{grid-template-columns:1fr 260px}.hamburger-btn{top:var(--header-bottom,58px);z-index:150;cursor:pointer;background:#fff;border:1px solid #e0e0e0;border-radius:8px;justify-content:center;align-items:center;width:36px;height:36px;padding:0;display:flex;position:fixed;left:16px;box-shadow:0 1px 4px #00000014}.hamburger-btn:hover{background:#e6f7ed;border-color:#2c934e}.hamburger-icon{flex-direction:column;justify-content:space-between;width:18px;height:14px;display:flex;position:relative}.hamburger-icon span{background:#555;border-radius:1px;width:100%;height:2px;transition:all .2s;display:block}.hamburger-icon.open span:first-child{transform:translateY(6px)rotate(45deg)}.hamburger-icon.open span:nth-child(2){opacity:0}.hamburger-icon.open span:nth-child(3){transform:translateY(-6px)rotate(-45deg)}.browse-sidebar{top:var(--header-bottom,52px);width:300px;height:calc(100svh - var(--header-bottom,52px));z-index:140;background:#fff;border-right:1px solid #e0e0e0;padding:12px;transition:transform .25s;position:fixed;left:0;overflow-y:auto;transform:translate(-100%);box-shadow:4px 0 16px #00000014}.browse-sidebar.open{transform:translate(0)}.browse-sidebar-overlay{inset:0;top:var(--header-bottom,52px);z-index:130;background:#0003;position:fixed}.sidebar-header{border-bottom:1px solid #e0e0e0;justify-content:space-between;align-items:center;margin-bottom:8px;padding-top:32px;padding-bottom:8px;display:flex}.sidebar-header h3{color:#2c934e;margin:0;font-size:14px}.folder-tree{font-size:14px}.tree-node-row{cursor:default;border-radius:6px;align-items:center;gap:6px;min-height:32px;padding:6px;display:flex}.tree-node-row:hover{background:#f0f4f8}.tree-node-row.tree-selected{background:#e6f7ed}.tree-toggle{cursor:pointer;color:#666;background:0 0;border:none;flex-shrink:0;width:16px;padding:0;font-size:10px}.tree-toggle-spacer{flex-shrink:0;width:16px}.tree-label{cursor:pointer;flex:1;align-items:center;gap:4px;min-width:0;display:flex}.tree-label input[type=checkbox]{flex-shrink:0;width:16px;height:16px;margin:0}.tree-name{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.tree-exclude-btn{cursor:pointer;color:#999;background:#f5f5f5;border:1px solid #ddd;border-radius:4px;flex-shrink:0;justify-content:center;align-items:center;width:22px;height:22px;padding:0;font-size:14px;font-weight:700;transition:all .15s;display:flex}.tree-exclude-btn:hover{color:#dc3545;background:#fff5f5;border-color:#dc3545}.tree-exclude-btn.active{color:#fff;background:#dc3545;border-color:#dc3545}.tree-node-row.tree-excluded{opacity:.4}.tree-node-row.tree-excluded .tree-name{text-decoration:line-through}.tree-right{flex-shrink:0;align-items:center;gap:6px;margin-left:auto;display:flex}.tree-count{color:#999;text-align:right;font-variant-numeric:tabular-nums;min-width:28px;font-size:11px}.tree-count-selected{color:#2c934e;font-weight:600}.face-section{border-top:1px solid #e0e0e0;margin-top:12px;padding-top:12px}.face-section-header{color:#2c934e;margin-bottom:8px;font-size:13px;font-weight:600}.face-stats{color:#666;gap:12px;margin-bottom:8px;font-size:11px;display:flex}.face-detect-btn,.face-suggest-btn{width:100%;margin-bottom:6px}.face-progress{align-items:center;gap:8px;margin-bottom:6px;display:flex}.face-progress-text{color:#666;white-space:nowrap;font-size:11px}.progress-bar-container.small{flex:1;height:8px}.suggest-panel{background:#fff;border:1px solid #e0e0e0;border-radius:8px;height:calc(100svh - 80px);padding:12px;position:sticky;top:60px;overflow-y:auto}.suggest-panel h3{color:#2c934e;margin:0 0 4px;font-size:14px}.suggest-desc{color:#666;margin:0 0 12px;font-size:11px}.suggest-loading,.suggest-empty{color:#999;font-size:12px}.suggest-group{margin-bottom:16px}.suggest-group-header{color:#2c934e;border-bottom:1px solid #e6f7ed;margin-bottom:6px;padding-bottom:4px;font-size:12px;font-weight:600}.suggest-photos{grid-template-columns:repeat(auto-fill,minmax(56px,1fr));gap:4px;display:grid}.suggest-photo{aspect-ratio:1;cursor:pointer;background:#f0f0f0;border:1px solid #e0e0e0;border-radius:4px;padding:0;transition:border-color .2s;overflow:hidden}.suggest-photo:hover{border-color:#2c934e}.suggest-photo img{object-fit:cover;width:100%;height:100%}.suggest-photo-name{color:#999;text-align:center;word-break:break-all;justify-content:center;align-items:center;width:100%;height:100%;padding:2px;font-size:8px;display:flex}.suggest-more{color:#666;justify-content:center;align-items:center;font-size:11px;display:flex}.suggest-face-list{scrollbar-width:none;gap:6px;padding:8px 0;display:flex;overflow-x:auto}.suggest-face-list::-webkit-scrollbar{display:none}.suggest-face-btn{cursor:pointer;background:#f0f0f0;border:2px solid #e0e0e0;border-radius:50%;flex-shrink:0;width:48px;height:48px;padding:0;transition:border-color .15s;position:relative;overflow:hidden}.suggest-face-btn img{object-fit:cover;width:100%;height:100%}.suggest-face-btn.active{border-color:#2c934e;box-shadow:0 0 0 2px #2c934e}.suggest-face-btn.merge-selected{border-color:#e67e22;box-shadow:0 0 0 2px #e67e22}.suggest-face-count{color:#fff;background:#2c934e;border-radius:50%;justify-content:center;align-items:center;width:16px;height:16px;font-size:9px;font-weight:700;display:flex;position:absolute;bottom:-2px;right:-2px}.suggest-face-placeholder{color:#ccc;justify-content:center;align-items:center;width:100%;height:100%;font-size:16px;display:flex}.suggest-group-actions{gap:6px;padding:4px 0;display:flex}.suggest-merge-hint{color:#e67e22;margin:4px 0;font-size:11px}.suggest-group-detail{background:#f8f9fa;border-radius:6px;margin:8px 0;padding:8px}.suggest-group-faces{flex-wrap:wrap;gap:6px;display:flex}.suggest-group-face-item{width:40px;height:40px;position:relative}.suggest-group-face-thumb{object-fit:cover;border-radius:50%;width:40px;height:40px}.suggest-split-btn{color:#fff;cursor:pointer;opacity:0;background:#dc3545;border:none;border-radius:50%;justify-content:center;align-items:center;width:16px;height:16px;padding:0;font-size:9px;transition:opacity .15s;display:flex;position:absolute;top:-4px;right:-4px}.suggest-group-face-item:hover .suggest-split-btn{opacity:1}.suggest-results{border-top:1px solid #e0e0e0;margin-top:8px;padding-top:8px}.suggest-progress{margin-bottom:8px}.suggest-progress-text{color:#666;margin-top:4px;font-size:11px;display:block}.suggest-close-btn{z-index:10;position:fixed;top:68px;right:24px}.browse-tip-toggle{margin-bottom:8px}.browse-tip{color:#2c6e3f;background:#f0faf4;border:1px solid #c3e8d0;border-radius:10px;align-items:flex-start;gap:12px;margin-bottom:12px;padding:14px 16px;display:flex}.browse-tip-content{flex:1}.browse-tip-title{margin-bottom:6px;font-size:14px;font-weight:700}.browse-tip-steps{flex-direction:column;gap:4px;margin:0;padding-left:20px;font-size:13px;line-height:1.6;display:flex}.browse-tip-steps li::marker{color:#2c934e;font-weight:700}.tip-step-icon{margin-right:4px}.browse-tip-icon{color:#2c934e;vertical-align:middle;border:1px solid #2c934e;border-radius:4px;justify-content:center;align-items:center;width:18px;height:18px;font-size:12px;font-weight:700;display:inline-flex}.browse-tip-close{color:#2c6e3f;cursor:pointer;white-space:nowrap;background:0 0;border:1px solid #a3d4b5;border-radius:9999px;flex-shrink:0;margin-top:2px;padding:4px 12px;font-size:12px}.browse-tip-close:hover{background:#d0f0dc}.user-filter{flex-wrap:wrap;align-items:center;gap:6px;margin-bottom:10px;display:flex}.user-filter-label{color:#666;margin-right:2px;font-size:12px;font-weight:600}.user-filter-chip{cursor:pointer;color:#555;background:#fff;border:1px solid #ddd;border-radius:9999px;align-items:center;gap:4px;padding:3px 10px;font-size:12px;transition:all .15s;display:inline-flex}.user-filter-chip:hover{background:#f0faf4;border-color:#2c934e}.user-filter-chip.active{color:#fff;background:#2c934e;border-color:#2c934e}.user-filter-avatar{border-radius:50%;width:16px;height:16px}.user-filter-count{opacity:.7;font-size:11px;font-weight:700}.filters{margin-bottom:20px}.filter-row{flex-wrap:wrap;gap:16px;margin-bottom:12px;display:flex}.filter-group{flex-direction:column;gap:4px;display:flex}.filter-group label{color:#666;font-size:12px;font-weight:600}.filter-group select{border:1px solid #ccc;border-radius:6px;min-width:200px;padding:8px 12px;font-size:14px}.action-bar{background:#e6f7ed;border-radius:6px;align-items:center;gap:12px;padding:8px 12px;display:flex}.photo-count{color:#2c934e;font-size:14px;font-weight:600}.photo-grid{grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:12px;display:grid}.photo-card{cursor:pointer;background:#fff;border:2px solid #0000;border-radius:8px;transition:all .2s;overflow:hidden;box-shadow:0 1px 4px #0000000f}.photo-card:hover{transform:translateY(-1px);box-shadow:0 4px 12px #0000001f}.photo-card.selected{border-color:#2c934e;box-shadow:0 0 0 1px #2c934e}.photo-card.toggling{opacity:.7;pointer-events:none}.photo-thumbnail{aspect-ratio:1;background:#f0f0f0;position:relative;overflow:hidden}.photo-thumbnail img{object-fit:cover;-webkit-touch-callout:none;-webkit-user-select:none;pointer-events:none;width:100%;height:100%}.photo-placeholder{color:#999;word-break:break-all;text-align:center;justify-content:center;align-items:center;width:100%;height:100%;padding:8px;font-size:11px;display:flex}.selected-check{color:#fff;background:#2c934e;border-radius:50%;justify-content:center;align-items:center;width:28px;height:28px;font-size:16px;font-weight:700;display:flex;position:absolute;top:8px;right:8px}.photo-info{padding:6px 8px}.photo-info-row{align-items:center;gap:4px;display:flex}.selector-avatars{flex-shrink:0;gap:1px;margin-left:auto;display:flex}.selector-avatar{background:#2c934e;border:1.5px solid #fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:18px;height:18px;display:flex;overflow:hidden;box-shadow:0 0 0 .5px #ccc}.selector-avatar img{object-fit:cover;width:100%;height:100%}.selector-avatar-initial{color:#fff;font-size:9px;font-weight:700}.photo-name{color:#666;text-overflow:ellipsis;white-space:nowrap;font-size:11px;display:block;overflow:hidden}.selector-badges{flex-wrap:wrap;gap:4px;margin-top:4px;display:flex}.selector-count{color:#2c934e;background:#e6f7ed;border-radius:10px;padding:1px 6px;font-size:11px;font-weight:600}.selector-badge{color:#666;background:#f0f0f0;border-radius:10px;padding:1px 6px;font-size:10px}.lightbox-overlay{z-index:1000;background:#000000eb;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.lightbox-content{-webkit-user-select:none;user-select:none;flex-direction:column;width:100%;height:100%;padding-top:44px;display:flex;position:relative}.lightbox-close{z-index:10;color:#fff;cursor:pointer;background:#ffffff26;border:none;border-radius:50%;justify-content:center;align-items:center;width:40px;height:40px;font-size:20px;display:flex;position:absolute;top:12px;right:12px}.lightbox-close:hover{background:#ffffff4d}.lightbox-counter{color:#ffffffb3;z-index:10;font-size:14px;position:absolute;top:16px;left:16px}.lightbox-main{flex:1;justify-content:center;align-items:center;min-height:0;display:flex;overflow:hidden}.lightbox-image{object-fit:contain;border-radius:4px;max-width:92vw;max-height:100%}.lightbox-controls{z-index:10;flex-shrink:0;justify-content:center;align-items:center;gap:16px;padding:8px 0;display:flex}.lightbox-nav-btn{color:#fff;cursor:pointer;background:#ffffff1f;border:none;border-radius:50%;justify-content:center;align-items:center;width:44px;height:44px;font-size:20px;transition:background .15s;display:flex}.lightbox-nav-btn:hover{background:#ffffff40}.lightbox-nav-btn:disabled{opacity:.2;cursor:default}.lightbox-strip-wrap{padding:0 0 env(safe-area-inset-bottom,8px);z-index:10;flex-shrink:0}.lightbox-strip{scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch;scrollbar-width:none;gap:4px;padding:4px 8px;display:flex;overflow-x:auto}.lightbox-strip::-webkit-scrollbar{display:none}.lightbox-strip-item{cursor:pointer;scroll-snap-align:center;opacity:.5;background:#333;border:2px solid #0000;border-radius:6px;flex-shrink:0;width:56px;height:56px;padding:0;transition:opacity .15s,border-color .15s;position:relative;overflow:hidden}.lightbox-strip-item:hover{opacity:.8}.lightbox-strip-item.current{opacity:1;border-color:#fff}.lightbox-strip-item.strip-selected{opacity:.9;border-color:#2c934e}.lightbox-strip-item.current.strip-selected{opacity:1;border-color:#2c934e;box-shadow:0 0 0 1px #fff}.lightbox-strip-item img{object-fit:cover;width:100%;height:100%}.lightbox-strip-name{color:#999;text-align:center;word-break:break-all;justify-content:center;align-items:center;width:100%;height:100%;padding:2px;font-size:7px;display:flex}.strip-check{color:#fff;background:#2c934e;border-radius:50%;justify-content:center;align-items:center;width:14px;height:14px;font-size:9px;line-height:1;display:flex;position:absolute;bottom:1px;right:1px}.lightbox-select-btn{color:#fff;cursor:pointer;background:0 0;border:2px solid #fff9;border-radius:9999px;padding:8px 28px;font-size:14px;font-weight:600;transition:all .15s}.lightbox-select-btn:hover{background:#ffffff26}.lightbox-select-btn.active{background:#2c934e;border-color:#2c934e}.lightbox-filename{color:#fff9;text-align:center;text-overflow:ellipsis;white-space:nowrap;flex-shrink:0;padding:0 16px;font-size:12px;overflow:hidden}.lightbox-flash{z-index:20;pointer-events:none;border-radius:12px;padding:16px 32px;font-size:24px;font-weight:700;animation:.6s ease-out forwards flashFade;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.lightbox-flash.select{color:#fff;background:#2c934ed9}.lightbox-flash.deselect{color:#fff;background:#dc3545d9}@keyframes flashFade{0%{opacity:1;transform:translate(-50%,-50%)scale(1)}to{opacity:0;transform:translate(-50%,-60%)scale(1.1)}}@media (width<=768px){.lightbox-strip-item{width:48px;height:48px}}.photo-grid-sentinel{grid-column:1/-1;height:1px}.empty-state{color:#999;justify-content:center;align-items:center;padding:60px 20px;font-size:16px;display:flex}.summary-page h2{color:#2c934e;margin:0 0 16px;font-size:20px}.summary-controls{margin-bottom:16px}.checkbox-label{cursor:pointer;align-items:center;gap:6px;font-size:14px;display:inline-flex}.summary-section{margin-bottom:24px}.summary-h2{color:#2c934e;border-bottom:2px solid #e6f7ed;margin:0 0 8px;padding-bottom:4px;font-size:16px}.summary-table{border-collapse:collapse;width:100%;font-size:14px}.summary-table th{text-align:left;color:#666;background:#f8f9fa;border-bottom:1px solid #e0e0e0;padding:6px 12px;font-size:12px}.summary-table td{border-bottom:1px solid #f0f0f0;padding:6px 12px}.summary-table .num{text-align:right;font-variant-numeric:tabular-nums}.summary-table tr.no-selection{background:#fff8e1}.summary-table tr.excluded-row{opacity:.5;text-decoration:line-through}.album-header-row{justify-content:space-between;align-items:center;margin-bottom:16px;display:flex}.album-header-row h2{color:#2c934e;margin:0;font-size:20px}.book-overlay{z-index:500;background:#2a2a2a;flex-direction:column;display:flex;position:fixed;inset:0}.book-topbar{flex-shrink:0;justify-content:space-between;align-items:center;padding:10px 16px;display:flex}.book-page-indicator{color:#ffffffb3;font-size:14px}.book-close-btn{color:#fff!important;border-color:#ffffff4d!important}.book-container{perspective:1200px;flex:1;justify-content:center;align-items:center;gap:12px;min-height:0;padding:0 12px 20px;display:flex}.book-nav{color:#fff;cursor:pointer;background:#ffffff1a;border:none;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:48px;height:48px;font-size:20px;transition:background .15s;display:flex}.book-nav:hover:not(:disabled){background:#fff3}.book-nav:disabled{opacity:.2;cursor:default}.book-spread-area{perspective:1200px;flex:1;justify-content:center;align-items:center;max-width:1000px;height:100%;display:flex}.book-spread{width:100%;max-height:100%;transform-style:preserve-3d;display:flex}.book-spread.flip-out{animation:.5s forwards bookFlipOut}.book-spread.flip-in{animation:.5s forwards bookFlipIn}@keyframes bookFlipOut{0%{opacity:1;transform:rotateY(0)}50%{opacity:.6;transform:rotateY(-45deg)}to{opacity:0;transform:rotateY(-90deg)}}@keyframes bookFlipIn{0%{opacity:0;transform:rotateY(90deg)}50%{opacity:.6;transform:rotateY(45deg)}to{opacity:1;transform:rotateY(0)}}.book-page-inner{background:#fffef9;flex-direction:column;flex:1;min-height:55vh;max-height:80vh;padding:24px 20px 16px;display:flex;position:relative;overflow-y:auto}.book-page-left{border-right:1px solid #d8d4c9;border-radius:8px 0 0 8px;box-shadow:inset -8px 0 12px #0000000a,-3px 0 6px #00000014}.book-page-right{border-left:1px solid #d8d4c9;border-radius:0 8px 8px 0;box-shadow:inset 8px 0 12px #0000000a,3px 0 6px #00000014}.book-page-empty{background:#faf8f2}.book-page-title{color:#3a3a3a;text-align:center;border-bottom:1px solid #e0ddd4;margin-bottom:16px;padding-bottom:10px;font-family:Georgia,Times New Roman,serif;font-size:18px;font-weight:700}.book-page-photos{flex:1;grid-template-columns:repeat(auto-fill,minmax(120px,1fr));align-content:start;gap:10px;display:grid}.book-photo{aspect-ratio:4/3;cursor:pointer;background:#f0ede4;border:3px solid #fff;border-radius:2px;outline:1px solid #ddd;transition:transform .15s,box-shadow .15s;overflow:hidden;box-shadow:0 1px 3px #0000001f}.book-photo:hover{transform:scale(1.03);box-shadow:0 3px 10px #0003}.book-photo img{object-fit:cover;width:100%;height:100%}.book-photo-name{color:#999;text-align:center;word-break:break-all;justify-content:center;align-items:center;width:100%;height:100%;padding:4px;font-size:9px;display:flex}.book-page-number{text-align:center;color:#aaa;margin-top:auto;padding-top:12px;font-family:Georgia,Times New Roman,serif;font-size:13px}@media (width<=768px){.book-container{gap:6px;padding:0 6px 12px}.book-nav{width:36px;height:36px;font-size:16px}.book-spread{flex-direction:column;gap:2px}.book-page-inner{border:none;border-radius:6px;min-height:40vh;max-height:42vh;padding:12px 12px 8px;box-shadow:0 1px 4px #0000001a}.book-page-left{border-bottom:1px solid #d8d4c9;border-right:none;border-radius:6px 6px 0 0}.book-page-right{border-top:1px solid #d8d4c9;border-left:none;border-radius:0 0 6px 6px}.book-page-photos{grid-template-columns:repeat(auto-fill,minmax(70px,1fr));gap:4px}.book-page-title{margin-bottom:8px;padding-bottom:6px;font-size:13px}.book-page-number{padding-top:6px;font-size:11px}.book-photo{border-width:2px}}.album-unassigned{background:#fff;border:1px solid #e0e0e0;border-radius:8px;margin-bottom:20px;padding:16px}.album-unassigned-header{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:8px;margin-bottom:12px;display:flex}.album-unassigned-header h3{color:#333;margin:0;font-size:15px}.album-assign-bar{color:#2c934e;align-items:center;gap:8px;font-size:13px;font-weight:600;display:flex}.album-assign-bar select{border:1px solid #ccc;border-radius:6px;padding:4px 8px;font-size:13px}.album-photo-grid{grid-template-columns:repeat(auto-fill,minmax(80px,1fr));gap:6px;display:grid}.album-photo-card{background:#f0f0f0;border:2px solid #0000;border-radius:6px;position:relative;overflow:hidden}.album-photo-card.checked{border-color:#2c934e}.album-photo-thumb{aspect-ratio:1;cursor:pointer;position:relative}.album-photo-thumb img{object-fit:cover;-webkit-touch-callout:none;-webkit-user-select:none;pointer-events:none;width:100%;height:100%}.album-photo-name{color:#999;text-align:center;word-break:break-all;justify-content:center;align-items:center;width:100%;height:100%;padding:4px;font-size:8px;display:flex}.album-photo-check{cursor:pointer;width:16px;height:16px;position:absolute;top:4px;left:4px}.album-photo-remove{color:#fff;cursor:pointer;opacity:0;background:#00000080;border:none;border-radius:50%;justify-content:center;align-items:center;width:18px;height:18px;padding:0;font-size:11px;transition:opacity .15s;display:flex;position:absolute;top:2px;right:2px}.album-photo-card:hover .album-photo-remove{opacity:1}.album-empty-msg{color:#999;text-align:center;grid-column:1/-1;margin:0;padding:20px 0;font-size:13px}.album-pages-row{grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:12px;margin-bottom:20px;display:grid}.album-box{background:#fff;border:1px solid #e0e0e0;border-radius:8px;padding:12px}.album-box-header{border-bottom:2px solid #e6f7ed;align-items:center;gap:8px;margin-bottom:8px;padding-bottom:8px;display:flex}.album-box-name{flex:1;font-size:14px;font-weight:600}.album-box-count{color:#666;font-variant-numeric:tabular-nums;font-size:12px}.shortage{color:#e65100;font-size:12px;font-weight:600}.excess{color:#dc3545;font-size:12px;font-weight:600}.album-box-photos{grid-template-columns:repeat(auto-fill,minmax(56px,1fr));gap:4px;display:grid}.album-add-page{background:#fff;border:1px dashed #ccc;border-radius:8px;padding:16px}.add-page-form{flex-wrap:wrap;align-items:end;gap:12px;display:flex}.add-page-form input[type=text]{border:1px solid #ccc;border-radius:6px;flex:1;min-width:180px;padding:8px 12px;font-size:14px}.add-page-form label{color:#666;align-items:center;gap:8px;font-size:13px;display:flex}.add-page-form input[type=number]{border:1px solid #ccc;border-radius:6px;width:80px;padding:8px;font-size:14px}.export-page h2{color:#2c934e;margin:0 0 16px;font-size:20px}.export-stats{color:#666;margin-bottom:20px;font-size:14px}.export-stats p{margin:2px 0}.export-section{background:#fff;border:1px solid #e0e0e0;border-radius:8px;margin-bottom:16px;padding:20px}.export-section h3{color:#2c934e;margin:0 0 12px;font-size:16px}.help-text{color:#666;margin-bottom:12px;font-size:13px}.export-form{align-items:center;gap:12px;display:flex}.export-form input{border:1px solid #ccc;border-radius:6px;flex:1;padding:8px 12px;font-size:14px}.progress-bar-container{background:#e0e0e0;border-radius:8px;height:24px;margin-top:16px;position:relative;overflow:hidden}.progress-bar{background:#2c934e;border-radius:8px;height:100%;transition:width .3s}.progress-text{color:#fff;mix-blend-mode:difference;justify-content:center;align-items:center;font-size:12px;font-weight:600;display:flex;position:absolute;inset:0}.success-text{color:#2e7d32;margin-top:12px;font-weight:600}.error-text{color:#dc3545;margin-top:12px;font-weight:600}@media (width<=768px){.browse-layout,.browse-layout.with-suggest{grid-template-columns:1fr}.suggest-panel{z-index:200;border-radius:0;width:280px;height:100svh;position:fixed;top:0;right:0;box-shadow:-4px 0 12px #0000001a}.header-content{flex-direction:column;align-items:flex-start;gap:8px}.nav-links{gap:2px;width:100%;overflow-x:auto}.nav-links a{flex-shrink:0;padding:4px 8px;font-size:11px}.user-info{justify-content:flex-end;width:100%;margin-left:0}.filter-row{flex-direction:column;gap:12px}.filter-group select{min-width:100%}.photo-grid{grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:8px}.action-bar{flex-wrap:wrap;gap:8px}.export-form{flex-direction:column}.add-page-form{flex-direction:column;align-items:stretch}}
