*,:before,:after{box-sizing:border-box;-webkit-tap-highlight-color:transparent;margin:0;padding:0}:root{--bg:#f7f6f2;--surface:#fff;--surface-2:#f0eee9;--border:#e8e6e1;--accent:#f05e3b;--accent-dim:#f05e3b1f;--text-1:#1a1814;--text-2:#6b6760;--text-3:#a8a49e;--red:#e53e3e;--shadow-xs:0 1px 3px #00000012;--shadow-sm:0 2px 8px #00000017;--shadow-md:0 8px 24px #0000001f;--shadow-lg:0 24px 64px #00000038;--r-sm:10px;--r-md:16px;--r-lg:24px;--nav-h:50px}html{height:100dvh;overflow:hidden}body,#root{height:100%;overflow:hidden}body{background:var(--surface);color:var(--text-1);-webkit-font-smoothing:antialiased;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}.app-shell{background:var(--bg);max-width:430px;height:100%;box-shadow:0 0 0 1px #0000000f, var(--shadow-lg);flex-direction:column;margin:0 auto;display:flex;position:relative;overflow:hidden}.page{-webkit-overflow-scrolling:touch;padding-bottom:calc(var(--nav-h) + 16px + env(safe-area-inset-bottom,0px));flex:1;overflow:hidden auto}.page-header{padding:calc(env(safe-area-inset-top) + 20px) 20px 12px;background:var(--bg);z-index:10;justify-content:space-between;align-items:center;display:flex;position:sticky;top:0}.page-title{letter-spacing:-.5px;color:var(--text-1);font-size:28px;font-weight:700}.bottom-nav{padding-bottom:env(safe-area-inset-bottom,0px);background:var(--surface);border-top:1px solid var(--border);flex-shrink:0;align-items:stretch;display:flex}.nav-tab{height:var(--nav-h);cursor:pointer;color:var(--text-3);-webkit-user-select:none;user-select:none;background:0 0;border:none;flex-direction:column;flex:1;justify-content:center;align-items:center;gap:4px;transition:color .15s;display:flex}.nav-tab.active{color:var(--accent)}.nav-tab-label{letter-spacing:.2px;font-size:10px;font-weight:600}.icon-btn{cursor:pointer;width:36px;height:36px;color:var(--text-2);background:0 0;border:none;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;transition:background .15s,color .15s;display:flex}.icon-btn:active{background:var(--surface-2)}.icon-btn.primary{background:var(--accent);color:#fff;width:34px;height:34px}.icon-btn.primary:active{opacity:.85}.collection-row{margin-bottom:8px}.collection-row-header{align-items:center;gap:8px;padding:8px 20px 10px;display:flex}.collection-row-name{color:var(--text-1);letter-spacing:-.3px;flex:1;font-size:18px;font-weight:700}.collection-scroll{-webkit-overflow-scrolling:touch;scrollbar-width:none;gap:12px;padding:2px 20px 16px;display:flex;overflow-x:auto}.collection-scroll::-webkit-scrollbar{display:none}.podcast-card-wrapper{cursor:pointer;-webkit-user-select:none;user-select:none;flex-direction:column;flex-shrink:0;width:200px;display:flex}.podcast-card{background:var(--surface);border-radius:var(--r-md);box-shadow:var(--shadow-sm);border:1px solid var(--border);position:relative;overflow:hidden}@keyframes dismissSlideIn{0%{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:translateY(0)}}.card-dismiss-btn{color:#fff;letter-spacing:.04em;border-radius:var(--r-md);background:#c0392b;justify-content:center;align-items:center;height:42px;font-size:13px;font-weight:700;animation:.18s dismissSlideIn;display:flex}@keyframes overlayIn{0%{opacity:0}to{opacity:1}}.card-overlay{-webkit-backdrop-filter:blur(4px);z-index:10;background:#0000009e;justify-content:center;align-items:center;gap:24px;animation:.16s overlayIn;display:flex;position:absolute;inset:0}.card-overlay-btn{cursor:pointer;color:#fff;background:0 0;border:none;flex-direction:column;align-items:center;gap:8px;padding:8px;display:flex}.card-overlay-icon{border-radius:50%;justify-content:center;align-items:center;width:52px;height:52px;display:flex}.card-overlay-label{letter-spacing:.03em;color:#ffffffe6;font-size:11px;font-weight:600}.podcast-card:active{box-shadow:var(--shadow-xs);transform:scale(.97)}.podcast-card-art{aspect-ratio:1;object-fit:cover;background:var(--surface-2);width:100%;display:block}.podcast-card-art-placeholder{aspect-ratio:1;background:var(--surface-2);width:100%;color:var(--text-3);justify-content:center;align-items:center;display:flex}.podcast-card-body{flex-direction:column;height:96px;padding:10px 12px 12px;display:flex;overflow:hidden}.podcast-card-ep-title{color:var(--text-2);-webkit-line-clamp:2;-webkit-box-orient:vertical;flex-shrink:0;margin-bottom:4px;font-size:12px;font-weight:600;line-height:1.4;display:-webkit-box;overflow:hidden}.podcast-card-ep-meta{color:var(--text-3);flex-shrink:0;margin-bottom:4px;font-size:11px}.podcast-card-ep-desc{color:var(--text-3);-webkit-line-clamp:4;-webkit-box-orient:vertical;flex:1;font-size:11px;line-height:1.5;display:-webkit-box;overflow:hidden}.podcast-card-loading{padding:12px}.skeleton{background:linear-gradient(90deg, var(--surface-2) 25%, var(--border) 50%, var(--surface-2) 75%);background-size:200% 100%;border-radius:4px;animation:1.5s infinite shimmer}@keyframes shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.library-list{flex-direction:column;gap:2px;padding:0 16px 8px;display:flex}.library-row{background:var(--surface);border-radius:var(--r-sm);cursor:pointer;align-items:center;gap:14px;padding:12px 14px;transition:background .12s;display:flex}.library-row:active{background:var(--surface-2)}.library-art{object-fit:cover;background:var(--surface-2);border-radius:10px;flex-shrink:0;width:52px;height:52px}.library-info{flex:1;min-width:0}.library-podcast-name{color:var(--text-1);white-space:nowrap;text-overflow:ellipsis;margin-bottom:3px;font-size:15px;font-weight:600;overflow:hidden}.library-collection-tag{color:var(--text-3);font-size:12px}.library-collection-tag.assigned{color:var(--accent);font-weight:600}.search-bar-wrap{padding:0 16px 12px}.search-input{background:var(--surface);border:1.5px solid var(--border);width:100%;height:42px;color:var(--text-1);background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' fill='none' viewBox='0 0 24 24'%3E%3Ccircle cx='11' cy='11' r='8' stroke='%23A8A49E' stroke-width='2'/%3E%3Cpath d='M21 21l-4.35-4.35' stroke='%23A8A49E' stroke-width='2' stroke-linecap='round'/%3E%3C/svg%3E");background-position:12px;background-repeat:no-repeat;border-radius:12px;outline:none;padding:0 14px 0 38px;font-size:16px;transition:border-color .15s}.search-input:focus{border-color:var(--accent)}.search-results{flex-direction:column;gap:2px;padding:0 16px;display:flex}.search-result-row{background:var(--surface);border-radius:var(--r-sm);cursor:pointer;align-items:center;gap:14px;padding:10px 14px;transition:background .12s;display:flex}.search-result-row:active{background:var(--surface-2)}.search-result-art{object-fit:cover;background:var(--surface-2);border-radius:10px;flex-shrink:0;width:52px;height:52px}.search-result-name{color:var(--text-1);-webkit-line-clamp:2;-webkit-box-orient:vertical;font-size:14px;font-weight:600;line-height:1.3;display:-webkit-box;overflow:hidden}.search-result-artist{color:var(--text-3);margin-top:2px;font-size:12px}.sheet-overlay{z-index:100;pointer-events:none;background:0 0;transition:background .25s;position:absolute;inset:0}.sheet-overlay.open{pointer-events:all;background:#00000073}.bottom-sheet{background:var(--surface);border-radius:var(--r-lg) var(--r-lg) 0 0;z-index:101;max-height:92%;padding-bottom:env(safe-area-inset-bottom,0px);flex-direction:column;transition:transform .3s cubic-bezier(.32,.72,0,1);display:flex;position:absolute;bottom:0;left:0;right:0;overflow:hidden;transform:translateY(100%)}.bottom-sheet.open{transform:translateY(0)}.sheet-handle{background:var(--border);border-radius:2px;flex-shrink:0;width:36px;height:4px;margin:12px auto 0}.sheet-scroll{-webkit-overflow-scrolling:touch;flex:1;overflow-y:auto}.sheet-header{align-items:center;gap:16px;padding:16px 20px 12px;display:flex}.sheet-art{object-fit:cover;background:var(--surface-2);border-radius:14px;flex-shrink:0;width:80px;height:80px}.sheet-podcast-info{flex:1;min-width:0}.sheet-podcast-name{color:var(--text-1);letter-spacing:-.3px;margin-bottom:4px;font-size:18px;font-weight:700;line-height:1.3}.sheet-publisher{color:var(--text-3);font-size:13px}.sheet-divider{background:var(--border);height:1px;margin:0 20px}.sheet-section{padding:16px 20px}.sheet-section-label{letter-spacing:.6px;text-transform:uppercase;color:var(--text-3);margin-bottom:10px;font-size:11px;font-weight:700}.sheet-footer{flex-shrink:0;padding:12px 20px}.btn{cursor:pointer;border:none;border-radius:14px;justify-content:center;align-items:center;width:100%;height:50px;font-size:16px;font-weight:600;transition:opacity .15s,transform .1s;display:flex}.btn:active{opacity:.82;transform:scale(.98)}.btn-primary{background:var(--accent);color:#fff}.btn-secondary{background:var(--surface-2);color:var(--text-1)}.btn-destructive{color:var(--red);background:#e53e3e1a}.action-sheet-wrap{z-index:200;pointer-events:none;flex-direction:column;justify-content:flex-end;display:flex;position:absolute;inset:0}.action-sheet-wrap.open{pointer-events:all}.action-sheet-backdrop{background:0 0;transition:background .2s;position:absolute;inset:0}.action-sheet-wrap.open .action-sheet-backdrop{background:#0006}.action-sheet-body{z-index:1;padding:0 10px;padding-bottom:calc(10px + env(safe-area-inset-bottom,0px));transition:transform .28s cubic-bezier(.32,.72,0,1);position:relative;transform:translateY(120%)}.action-sheet-wrap.open .action-sheet-body{transform:translateY(0)}.action-sheet-group{background:var(--surface);border-radius:14px;margin-bottom:8px;overflow:hidden}.action-sheet-title{text-align:center;color:var(--text-3);border-bottom:1px solid var(--border);padding:14px 16px 10px;font-size:13px}.action-sheet-item{color:var(--text-1);cursor:pointer;border:none;border-top:1px solid var(--border);background:0 0;justify-content:center;align-items:center;width:100%;padding:17px 16px;font-size:17px;transition:background .12s;display:flex}.action-sheet-item:first-child{border-top:none}.action-sheet-item:active{background:var(--surface-2)}.action-sheet-item.destructive{color:var(--red)}.action-sheet-item.cancel{font-weight:600}.select{border:1.5px solid var(--border);background:var(--surface);width:100%;height:44px;color:var(--text-1);appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' fill='none' viewBox='0 0 24 24'%3E%3Cpath d='M6 9l6 6 6-6' stroke='%23A8A49E' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");background-position:right 12px center;background-repeat:no-repeat;border-radius:10px;outline:none;padding:0 36px 0 12px;font-size:15px}.select:focus{border-color:var(--accent)}.text-input{border:1.5px solid var(--border);background:var(--surface);width:100%;height:44px;color:var(--text-1);border-radius:10px;outline:none;padding:0 12px;font-size:16px}.text-input:focus{border-color:var(--accent)}.empty-state{text-align:center;color:var(--text-3);flex-direction:column;justify-content:center;align-items:center;gap:12px;padding:60px 32px;display:flex}.empty-state-icon{opacity:.45}.empty-state-text{font-size:15px;line-height:1.5}.in-library-badge{background:var(--accent-dim,#f05e3b1a);color:var(--accent);border-radius:6px;align-items:center;gap:4px;margin-bottom:12px;padding:4px 8px;font-size:12px;font-weight:600;display:inline-flex}.spinner{border:2.5px solid var(--border);border-top-color:var(--accent);border-radius:50%;width:22px;height:22px;animation:.7s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.search-status{text-align:center;color:var(--text-3);flex-direction:column;align-items:center;gap:12px;padding:40px 16px;font-size:14px;display:flex}.unassigned-section{align-items:center;gap:10px;padding:16px 20px 8px;display:flex}.unassigned-label{color:var(--text-2);flex:1;font-size:18px;font-weight:700}
