@import "https://fonts.googleapis.com/css2?family=Barlow+Condensed:wght@300;400;500;600;700;800;900&family=Inter:wght@300;400;500;600;700&family=Lora:ital,wght@0,400;0,500;0,600;0,700;1,400;1,500&family=IBM+Plex+Mono:wght@300;400;500&display=swap";@import "https://fonts.googleapis.com/css2?family=Barlow+Condensed:wght@300;400;500;600;700;900&family=Lora:ital,wght@0,400;0,500;0,600;0,700;1,400;1,500&family=IBM+Plex+Mono:wght@300;400;500&display=swap";:root{--bg-primary:#0f0f1a;--bg-card:#1a1a2e;--bg-card-end:#12121f;--bg-elevated:#ffffff0a;--bg-input:#ffffff0f;--bg-hover:#ffffff14;--bg-active:#ffffff1a;--border-subtle:#ffffff0f;--border-medium:#ffffff1a;--border-strong:#ffffff29;--text-primary:#fff;--text-secondary:#ffffffd9;--text-muted:#ffffff80;--text-faint:#ffffff40;--accent-red:#e94560;--accent-red-dim:#e945601f;--accent-green:#4ade80;--accent-green-dim:#4ade801f;--accent-gold:#facc15;--accent-gold-dim:#facc151f;--accent-cyan:#22d3ee;--accent-cyan-dim:#22d3ee1f;--accent-purple:#a78bfa;--accent-purple-dim:#a78bfa1f;--accent-orange:#fc4c02;--accent-terra:#c4734f;--accent-terra-dim:#c4734f1f;--font-display:"Barlow Condensed", sans-serif;--font-body:"Inter", system-ui, -apple-system, sans-serif;--font-serif:"Lora", serif;--font-mono:"IBM Plex Mono", monospace;--shadow-card:0 2px 8px #0000004d, 0 8px 24px #0003;--shadow-poster:0 2px 6px #0000004d, 0 8px 20px #0003;--shadow-modal:0 -4px 24px #00000080;--shadow-glow-red:0 0 20px #e9456026;--shadow-glow-green:0 0 20px #4ade8026;--radius-sm:8px;--radius-md:12px;--radius-lg:16px;--radius-xl:20px;--radius-full:9999px;--space-xs:4px;--space-sm:8px;--space-md:16px;--space-lg:24px;--space-xl:32px;--ease-out:cubic-bezier(.2, .9, .3, 1);--ease-spring:cubic-bezier(.22, 1, .36, 1);--duration-fast:.15s;--duration-normal:.25s;--duration-slow:.35s;--z-base:1;--z-sticky:10;--z-overlay:100;--z-modal:200;--z-toast:300;--z-max:999}*{scrollbar-width:thin;scrollbar-color:#ffffff1f transparent}::-webkit-scrollbar{width:4px;height:4px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:#ffffff1f;border-radius:2px}::-webkit-scrollbar-thumb:hover{background:#fff3}.hide-scrollbar{-ms-overflow-style:none;scrollbar-width:none}.hide-scrollbar::-webkit-scrollbar{display:none}.grain{position:relative}.grain:before{content:"";opacity:.03;pointer-events:none;border-radius:inherit;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='200' height='200'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.65' numOctaves='3' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.5'/%3E%3C/svg%3E");background-size:200px 200px;position:absolute;inset:0}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes fadeUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes slideUp{0%{transform:translateY(100%)}to{transform:translateY(0)}}@keyframes slideDown{0%{transform:translateY(-100%)}to{transform:translateY(0)}}@keyframes scaleIn{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}@keyframes shimmer{0%{background-position:-400px 0}to{background-position:400px 0}}.skeleton-dark{border-radius:var(--radius-sm);background:linear-gradient(90deg,#ffffff0a 25%,#ffffff14 50%,#ffffff0a 75%) 0 0/200% 100%;animation:1.5s ease-in-out infinite shimmer}.dark-display{font-family:var(--font-display);color:var(--text-primary);text-transform:uppercase;letter-spacing:.02em;font-weight:700;line-height:1.1}.dark-label{font-family:var(--font-mono);color:var(--text-muted);text-transform:uppercase;letter-spacing:.08em;font-size:10px;font-weight:600}.dark-body{font-family:var(--font-body);color:var(--text-secondary);font-size:14px;line-height:1.5}.dark-meta{font-family:var(--font-body);color:var(--text-muted);font-size:12px;line-height:1.4}.dark-input{background:var(--bg-input);border:1px solid var(--border-medium);border-radius:var(--radius-md);width:100%;color:var(--text-primary);font-family:var(--font-body);transition:border-color var(--duration-fast);outline:none;padding:12px 14px;font-size:14px}.dark-input:focus{border-color:#4ade8066}.dark-input::placeholder{color:var(--text-faint)}.dark-textarea{background:var(--bg-input);border:1px solid var(--border-medium);border-radius:var(--radius-md);width:100%;min-height:60px;color:var(--text-secondary);font-family:var(--font-body);resize:none;transition:border-color var(--duration-fast);outline:none;padding:10px 14px;font-size:13px}.dark-textarea:focus{border-color:#4ade8066}.dark-textarea::placeholder{color:var(--text-faint)}.btn-dark-primary{border-radius:var(--radius-md);color:#0a0a0a;width:100%;font-family:var(--font-display);letter-spacing:.02em;cursor:pointer;transition:opacity var(--duration-fast);background:linear-gradient(135deg,#4ade80,#22c55e);border:none;padding:13px 0;font-size:15px;font-weight:700}.btn-dark-primary:disabled{opacity:.6;cursor:wait}.btn-dark-secondary{background:var(--bg-input);border:1px solid var(--border-medium);border-radius:var(--radius-md);color:#ccc;width:100%;font-family:var(--font-body);cursor:pointer;transition:background var(--duration-fast);padding:11px 0;font-size:13px;font-weight:600}.btn-dark-secondary:hover{background:var(--bg-hover)}.btn-dark-danger{background:var(--accent-red-dim);border-radius:var(--radius-md);width:100%;color:var(--accent-red);font-family:var(--font-body);cursor:pointer;transition:background var(--duration-fast);border:1px solid #e9456033;padding:11px 0;font-size:13px;font-weight:600}.btn-dark-ghost{width:100%;color:var(--text-muted);cursor:pointer;background:0 0;border:none;padding:10px 0;font-size:13px}.dark-pill{border-radius:var(--radius-full);align-items:center;gap:4px;padding:3px 10px;font-size:11px;font-weight:600;display:inline-flex}.dark-pill-green{background:var(--accent-green-dim);color:var(--accent-green);border:1px solid #4ade804d}.dark-pill-red{background:var(--accent-red-dim);color:var(--accent-red);border:1px solid #e945604d}.dark-pill-gold{background:var(--accent-gold-dim);color:var(--accent-gold);border:1px solid #facc154d}.poster-shadow{box-shadow:var(--shadow-poster);border-radius:var(--radius-sm)}button,a,[role=button]{-webkit-tap-highlight-color:transparent}.overlay{-webkit-backdrop-filter:blur(4px);background:#000000b3}.item-detail-overlay.item-detail-overlay{-webkit-backdrop-filter:blur(6px);background:#000000b3}.item-detail-sheet.item-detail-sheet{background:linear-gradient(180deg, var(--bg-card) 0%, var(--bg-card-end) 100%);border:1px solid var(--border-subtle);box-shadow:var(--shadow-modal);border-bottom:none}.item-detail-close.item-detail-close{color:var(--text-muted)}.item-detail-close:hover,.item-detail-title.item-detail-title{color:var(--text-primary)}.item-detail-meta.item-detail-meta{color:var(--text-muted)}.item-detail-actions.item-detail-actions{border-top-color:var(--border-subtle)}.pin-picker.pin-picker{background:linear-gradient(180deg, var(--bg-card) 0%, var(--bg-card-end) 100%);border:1px solid var(--border-subtle);box-shadow:var(--shadow-modal);border-bottom:none}.pin-picker-header.pin-picker-header{border-bottom:1px solid var(--border-subtle);padding-bottom:12px}.pin-picker-title.pin-picker-title{color:var(--text-primary)}.pin-picker-close.pin-picker-close{color:var(--text-muted)}.pin-picker-close:hover{color:var(--text-primary)}.pin-picker-search.pin-picker-search{background:var(--bg-input);border-color:var(--border-medium);color:var(--text-primary);font-family:var(--font-body)}.pin-picker-search::placeholder{color:var(--text-faint)}.pin-picker-cat.pin-picker-cat{color:var(--text-muted)}.pin-picker-item.pin-picker-item{transition:background .15s}.pin-picker-item.disabled{opacity:.3}.pin-picker-item-cover.pin-picker-item-cover{background:var(--bg-elevated);box-shadow:var(--shadow-poster)}.pin-picker-item-title.pin-picker-item-title{color:var(--text-primary)}.pin-picker-item-meta.pin-picker-item-meta{color:var(--text-muted)}.pin-picker-item-action.pin-picker-item-action{color:var(--accent-terra)}.pin-picker-empty.pin-picker-empty{color:var(--text-muted);font-family:var(--font-serif)}.event-form-label.event-form-label{color:var(--text-muted)}.event-form-input.event-form-input{background:var(--bg-input);border-color:var(--border-medium);color:var(--text-primary);font-family:var(--font-body)}.event-form-input::placeholder,.event-form-hint.event-form-hint{color:var(--text-faint)}.event-add-goal.event-add-goal{color:var(--accent-green)}.btn-shelf-it.btn-shelf-it{color:#0a0a0a;background:linear-gradient(135deg,#4ade80,#22c55e);border:none;box-shadow:0 4px 16px #4ade8033}.btn-save-profile.btn-save-profile{color:#0a0a0a;background:linear-gradient(135deg,#4ade80,#22c55e)}.btn-edit-rating.btn-edit-rating{background:var(--bg-input);color:var(--text-secondary);border-color:var(--border-medium)}.btn-edit-rating:hover{border-color:var(--accent-terra)!important;background:var(--bg-hover)!important}.btn-remove.btn-remove{background:var(--accent-red-dim);color:var(--accent-red);border-color:#e9456033}.btn-remove:hover{border-color:var(--accent-red)!important;background:#e945602e!important}.btn-pin-mantl.btn-pin-mantl{color:var(--accent-terra);background:var(--accent-terra-dim);border-color:#c4734f4d}.confirm-delete.confirm-delete{background:var(--accent-red-dim);border-color:#e9456033}.confirm-delete-text.confirm-delete-text{color:var(--accent-red)}.btn-confirm-yes.btn-confirm-yes{background:var(--accent-red);color:#fff}.edit-rating-section{background:var(--bg-elevated)!important;border-color:var(--border-medium)!important}.edit-rating-btns .btn-edit-rating{background:var(--bg-input);color:var(--text-secondary);border-color:var(--border-medium)}.item-detail-notes.item-detail-notes{background:var(--bg-elevated);border-color:var(--border-subtle);color:var(--text-secondary)}.item-detail-notes-label{color:var(--text-muted)!important}.notes-input.notes-input{background:var(--bg-input);border-color:var(--border-medium);color:var(--text-secondary)}.notes-input::placeholder{color:var(--text-faint)!important}.trophy-overlay-card-fallback.trophy-overlay-card-fallback{background:linear-gradient(135deg,#facc1514,#c4734f0f)}.trophy-overlay-gradient.trophy-overlay-gradient{background:linear-gradient(#0000 0%,#0f0f1a66 40%,#0f0f1ae6 100%)}.trophy-photo-empty.trophy-photo-empty{border-color:var(--border-medium);background:var(--bg-elevated);color:var(--text-muted)}.passport-map-overlay.passport-map-overlay{background:var(--bg-primary)}.passport-map-header.passport-map-header{border-bottom-color:var(--border-subtle);background:var(--bg-card)}.passport-map-title.passport-map-title{color:var(--text-primary)}.passport-map-close.passport-map-close{color:var(--text-muted)}.passport-map-close:hover{color:var(--text-primary)}.passport-map-body.passport-map-body{background:var(--bg-primary)}.passport-map-container.passport-map-container{border:1px solid var(--border-subtle);background:#22d3ee0a;box-shadow:inset 0 0 40px #00000026}.passport-map-stat-num.passport-map-stat-num{color:var(--text-primary)}.passport-map-stat-label.passport-map-stat-label,.passport-map-legend-item.passport-map-legend-item,.passport-map-loading.passport-map-loading{color:var(--text-muted)}.passport-map-country-tooltip.passport-map-country-tooltip{background:var(--bg-card);border:1px solid var(--border-medium);box-shadow:0 4px 12px #0006}.passport-detail-hero-overlay.passport-detail-hero-overlay{background:linear-gradient(#0000 20%,#0f0f1acc)}.passport-tabs.passport-tabs{border-color:var(--border-subtle)}.passport-empty-tab.passport-empty-tab{color:var(--text-muted)}.strava-disconnect.strava-disconnect{color:var(--text-faint)}.bb{color:var(--text-primary)!important}.mono{color:var(--text-muted)!important}.event-form-input[type=date]{--lightningcss-light: ;--lightningcss-dark:initial;color-scheme:dark}input[type=text].event-form-input,input[type=date].event-form-input,input.event-form-input{background:var(--bg-input)!important;border-color:var(--border-medium)!important;color:var(--text-primary)!important}.pin-picker-list,.trophy-case-list,.item-detail-sheet{scrollbar-width:thin;scrollbar-color:#ffffff1a transparent}.pin-picker-list::-webkit-scrollbar{width:4px}.trophy-case-list::-webkit-scrollbar{width:4px}.item-detail-sheet::-webkit-scrollbar{width:4px}.pin-picker-list::-webkit-scrollbar-thumb{background:#ffffff1a;border-radius:2px}.trophy-case-list::-webkit-scrollbar-thumb{background:#ffffff1a;border-radius:2px}.item-detail-sheet::-webkit-scrollbar-thumb{background:#ffffff1a;border-radius:2px}.mantl-app.mantl-app{background:var(--bg-primary);color:var(--text-primary)}.main.main,.tab-pane,.screen-fade.screen-fade{background:var(--bg-primary)}.header.header{background:var(--bg-card);border-bottom-color:var(--border-subtle)}.header-brand.header-brand{color:var(--text-primary)}.header-brand-line.header-brand-line{background:var(--accent-green)}.header-tagline.header-tagline{color:var(--text-muted)}.notif-bell.notif-bell:active{background:#ffffff0f}.notif-bell-icon svg{stroke:var(--text-secondary)!important}.notif-bell-badge.notif-bell-badge{background:var(--accent-red);color:#fff;border-color:var(--bg-card)}.header-profile.header-profile{background:var(--bg-elevated);border-color:var(--border-medium);color:var(--accent-terra)}.notif-panel.notif-panel{background:var(--bg-card);box-shadow:-4px 0 24px #0006}.notif-panel-header.notif-panel-header{border-bottom-color:var(--border-subtle)}.notif-panel-title.notif-panel-title{color:var(--text-primary)}.notif-panel-close.notif-panel-close{color:var(--text-muted)}.notif-item.notif-item{border-bottom-color:var(--border-subtle)}.notif-item-avatar.notif-item-avatar{background:var(--bg-elevated)}.notif-item-text.notif-item-text{color:var(--text-secondary)}.notif-item-time.notif-item-time{color:var(--text-faint)}.nav-bar.nav-bar{background:var(--bg-card);border-top-color:var(--border-subtle)}.nav-item.nav-item{color:var(--text-faint)}.fab.fab{color:#0a0a0a;background:linear-gradient(135deg,#4ade80,#22c55e);box-shadow:0 4px 16px #4ade8040}.fab-label.fab-label{color:var(--accent-green)}.modal-overlay.modal-overlay{-webkit-backdrop-filter:blur(6px);background:#000000b3}.modal-sheet.modal-sheet{background:linear-gradient(180deg, var(--bg-card) 0%, var(--bg-card-end) 100%);border:1px solid var(--border-subtle);box-shadow:var(--shadow-modal);border-bottom:none}.modal-handle.modal-handle{background:#ffffff26}.modal-title.modal-title{color:var(--text-primary)}.modal-sub.modal-sub{color:var(--text-muted)}.search-input.search-input{background:var(--bg-input);border-color:var(--border-medium);color:var(--text-primary)}.pill.pill{border-color:var(--border-medium);color:var(--text-muted);background:0 0}.search-result.search-result:hover{background:var(--bg-hover)}.search-result.search-result:active{background:var(--bg-elevated)}.result-poster.result-poster{background:var(--bg-elevated);box-shadow:var(--shadow-poster)}.result-title.result-title{color:var(--text-primary)}.result-meta.result-meta{color:var(--text-muted)}.result-type-badge.result-type-badge{background:var(--accent-terra-dim);color:var(--accent-terra)}.search-placeholder-text.search-placeholder-text{color:var(--text-muted)}.search-loading{color:var(--text-muted)!important}.toast.toast{background:var(--bg-card);color:var(--text-primary);border:1px solid var(--border-subtle);box-shadow:0 4px 16px #0006}.loading-screen.loading-screen{background:var(--bg-primary)}.loading-brand.loading-brand{color:var(--text-primary)}.loading-brand-line.loading-brand-line{background:var(--accent-green)}.loading-spinner.loading-spinner{border-color:var(--border-medium);border-top-color:var(--accent-green)}.skel-shimmer.skel-shimmer{background:linear-gradient(90deg, var(--bg-elevated) 25%, #ffffff08 50%, var(--bg-elevated) 75%);background-size:800px 100%}.skel-surface.skel-surface{background:var(--bg-card);border-color:var(--border-subtle)}.shelf-item-cover.shelf-item-cover{box-shadow:var(--shadow-poster)}.shelf-item-title.shelf-item-title{color:var(--text-primary)}.shelf-item-stars .star-filled{color:var(--accent-gold)!important}.shelf-item-reading-tag.shelf-item-reading-tag{color:var(--accent-green);background:#4ade801f}.shelf-item-progress.shelf-item-progress{background:var(--bg-elevated)}.book-status-toggle.book-status-toggle{border-color:var(--border-medium)}.book-status-btn{background:var(--bg-input)!important;color:var(--text-muted)!important;border-color:var(--border-medium)!important}.book-status-btn.active{background:var(--accent-green)!important;color:#0a0a0a!important;border-color:var(--accent-green)!important}.modal-overlay .modal-sheet input,.modal-overlay .modal-sheet textarea,.modal-overlay .modal-sheet select{background:var(--bg-input);border-color:var(--border-medium);color:var(--text-primary)}.modal-overlay .modal-sheet input:focus,.modal-overlay .modal-sheet textarea:focus,.modal-overlay .modal-sheet select:focus{border-color:#4ade8066}.modal-overlay .modal-sheet input::placeholder,.modal-overlay .modal-sheet textarea::placeholder{color:var(--text-faint)}.modal-sheet,.notif-panel{scrollbar-width:thin;scrollbar-color:#ffffff1a transparent}.modal-sheet::-webkit-scrollbar{width:4px}.notif-panel::-webkit-scrollbar{width:4px}.modal-sheet::-webkit-scrollbar-thumb{background:#ffffff1a;border-radius:2px}.notif-panel::-webkit-scrollbar-thumb{background:#ffffff1a;border-radius:2px}.friends-screen.friends-screen{background:var(--bg-primary)}.friends-header.friends-header{color:var(--text-primary)}.friends-sub.friends-sub{color:var(--text-muted)}.friends-empty.friends-empty{background:var(--bg-card);border-color:var(--border-subtle);box-shadow:var(--shadow-card)}.friends-empty-title.friends-empty-title{color:var(--text-primary)}.friends-empty-text.friends-empty-text{color:var(--text-muted)}.friends-search-input.friends-search-input{background:var(--bg-input);border-color:var(--border-medium);color:var(--text-primary)}.friends-share-row.friends-share-row{background:#ffffff0a}.friends-share-link.friends-share-link{color:var(--text-muted)}.friends-share-btn.friends-share-btn{color:var(--accent-green);border-color:var(--accent-green)}.friends-search-result.friends-search-result{border-bottom-color:var(--border-subtle)}.friends-result-avatar.friends-result-avatar{background:var(--bg-elevated)}.friends-result-name.friends-result-name{color:var(--text-primary)}.friends-result-username.friends-result-username{color:var(--text-faint)}.friends-result-action.pending{border-color:var(--border-medium)!important;color:var(--text-faint)!important}.friends-result-action.accepted{color:var(--accent-green)!important;border-color:var(--accent-green)!important}.friends-section-label.friends-section-label{color:var(--text-faint);border-bottom-color:var(--border-subtle)}.friends-no-results.friends-no-results{color:var(--text-faint)}.feed-card.feed-card{border-bottom-color:var(--border-subtle)}.feed-avatar.feed-avatar{background:var(--bg-elevated)}.feed-action-text.feed-action-text{color:var(--text-secondary)}.feed-action-text strong{color:var(--text-primary)!important}.feed-item-row.feed-item-row{background:var(--bg-card);border-color:var(--border-subtle)}.feed-item-cover.feed-item-cover{background:var(--bg-elevated)}.feed-item-title.feed-item-title{color:var(--text-primary)}.feed-item-meta.feed-item-meta{color:var(--text-faint)}.feed-item-rating.feed-item-rating{color:var(--accent-gold)!important}.feed-loading.feed-loading,.feed-empty.feed-empty{color:var(--text-faint)}.feed-reaction-btn.feed-reaction-btn{border-color:var(--border-medium);background:var(--bg-card)}.feed-reaction-btn.active{background:var(--accent-green-dim)!important;border-color:var(--accent-green)!important}.feed-reaction-count.feed-reaction-count{color:var(--text-muted)}.feed-wishlist-btn.feed-wishlist-btn{border-color:var(--border-medium);background:var(--bg-card);color:var(--text-muted)}.feed-wishlist-btn.added{background:var(--accent-green-dim)!important;border-color:var(--accent-green)!important;color:var(--accent-green)!important}.feed-comments-section.feed-comments-section{background:var(--bg-card);border-color:var(--border-subtle)}.feed-comment.feed-comment{border-bottom-color:var(--border-subtle)}.feed-comment-avatar.feed-comment-avatar{background:var(--bg-elevated)}.feed-comment-name.feed-comment-name{color:var(--text-primary)}.feed-comment-text.feed-comment-text{color:var(--text-secondary)}.feed-comment-time.feed-comment-time{color:var(--text-faint)}.feed-comment-input.feed-comment-input{background:var(--bg-input);border-color:var(--border-medium);color:var(--text-primary)}.feed-comment-input::placeholder{color:var(--text-faint)!important}.feed-comment-send.feed-comment-send{background:var(--accent-green);color:#0a0a0a}.friends-screen .overlay .pin-picker{background:var(--bg-card)!important}.friends-screen .event-form-label{color:var(--text-secondary)!important}.explore-screen.explore-screen{background:var(--bg-primary);color:var(--text-primary)}.profile-screen.profile-screen{background:var(--bg-primary)}.profile-hero.profile-hero{border-color:var(--border-subtle);box-shadow:0 2px 12px #0000004d}.profile-hero-bg.profile-hero-bg{filter:grayscale(20%)brightness(.6)saturate(1.2)}.profile-hero-overlay:not(.has-bg){background:var(--bg-card)}.profile-hero-name{color:var(--text-primary)}.profile-hero-location,.profile-hero-bio,.profile-back.profile-back{color:var(--text-muted)}.profile-big-avatar.profile-big-avatar{background:var(--bg-elevated);border-color:var(--border-medium)}.profile-big-name.profile-big-name{color:var(--text-primary)}.profile-big-handle.profile-big-handle,.profile-bio.profile-bio{color:var(--text-muted)}.profile-card.profile-card{background:var(--bg-card);border-color:var(--border-subtle);box-shadow:var(--shadow-card)}.profile-stats.profile-stats{border-top-color:var(--border-subtle)}.stat-num.stat-num{color:var(--text-primary)}.stat-label.stat-label{color:var(--text-faint)}.share-link-section.share-link-section{background:var(--bg-card);border-color:var(--border-subtle)}.share-link-label.share-link-label{color:var(--text-faint)}.share-link-url.share-link-url{color:var(--accent-green)}.share-link-btn.share-link-btn{background:var(--accent-green);color:#0a0a0a}.settings-section.settings-section{border-top-color:var(--border-subtle)}.settings-label.settings-label{color:var(--text-faint)}.settings-item.settings-item{border-bottom-color:var(--border-subtle)}.settings-item-text.settings-item-text{color:var(--text-secondary)}.settings-item-arrow.settings-item-arrow{color:var(--text-faint)}.edit-profile-form.edit-profile-form{background:#ffffff08}.btn-save-profile.btn-save-profile{background:var(--accent-green);color:#0a0a0a}.shelf-toggle-row.shelf-toggle-row{border-bottom-color:var(--border-subtle)}.shelf-toggle-row.shelf-dragging{background:var(--bg-elevated)!important}.shelf-drag-handle.shelf-drag-handle{color:var(--text-muted)}.shelf-toggle-label.shelf-toggle-label{color:var(--text-secondary)}.shelf-toggle-switch.shelf-toggle-switch{background:var(--border-medium)}.shelf-toggle-permanent.shelf-toggle-permanent{color:var(--text-faint);background:#ffffff0d}.btn-signout.btn-signout{color:#f87171;background:0 0;border-color:#f8717140}.btn-confirm-yes.btn-confirm-yes{color:#fff;background:#ef4444}.btn-confirm-no.btn-confirm-no{background:var(--bg-elevated);color:var(--text-secondary);border-color:var(--border-medium)}.profile-screen .friends-share-btn{color:var(--accent-green);border-color:var(--accent-green)}.profile-screen .event-form-input{background:var(--bg-input);border-color:var(--border-medium);color:var(--text-primary)}.profile-screen .event-form-input:focus{border-color:var(--accent-green)}.profile-screen .event-form-input::placeholder{color:var(--text-faint)}.profile-screen .event-form-label{color:var(--text-secondary)}.profile-screen .event-form-hint{color:var(--text-faint)}.profile-screen .btn-shelf-it{background:var(--accent-green);color:#0a0a0a}.challenge-screen.challenge-screen{background:var(--bg-primary)}.challenge-header.challenge-header{color:var(--text-primary)}.challenge-sub.challenge-sub{color:var(--text-muted)}.challenge-setup-title.challenge-setup-title{color:var(--text-primary)}.challenge-setup-desc.challenge-setup-desc{color:var(--text-muted)}.habit-card.habit-card{background:var(--bg-card);border-color:var(--border-subtle)}.habit-card-name.habit-card-name{color:var(--text-primary)}.habit-card-sub.habit-card-sub{color:var(--text-faint)}.habit-card-check.habit-card-check{border-color:var(--border-medium)}.challenge-counter.challenge-counter{color:var(--text-muted)}.challenge-counter .n{color:var(--accent-green)!important}.challenge-screen .btn-primary{background:var(--accent-green);color:#0a0a0a;box-shadow:0 4px 16px #4ade8026}.ch-tab-bar.ch-tab-bar{background:var(--bg-elevated)}.ch-tab.ch-tab{color:var(--text-muted)}.ch-tab.ch-tab-active{box-shadow:0 1px 3px #0003;background:var(--bg-card)!important;color:var(--text-primary)!important}.challenge-day-nav.challenge-day-nav{color:var(--text-primary)}.challenge-day-weekday.challenge-day-weekday{color:var(--text-faint)}.challenge-day-date.challenge-day-date{color:var(--text-primary)}.challenge-day-of.challenge-day-of{color:var(--text-muted)}.challenge-past-banner.challenge-past-banner{background:#4ade8014}.challenge-progress-bar.challenge-progress-bar{background:var(--bg-elevated)}.challenge-progress-fill.challenge-progress-fill{background:var(--accent-green)}.challenge-done-count.challenge-done-count{color:var(--text-primary)}.challenge-daily-card.challenge-daily-card{background:var(--bg-card);border-color:var(--border-subtle)}.challenge-daily-card.ch-rested{background:#c4a86a1a!important;border-color:#c4a86a!important}.challenge-daily-card.ch-missed{background:#c47a6a1a!important;border-color:#c47a6a!important}.challenge-daily-name.challenge-daily-name{color:var(--text-primary)}.challenge-daily-sub.challenge-daily-sub{color:var(--text-faint)}.challenge-daily-status.challenge-daily-status{border-color:var(--border-medium)}.ch-edit-hint.ch-edit-hint{color:var(--text-faint)}.ch-edit-hint:hover{color:var(--accent-green)!important}.ch-card-wrap.ch-dragging>.challenge-daily-card{border-color:var(--accent-green)!important}.ch-card-wrap.ch-drag-over:before{border-color:var(--accent-green)!important;background:#4ade800a!important}.ch-expand-panel.ch-expand-panel{background:var(--bg-card);border-color:#7a9a6a4d #7a9a6a #7a9a6a}.ch-panel-label.ch-panel-label{color:var(--text-muted)}.ch-input.ch-input{background:var(--bg-input);border-color:var(--border-medium);color:var(--text-primary)}.ch-btn-sm.ch-btn-sm{background:var(--bg-elevated);border-color:var(--border-medium);color:var(--text-secondary)}.ch-book-results.ch-book-results{background:var(--bg-input);border-color:var(--border-medium)}.ch-book-result+.ch-book-result{border-top-color:var(--border-subtle)!important}.ch-book-result-cover.ch-book-result-cover,.ch-book-no-cover.ch-book-no-cover,.ch-book-progress-bar.ch-book-progress-bar,.ch-book-mini-bar.ch-book-mini-bar{background:var(--bg-elevated)}.ch-dash-month.ch-dash-month{color:var(--text-primary)}.ch-dash-days.ch-dash-days{color:var(--text-muted)}.ch-dash-score-card.ch-dash-score-card{background:var(--bg-card);border-color:var(--border-subtle)}.ch-dash-section-label.ch-dash-section-label{color:var(--text-faint)}.ch-dash-tier-row.ch-dash-tier-row{background:var(--bg-elevated)}.ch-dash-tier-row.ch-tier-met{background:#7a9a6a1f!important;border-color:#7a9a6a40!important}.ch-dash-habit-row.ch-dash-habit-row{background:var(--bg-card);border-color:var(--border-subtle)}.ch-dash-habit-bar.ch-dash-habit-bar{background:var(--bg-elevated)}.ch-dash-habit-bar-target.ch-dash-habit-bar-target{background:var(--text-primary)}.ch-share-card.ch-share-card{background:var(--bg-card);border-color:var(--border-subtle)}.ch-share-brand.ch-share-brand{color:var(--text-faint)}.ch-results-tier-name.ch-results-tier-name{color:var(--text-primary)}.ch-results-month.ch-results-month{color:var(--text-muted)}.ch-results-stats-row.ch-results-stats-row{border-color:var(--border-subtle);background:0 0}.ch-results-stat-num.ch-results-stat-num{color:var(--text-primary)}.ch-results-stat-label.ch-results-stat-label{color:var(--text-faint)}.ch-share-footer.ch-share-footer{border-top-color:var(--border-subtle)}.ch-share-habit-bar.ch-share-habit-bar{background:#ffffff14}.ch-share-mode-toggle.ch-share-mode-toggle{background:var(--bg-elevated)}.ch-share-mode.ch-share-mode{color:var(--text-muted)}.ch-share-mode.active{box-shadow:0 1px 4px #0003;background:var(--bg-card)!important;color:var(--text-primary)!important}.ch-results-highlight.ch-results-highlight,.ch-shelf-widget.ch-shelf-widget{background:var(--bg-card);border-color:var(--border-subtle)}.ch-shelf-ring-pct.ch-shelf-ring-pct,.ch-shelf-tier.ch-shelf-tier{color:var(--text-primary)}.ch-shelf-meta.ch-shelf-meta{color:var(--text-muted)}.challenge-active-card.challenge-active-card{background:var(--bg-card);border-color:var(--border-subtle)}.challenge-month-label.challenge-month-label,.challenge-habit-name.challenge-habit-name{color:var(--text-primary)}.challenge-habit-row.challenge-habit-row{border-bottom-color:var(--border-subtle)}.ch-dash-score-ring circle[stroke="var(--cream-dark)"]{stroke:var(--bg-elevated)}.cinema-strip.cinema-strip{box-shadow:none;background:0 0;border-radius:0;padding:4px 0 0}.cinema-strip:before{display:none!important}.cinema-label.cinema-label{letter-spacing:.08em;color:var(--text-primary);font-size:20px}.cinema-count.cinema-count{color:var(--text-faint);font-size:13px}.cinema-add.cinema-add{color:var(--accent-green);font-size:14px}.cinema-add:hover{opacity:.8;color:var(--accent-green)!important}.cinema-header .mono{color:var(--accent-green)}.cinema-cover.cinema-cover{background:#ffffff0a;border-radius:10px;width:140px;height:200px;box-shadow:0 2px 8px #00000040,0 10px 30px #0003}.cinema-item:hover .cinema-cover{transform:translateY(-3px);box-shadow:0 4px 12px #0000004d,0 16px 40px #00000040}.cinema-title.cinema-title{color:#ffffffbf;width:140px;margin-top:10px;font-size:13px}.cinema-stars.cinema-stars{width:140px;font-size:12px}.cinema-tag.cinema-tag{font-size:9px}.cinema-progress.cinema-progress{width:140px}.cinema-items.cinema-items{gap:16px;padding-bottom:4px}.cinema-see-all.cinema-see-all{color:#ffffff59;letter-spacing:.06em;padding:14px 0 4px;font-size:14px}.cinema-empty .shelf-empty-text{color:var(--text-faint)}.cinema-empty .shelf-empty-cta{color:var(--accent-green)}.shelf-add-more.shelf-add-more{border-color:var(--border-subtle);background:0 0;width:140px;height:200px}.shelf-add-more-icon.shelf-add-more-icon,.shelf-add-more-text.shelf-add-more-text{color:var(--text-faint)}.shelf-surface.shelf-surface{box-shadow:none;background:0 0;border:none;min-height:auto;padding:4px 0 0}.shelf-surface:after{display:none!important}.shelf-label.shelf-label{letter-spacing:.08em;color:var(--text-primary);font-size:20px}.shelf-count.shelf-count{color:var(--text-faint)}.shelf-item-cover.shelf-item-cover{background:#ffffff0a;border-radius:10px;width:140px;height:200px;box-shadow:0 2px 8px #00000040,0 10px 30px #0003}.shelf-item-title.shelf-item-title{width:140px;color:var(--text-secondary);margin-top:10px;font-size:13px}.shelf-item-stars.shelf-item-stars{width:140px;color:var(--accent-gold)}.shelf-item-progress.shelf-item-progress{background:var(--bg-elevated);width:140px}.shelf-item-progress-fill.shelf-item-progress-fill{background:var(--accent-green)}.shelf-item-reading-tag.shelf-item-reading-tag{color:var(--accent-green)}.shelf-items.shelf-items{gap:16px}.shelf-empty-cta.shelf-empty-cta,.shelf-add-btn.shelf-add-btn{color:var(--accent-green)}.shelf-add-btn:hover{opacity:.8;color:var(--accent-green)!important}*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--cream:#f0ebe1;--cream-dark:#e8e2d6;--warm-white:#fdfbf7;--terracotta:#c4734f;--terra-light:#d4896a;--terra-glow:#c4734f1f;--sage:#8b9e7e;--sage-light:#a8b89d;--wood:#8b6f4e;--wood-dark:#6b5540;--charcoal:#2c2824;--text:#2c2824;--text-dim:#7a7269;--text-faint:#b5aea4;--border:#2c282414;--border-med:#2c282421;--card:#fdfbf7;--shadow:#2c28240f;--shadow-med:#2c28241f}html,body{background:var(--cream,#f0ebe1);min-height:100vh;min-height:-webkit-fill-available;margin:0;padding:0}#root{width:100%;min-height:100vh}.mantl-app{min-height:100vh;background:var(--cream);min-height:-webkit-fill-available;color:var(--text);-webkit-tap-highlight-color:transparent;width:100%;max-width:430px;padding-top:env(safe-area-inset-top);padding-bottom:env(safe-area-inset-bottom);margin:0 auto;font-family:Lora,serif;position:relative;overflow-x:hidden}.bb{font-family:Barlow Condensed,sans-serif}.mono{font-family:IBM Plex Mono,monospace}.landing{background:var(--cream);flex-direction:column;min-height:100vh;padding:0 32px;display:flex;position:relative;overflow:hidden auto}.landing-hero{flex-direction:column;min-height:100vh;display:flex;position:relative}.landing-glow{background:radial-gradient(circle, var(--terra-glow) 0%, transparent 70%);pointer-events:none;width:300px;height:300px;position:absolute;top:20%;left:50%;transform:translate(-50%,-50%)}.landing-top{z-index:1;flex-direction:column;flex:1;justify-content:center;display:flex;position:relative}.landing-eyebrow{letter-spacing:.25em;color:var(--terracotta);text-transform:uppercase;opacity:0;margin-bottom:20px;font-family:IBM Plex Mono,monospace;font-size:11px;animation:.6s .1s forwards fadeUp}.landing-wordmark{letter-spacing:.02em;color:var(--charcoal);text-transform:uppercase;opacity:0;font-family:Barlow Condensed,sans-serif;font-size:88px;font-weight:900;line-height:.85;animation:10ms .2s forwards fadeIn;position:relative}.landing-shelf-letters{padding-bottom:4px;display:inline-flex;overflow:hidden}.shelf-letter{opacity:0;animation:.6s cubic-bezier(.22,1,.36,1) forwards shelfRise;display:inline-block;transform:translateY(110%)}@keyframes shelfRise{0%{opacity:0;transform:translateY(110%)}30%{opacity:1}85%{transform:translateY(-8%)}to{opacity:1;transform:translateY(0%)}}.landing-wordmark-line{background:var(--terracotta);border-radius:2px;width:100%;height:4px;margin-top:6px;display:block}.landing-tagline{color:var(--text-dim);opacity:0;margin-top:24px;font-family:Lora,serif;font-size:18px;font-style:italic;line-height:1.5;animation:.7s .4s forwards fadeUp}.landing-bottom{z-index:1;opacity:0;padding-bottom:56px;animation:.7s .6s forwards fadeUp;position:relative}.btn-primary{background:var(--terracotta);width:100%;color:var(--warm-white);letter-spacing:.12em;text-transform:uppercase;cursor:pointer;border:none;border-radius:12px;padding:18px;font-family:Barlow Condensed,sans-serif;font-size:18px;font-weight:700;transition:opacity .15s,transform .1s;box-shadow:0 4px 16px #c4734f40}.btn-primary:hover{opacity:.9}.btn-primary:active{transform:scale(.98)}.landing-footer{text-align:center;color:var(--text-faint);letter-spacing:.1em;margin-top:16px;font-family:IBM Plex Mono,monospace;font-size:10px}.landing-footer a{color:var(--terracotta);text-decoration:none}.landing-learn-more{text-align:center;opacity:0;margin-top:20px;animation:.7s .8s forwards fadeUp}.landing-learn-more span{letter-spacing:.15em;color:var(--text-faint);cursor:pointer;font-family:IBM Plex Mono,monospace;font-size:12px;transition:color .2s}.landing-learn-more span:hover{color:var(--terracotta)}.landing-learn-more-arrow{color:var(--terracotta);margin-top:6px;font-size:18px;animation:2s 1.5s infinite bounce;display:block}@keyframes bounce{0%,to{transform:translateY(0)}50%{transform:translateY(6px)}}.landing-features{padding:40px 0 60px}.landing-features-title{text-transform:uppercase;letter-spacing:.04em;color:var(--charcoal);text-align:center;margin-bottom:8px;font-family:Barlow Condensed,sans-serif;font-size:28px;font-weight:800}.landing-features-sub{color:var(--text-dim);text-align:center;margin-bottom:32px;font-family:Lora,serif;font-size:14px;font-style:italic}.feature-card{opacity:0;border:1px solid var(--border);background:#fff;border-radius:16px;margin-bottom:16px;padding:24px;transition:opacity .5s,transform .5s;transform:translateY(30px);box-shadow:0 2px 12px #2c24200f}.feature-card.visible{opacity:1;transform:translateY(0)}.feature-card-icon{margin-bottom:10px;font-size:28px}.feature-card-title{text-transform:uppercase;letter-spacing:.05em;color:var(--charcoal);margin-bottom:6px;font-family:Barlow Condensed,sans-serif;font-size:18px;font-weight:700}.feature-card-desc{color:var(--text-dim);font-family:Lora,serif;font-size:13px;line-height:1.6}.feature-shelf-demo{align-items:flex-end;gap:6px;height:50px;margin-top:14px;display:flex;overflow:hidden}.feature-shelf-item{cursor:pointer;border-radius:4px;transition:transform .3s}.feature-shelf-item:hover{transform:translateY(-4px)}.feature-passport-dots{flex-wrap:wrap;gap:6px;margin-top:14px;display:flex}.feature-passport-dot{background:var(--cream-dark);cursor:pointer;border-radius:50%;justify-content:center;align-items:center;width:30px;height:30px;transition:transform .2s;display:flex;overflow:hidden}.feature-passport-dot:hover{transform:scale(1.2)}.landing-cta-bottom{text-align:center;padding:20px 0 40px}.landing-cta-bottom .btn-primary{max-width:300px;margin:0 auto}.challenge-screen{padding:24px 20px 120px}.challenge-header{text-transform:uppercase;letter-spacing:.04em;color:var(--charcoal);font-family:Barlow Condensed,sans-serif;font-size:26px;font-weight:800}.challenge-sub{color:var(--text-dim);margin:4px 0 20px;font-family:Lora,serif;font-size:14px;font-style:italic}.challenge-setup{text-align:center;padding:40px 0}.challenge-setup-icon{margin-bottom:16px;font-size:48px}.challenge-setup-title{text-transform:uppercase;color:var(--charcoal);margin-bottom:8px;font-family:Barlow Condensed,sans-serif;font-size:22px;font-weight:800}.challenge-setup-desc{color:var(--text-dim);margin-bottom:24px;font-family:Lora,serif;font-size:13px;line-height:1.6}.habit-select-grid{flex-direction:column;gap:10px;margin-bottom:20px;display:flex}.habit-card{border:1.5px solid var(--border);cursor:pointer;background:#fff;border-radius:12px;align-items:center;gap:14px;padding:14px 16px;transition:border-color .15s,background .15s;display:flex}.habit-card.selected{border-color:var(--terracotta);background:#c4734f0a}.habit-card-icon{text-align:center;flex-shrink:0;width:32px;font-size:22px}.habit-card-info{flex:1;min-width:0}.habit-card-name{text-transform:uppercase;letter-spacing:.03em;color:var(--charcoal);font-family:Barlow Condensed,sans-serif;font-size:15px;font-weight:700}.habit-card-sub{color:var(--text-faint);letter-spacing:.05em;font-family:IBM Plex Mono,monospace;font-size:10px}.habit-card-check{border:2px solid var(--border);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:22px;height:22px;transition:border-color .15s,background .15s;display:flex}.habit-card.selected .habit-card-check{border-color:var(--terracotta);background:var(--terracotta)}.habit-card-check-dot{background:#fff;border-radius:50%;width:8px;height:8px}@keyframes slideInRight{0%{opacity:0;transform:translate(40px)}to{opacity:1;transform:translate(0)}}@keyframes slideInLeft{0%{opacity:0;transform:translate(-40px)}to{opacity:1;transform:translate(0)}}@keyframes beatPop{0%{transform:scale(1)}30%{transform:scale(1.35)}50%{transform:scale(.9)}70%{transform:scale(1.15)}to{transform:scale(1)}}@keyframes beatFade{0%{opacity:1}50%{opacity:.5}to{opacity:.65}}.beat-pop{animation:.4s ease-out beatPop}.beat-fade{animation:.3s ease-out forwards beatFade}.habit-slide-in{animation:.25s ease-out slideInRight}.habit-slide-back{animation:.25s ease-out slideInLeft}.challenge-counter{color:var(--text-dim);text-align:center;margin-bottom:16px;font-family:IBM Plex Mono,monospace;font-size:13px}.challenge-counter .n{color:var(--terracotta);font-weight:700}.challenge-active-card{border:1px solid var(--border);background:#fff;border-radius:16px;margin-bottom:16px;padding:20px;box-shadow:0 2px 12px #2c24200f}.challenge-month-label{text-transform:uppercase;color:var(--charcoal);margin-bottom:4px;font-family:Barlow Condensed,sans-serif;font-size:20px;font-weight:800}.challenge-day-label{color:var(--text-faint);letter-spacing:.05em;margin-bottom:16px;font-family:IBM Plex Mono,monospace;font-size:12px}.challenge-habit-row{border-bottom:1px solid var(--border);align-items:center;gap:10px;padding:8px 0;display:flex}.challenge-habit-row:last-child{border-bottom:none}.challenge-habit-icon{text-align:center;width:28px;font-size:18px}.challenge-habit-name{color:var(--charcoal);flex:1;font-family:Barlow Condensed,sans-serif;font-size:14px;font-weight:600}.challenge-progress-bar{background:var(--cream-dark);border-radius:3px;height:6px;margin-top:16px;overflow:hidden}.challenge-progress-fill{background:var(--terracotta);border-radius:3px;height:100%;transition:width .3s}.challenge-day-header{justify-content:space-between;align-items:center;margin-bottom:16px;display:flex}.challenge-day-nav{color:var(--charcoal);cursor:pointer;-webkit-tap-highlight-color:transparent;background:0 0;border:none;padding:8px 12px;font-size:28px}.challenge-day-center{text-align:center;flex:1}.challenge-day-weekday{color:var(--text-faint);letter-spacing:.1em;text-transform:uppercase;font-size:11px}.challenge-day-date{text-transform:uppercase;color:var(--charcoal);font-size:24px;font-weight:800}.challenge-day-of{color:var(--text-dim);letter-spacing:.05em;font-size:11px}.challenge-past-banner{cursor:pointer;background:#c4734f14;border-radius:8px;justify-content:space-between;align-items:center;margin-bottom:12px;padding:8px 14px;font-size:11px;display:flex}.challenge-progress-row{align-items:center;gap:12px;margin-bottom:16px;display:flex}.challenge-done-count{color:var(--charcoal);white-space:nowrap;font-size:16px;font-weight:700}.challenge-habit-list{flex-direction:column;gap:8px;display:flex}.challenge-daily-card{border:1.5px solid var(--border);cursor:pointer;-webkit-tap-highlight-color:transparent;background:#fff;border-radius:14px;align-items:center;gap:14px;padding:16px;transition:all .2s;display:flex;position:relative;overflow:hidden}.challenge-daily-card:active{transform:scale(.98)}.ch-card-wrap.ch-dragging{z-index:10;position:relative}.ch-card-wrap.ch-dragging>.challenge-daily-card{opacity:.95;border-color:var(--terracotta);touch-action:none;transition:transform .15s,box-shadow .15s;transform:scale(1.03);box-shadow:0 8px 24px #0000002e}.ch-card-wrap.ch-dragging>.challenge-daily-card:active{transform:scale(1.03)}.ch-card-wrap.ch-drag-over{padding-top:60px;transition:padding .2s}.ch-card-wrap.ch-drag-over:before{content:"";border:2px dashed var(--terracotta);opacity:.6;background:#c4734f0a;border-radius:12px;height:50px;position:absolute;top:4px;left:4px;right:4px}.challenge-daily-card.ch-done{background:#7a9a6a0f;border-color:#7a9a6a}.challenge-daily-card.ch-rested{opacity:.7;background:#c4a86a0f;border-color:#c4a86a}.challenge-daily-card.ch-missed{opacity:.7;background:#c47a6a0f;border-color:#c47a6a}.challenge-daily-icon{text-align:center;flex-shrink:0;width:36px;font-size:24px}.challenge-daily-info{flex:1;min-width:0}.challenge-daily-name{text-transform:uppercase;letter-spacing:.03em;color:var(--charcoal);align-items:center;gap:6px;font-family:Barlow Condensed,sans-serif;font-size:16px;font-weight:700;display:flex}.ch-edit-hint{color:var(--text-faint);opacity:0;cursor:pointer;padding:2px 4px;font-size:11px;transition:opacity .2s}.challenge-daily-card:hover .ch-edit-hint,.ch-card-wrap:active .ch-edit-hint{opacity:.5}.ch-edit-hint:hover{color:var(--terracotta);opacity:1!important}@media (hover:none){.ch-edit-hint{opacity:.35}}.challenge-daily-sub{color:var(--text-faint);letter-spacing:.04em;margin-top:2px;font-family:IBM Plex Mono,monospace;font-size:10px}.challenge-daily-status{border:2px solid var(--border);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:28px;height:28px;transition:all .15s;display:flex}.ch-done .challenge-daily-status{background:#7a9a6a;border-color:#7a9a6a}.ch-rested .challenge-daily-status{background:#c4a86a;border-color:#c4a86a}.ch-missed .challenge-daily-status{background:#c47a6a;border-color:#c47a6a}.ch-check-dot{background:#fff;border-radius:50%;width:10px;height:10px}.ch-rest-mark{color:#fff;font-size:18px;font-weight:800;line-height:1}.ch-miss-mark{color:#fff;font-size:12px;font-weight:700}.ch-overlay-label{letter-spacing:.15em;color:#c4a86a;font-size:9px;font-weight:600;position:absolute;right:60px}.ch-missed-label{color:#c47a6a}.challenge-all-done{text-align:center;text-transform:uppercase;letter-spacing:.05em;color:#7a9a6a;margin-top:12px;padding:16px;font-family:Barlow Condensed,sans-serif;font-size:16px;font-weight:700}.ch-card-wrap{position:relative}.ch-card-wrap.ch-expanded .challenge-daily-card{border-bottom:none;border-bottom-right-radius:0;border-bottom-left-radius:0}.ch-expand-panel{background:#fff;border:1.5px solid #7a9a6a;border-top:1px solid #7a9a6a33;border-radius:0 0 14px 14px;margin-top:-1px}.ch-panel-inner{flex-direction:column;gap:8px;padding:14px 16px 16px;display:flex}.ch-panel-label{color:var(--text-dim);letter-spacing:.05em;margin-bottom:2px;font-size:11px}.ch-input{border:1px solid var(--border);background:var(--warm-white);width:100%;color:var(--charcoal);box-sizing:border-box;border-radius:8px;outline:none;padding:10px 12px;font-size:13px}.ch-input:focus{border-color:var(--terracotta)}.ch-btn-sm{background:var(--cream-dark);border:1px solid var(--border);color:var(--charcoal);cursor:pointer;border-radius:8px;padding:8px 14px;font-family:IBM Plex Mono,monospace;font-size:11px}.ch-book-results{border:1px solid var(--border);background:var(--warm-white);border-radius:10px;flex-direction:column;gap:2px;max-height:220px;display:flex;overflow-y:auto}.ch-book-result{cursor:pointer;-webkit-tap-highlight-color:transparent;align-items:center;gap:10px;padding:10px 12px;display:flex}.ch-book-result:active{background:#c4734f0f}.ch-book-result+.ch-book-result{border-top:1px solid var(--border)}.ch-book-result-cover{object-fit:cover;background:var(--cream-dark);border-radius:3px;flex-shrink:0;width:32px;height:46px}.ch-book-no-cover{justify-content:center;align-items:center;font-size:18px;display:flex}.ch-book-result-info{flex:1;min-width:0}.ch-book-mini-bar{background:var(--cream-dark);border-radius:2px;width:80%;height:3px;margin-top:4px}.ch-book-mini-fill{background:#7a9a6a;border-radius:2px;height:100%;transition:width .3s}.ch-book-progress-bar{background:var(--cream-dark);border-radius:3px;height:6px;margin-bottom:4px;overflow:hidden}.ch-book-progress-fill{background:#7a9a6a;border-radius:3px;height:100%;transition:width .3s}.ch-tab-bar{background:var(--cream-dark);border-radius:10px;gap:0;margin-bottom:16px;padding:3px;display:flex}.ch-tab{text-transform:uppercase;letter-spacing:.05em;color:var(--text-dim);cursor:pointer;-webkit-tap-highlight-color:transparent;background:0 0;border:none;border-radius:8px;flex:1;padding:8px;font-family:Barlow Condensed,sans-serif;font-size:13px;font-weight:700;transition:all .2s}.ch-tab.ch-tab-active{color:var(--charcoal);background:#fff;box-shadow:0 1px 3px #00000014}.ch-dash-header{text-align:center;margin-bottom:16px}.ch-dash-month{text-transform:uppercase;color:var(--charcoal);font-size:22px;font-weight:800}.ch-dash-days{color:var(--text-dim);letter-spacing:.05em;margin-top:2px;font-size:11px}.ch-dash-score-card{border:1.5px solid var(--border);background:#fff;border-radius:14px;align-items:center;gap:20px;margin-bottom:16px;padding:20px;display:flex}.ch-dash-score-ring{flex-shrink:0;position:relative}.ch-dash-score-pct{justify-content:center;align-items:center;display:flex;position:absolute;inset:0}.ch-dash-score-info{flex:1}.ch-dash-tiers{flex-direction:column;gap:4px;margin-bottom:20px;display:flex}.ch-dash-tier-row{background:var(--cream-dark);opacity:.5;border-radius:8px;align-items:center;gap:8px;padding:8px 12px;display:flex}.ch-dash-tier-row.ch-tier-met{opacity:1;background:#7a9a6a1a;border:1px solid #7a9a6a33}.ch-dash-section-label{letter-spacing:.15em;color:var(--text-faint);margin-bottom:10px;font-size:10px}.ch-dash-habit-list{flex-direction:column;gap:14px;display:flex}.ch-dash-habit-row{border:1px solid var(--border);background:#fff;border-radius:12px;padding:14px 16px}.ch-dash-habit-bar{background:var(--cream-dark);border-radius:4px;height:8px;position:relative;overflow:visible}.ch-dash-habit-bar-fill{border-radius:4px;height:100%;transition:width .5s}.ch-dash-habit-bar-target{background:var(--charcoal);opacity:.3;border-radius:1px;width:2px;position:absolute;top:-2px;bottom:-2px;left:100%}.ch-shelf-widget{border:1.5px solid var(--border);cursor:pointer;-webkit-tap-highlight-color:transparent;background:#fff;border-radius:14px;align-items:center;gap:16px;padding:16px;display:flex}.ch-shelf-widget:active{transform:scale(.98)}.ch-shelf-ring{flex-shrink:0;position:relative}.ch-shelf-ring-pct{color:var(--charcoal);justify-content:center;align-items:center;font-size:14px;display:flex;position:absolute;inset:0}.ch-shelf-info{flex:1;min-width:0}.ch-shelf-tier{text-transform:uppercase;color:var(--charcoal);font-size:16px}.ch-shelf-meta{color:var(--text-dim);letter-spacing:.03em;margin-top:2px;font-size:10px}.ch-shelf-habits{gap:4px;margin-top:6px;font-size:16px;display:flex}.ch-share-card{background:var(--cream);border:1.5px solid var(--border);border-radius:20px;padding:28px 24px 20px;position:relative;overflow:hidden}.ch-share-brand{text-align:center;letter-spacing:.2em;color:var(--text-faint);margin-bottom:16px;font-size:9px}.ch-share-habits{flex-direction:column;gap:8px;margin-bottom:16px;display:flex}.ch-share-habit-row{align-items:center;gap:8px;display:flex}.ch-share-habit-bar{background:#2c24200f;border-radius:3px;flex-shrink:0;width:60px;height:6px;overflow:hidden}.ch-share-habit-bar-fill{border-radius:3px;height:100%;transition:width .5s}.ch-share-footer{text-align:center;border-top:1px solid var(--border);flex-direction:column;gap:4px;padding-top:14px;display:flex}.ch-share-actions{margin-top:12px;margin-bottom:20px}.ch-share-mode-toggle{background:var(--cream-dark);border-radius:10px;margin-bottom:12px;padding:3px;display:flex}.ch-share-mode{letter-spacing:.06em;color:var(--text-dim);cursor:pointer;background:0 0;border:none;border-radius:8px;flex:1;padding:8px;font-family:IBM Plex Mono,monospace;font-size:11px;transition:all .2s}.ch-share-mode.active{color:var(--charcoal);background:#fff;font-weight:700;box-shadow:0 1px 4px #00000014}.ch-share-overlay-hint{text-align:center;color:var(--text-faint);letter-spacing:.04em;margin-bottom:10px;font-size:10px}.ch-results-hero{text-align:center;margin-bottom:16px}.ch-results-tier-icon{margin-bottom:4px;font-size:48px}.ch-results-month{text-transform:uppercase;letter-spacing:.1em;color:var(--text-dim);font-size:13px}.ch-results-tier-name{text-transform:uppercase;color:var(--charcoal);margin-top:2px;font-size:28px;font-weight:800}.ch-results-ring-wrap{width:110px;height:110px;margin:0 auto 14px;position:relative}.ch-results-ring-label{flex-direction:column;justify-content:center;align-items:center;display:flex;position:absolute;inset:0}.ch-results-stats-row{border:1.5px solid var(--border);background:#fff;border-radius:14px;justify-content:space-around;margin-bottom:16px;padding:16px;display:flex}.ch-results-stat{text-align:center}.ch-results-stat-num{color:var(--charcoal);font-size:22px;font-weight:800}.ch-results-stat-label{letter-spacing:.08em;color:var(--text-faint);margin-top:2px;font-size:9px}.ch-results-highlights{gap:10px;margin-bottom:16px;display:flex}.ch-results-highlight{border:1px solid var(--border);background:#fff;border-radius:12px;flex:1;align-items:center;gap:10px;padding:12px;display:flex}.setup-screen{background:var(--cream);flex-direction:column;min-height:100vh;padding:80px 32px 48px;display:flex}.setup-title{text-transform:uppercase;letter-spacing:.02em;color:var(--charcoal);margin-bottom:8px;font-family:Barlow Condensed,sans-serif;font-size:44px;font-weight:900}.setup-sub{color:var(--text-dim);margin-bottom:40px;font-family:Lora,serif;font-size:15px;font-style:italic;line-height:1.5}.field-label{letter-spacing:.2em;color:var(--terracotta);text-transform:uppercase;margin-bottom:10px;font-family:IBM Plex Mono,monospace;font-size:10px;display:block}.field-input{background:var(--warm-white);border:1px solid var(--border-med);width:100%;color:var(--charcoal);border-radius:10px;outline:none;padding:14px 16px;font-family:Lora,serif;font-size:17px;transition:border-color .15s}.field-input::placeholder{color:var(--text-faint)}.field-input:focus{border-color:var(--terracotta)}.field-hint{color:var(--text-faint);margin-top:8px;font-family:IBM Plex Mono,monospace;font-size:11px}.field-error{color:#c45043;margin-top:8px;font-family:IBM Plex Mono,monospace;font-size:11px}.setup-spacer{flex:1}.main{background:var(--cream);flex:1;position:relative;overflow:hidden}.tab-slider{will-change:left;height:100%;display:flex;position:relative}.tab-slider.animating{transition:left .3s cubic-bezier(.4,0,.2,1)}.tab-pane{-webkit-overflow-scrolling:touch;flex-shrink:0;width:100%;min-width:100%;padding-bottom:80px;overflow:hidden auto}.profile-wrap{animation:.3s cubic-bezier(.2,.9,.3,1) profileSlideUp}@keyframes profileSlideUp{0%{opacity:0;transform:translateY(40px)}to{opacity:1;transform:translateY(0)}}.screen-fade{flex-direction:column;height:100dvh;animation:.35s screenFade;display:flex;overflow:hidden}@keyframes screenFade{0%{opacity:0}to{opacity:1}}.header{-webkit-backdrop-filter:blur(16px);z-index:50;border-bottom:1px solid var(--border);background:#f0ebe1eb;flex-shrink:0;align-items:center;gap:12px;padding:16px 20px 12px;display:flex}.header-brand{letter-spacing:.08em;text-transform:uppercase;color:var(--charcoal);font-family:Barlow Condensed,sans-serif;font-size:26px;font-weight:900;display:inline-block;position:relative}.header-brand-line{background:var(--terracotta);border-radius:1.5px;height:3px;position:absolute;bottom:-2px;left:0;right:0}.header-tagline{letter-spacing:.12em;text-transform:uppercase;color:var(--text-faint);margin-top:4px;font-family:IBM Plex Mono,monospace;font-size:8px}.notif-bell{cursor:pointer;-webkit-tap-highlight-color:transparent;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:40px;height:40px;transition:background .15s;display:flex;position:relative}.notif-bell:active{background:#2c24200f}.notif-bell-icon{justify-content:center;align-items:center;line-height:1;display:flex}.notif-bell-icon svg{width:20px;height:20px;stroke:var(--charcoal);fill:none;stroke-width:1.5px;stroke-linecap:round;stroke-linejoin:round}.notif-bell-badge{background:var(--terracotta);min-width:14px;height:14px;color:var(--cream);border:1.5px solid var(--cream);border-radius:7px;justify-content:center;align-items:center;padding:0 3px;font-family:IBM Plex Mono,monospace;font-size:8px;font-weight:700;line-height:1;display:flex;position:absolute;top:6px;right:6px}.notif-panel{background:var(--cream);z-index:300;flex-direction:column;width:min(380px,100vw);animation:.2s notifSlideIn;display:flex;position:fixed;top:0;bottom:0;right:0;box-shadow:-4px 0 24px #0000001f}@keyframes notifSlideIn{0%{transform:translate(100%)}to{transform:translate(0)}}.notif-panel-header{border-bottom:1px solid var(--border);flex-shrink:0;justify-content:space-between;align-items:center;padding:16px 20px 12px;display:flex}.notif-panel-title{text-transform:uppercase;letter-spacing:.04em;color:var(--charcoal);font-family:Barlow Condensed,sans-serif;font-size:18px;font-weight:800}.notif-panel-close{cursor:pointer;color:var(--text-dim);padding:4px 8px;font-size:18px}.notif-item{border-bottom:1px solid var(--border);align-items:center;gap:12px;padding:12px 20px;transition:background .1s;display:flex}.notif-item.unread{background:#c4734f0a}.notif-item-avatar{background:var(--sage);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:34px;height:34px;font-size:14px;display:flex;overflow:hidden}.notif-item-avatar img{object-fit:cover;width:100%;height:100%}.notif-item-text{min-width:0;color:var(--charcoal);flex:1;font-family:Lora,serif;font-size:13px;line-height:1.35}.notif-item-time{color:var(--text-faint);flex-shrink:0;font-family:IBM Plex Mono,monospace;font-size:9px}.notif-item-cover{object-fit:cover;border-radius:3px;flex-shrink:0;width:34px;height:50px}.header-profile{background:var(--terra-glow);border:2px solid var(--border-med);width:34px;height:34px;color:var(--terracotta);cursor:pointer;border-radius:50%;justify-content:center;align-items:center;font-family:Barlow Condensed,sans-serif;font-size:15px;font-weight:800;transition:border-color .15s;display:flex;overflow:hidden}.header-profile:hover{border-color:var(--terracotta)}.header-avatar-wrap{cursor:pointer;-webkit-tap-highlight-color:transparent;flex-shrink:0;position:relative}.header-avatar-badge{background:var(--terracotta);min-width:16px;height:16px;color:var(--cream);border:2px solid var(--cream);border-radius:8px;justify-content:center;align-items:center;padding:0 4px;font-family:IBM Plex Mono,monospace;font-size:9px;font-weight:700;line-height:1;display:flex;position:absolute;top:-2px;right:-4px}.shelf-home{padding:20px 18px}.shelf-order-wrap{flex-direction:column;display:flex}.profile-card{background:linear-gradient(180deg, var(--card) 0%, #faf7f1 100%);border:1px solid #2c28241a;border-radius:16px;margin-bottom:24px;padding:24px;box-shadow:0 1px 3px #2c28240f,0 4px 12px #2c28240f,0 12px 32px #2c28240a}.profile-hero{border:1px solid #2c28241a;border-radius:16px;min-height:100px;margin-bottom:24px;position:relative;overflow:hidden;box-shadow:0 1px 3px #2c28240f,0 4px 12px #2c28240f,0 12px 32px #2c28240a}.profile-hero-bg{filter:grayscale()brightness(.45);background-position:50%;background-size:cover;animation:.4s heroBgFade;position:absolute;inset:0}@keyframes heroBgFade{0%{opacity:0}to{opacity:1}}.profile-hero-overlay{z-index:1;background:var(--card);padding:18px 20px;position:relative}.profile-hero-overlay.has-bg{background:0 0}.profile-hero-row{align-items:center;gap:16px;display:flex}.profile-hero-name{color:var(--charcoal);letter-spacing:.04em;text-transform:uppercase;font-family:Barlow Condensed,sans-serif;font-size:34px;font-weight:900}.has-bg .profile-hero-name{color:#fff;text-shadow:0 2px 12px #00000080}.profile-hero-location{color:var(--text-faint);letter-spacing:.02em;margin-top:-2px;font-family:Lora,serif;font-size:12px;font-style:italic}.has-bg .profile-hero-location{color:#ffffffd9;text-shadow:0 1px 6px #0006}.profile-hero-bio{color:var(--text-dim);margin-top:12px;font-family:Lora,serif;font-size:13px;font-style:italic}.has-bg .profile-hero-bio{color:#fffc;text-shadow:0 1px 6px #0006}.has-bg .profile-avatar{border-color:#fff9;box-shadow:0 2px 8px #0000004d}.profile-row{align-items:center;gap:16px;display:flex}.profile-avatar{background:var(--terra-glow);border:2px solid var(--border-med);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:76px;height:76px;font-size:28px;display:flex;overflow:hidden}.profile-avatar img{object-fit:cover;width:100%;height:100%}.profile-name{color:var(--charcoal);letter-spacing:.02em;font-family:Barlow Condensed,sans-serif;font-size:24px;font-weight:700}.profile-handle{color:var(--text-dim);margin-top:2px;font-family:IBM Plex Mono,monospace;font-size:12px}.profile-stats{border-top:1px solid var(--border);gap:20px;margin-top:20px;padding-top:16px;display:flex}.stat{text-align:center;flex:1}.stat-num{color:var(--charcoal);font-family:Barlow Condensed,sans-serif;font-size:28px;font-weight:800}.stat-label{letter-spacing:.15em;text-transform:uppercase;color:var(--text-faint);margin-top:2px;font-family:IBM Plex Mono,monospace;font-size:9px}.shelf-section{margin-bottom:32px}.shelf-label-row{justify-content:space-between;align-items:center;margin-bottom:12px;display:flex}.shelf-label{letter-spacing:.05em;text-transform:uppercase;color:var(--charcoal);align-items:center;gap:8px;font-family:Barlow Condensed,sans-serif;font-size:22px;font-weight:800;display:flex}.shelf-count{color:var(--text-faint);font-family:IBM Plex Mono,monospace;font-size:12px;font-weight:500}.shelf-surface{background:linear-gradient(180deg, var(--card) 0%, #faf7f1 100%);border:1px solid #2c28241a;border-radius:16px;min-height:100px;padding:20px;position:relative;box-shadow:0 1px 3px #2c28240f,0 4px 12px #2c28240f,0 12px 32px #2c28240a}.shelf-surface:after{content:"";background:linear-gradient(180deg, var(--wood), var(--wood-dark));border-radius:0 0 16px 16px;height:6px;position:absolute;bottom:0;left:0;right:0}.shelf-empty{flex-direction:column;justify-content:center;align-items:center;padding:16px 0;display:flex}.shelf-empty-icon{opacity:.5;margin-bottom:8px;font-size:28px}.shelf-empty-text{color:var(--text-faint);text-align:center;font-family:Lora,serif;font-size:14px;font-style:italic}.shelf-empty-cta{color:var(--terracotta);cursor:pointer;letter-spacing:.05em;margin-top:8px;font-family:IBM Plex Mono,monospace;font-size:11px}.shelf-items{scrollbar-width:none;-ms-overflow-style:none;-webkit-overflow-scrolling:touch;gap:14px;padding-bottom:8px;display:flex;overflow-x:auto}.shelf-items::-webkit-scrollbar{display:none}.shelf-item{cursor:pointer;flex-shrink:0;transition:transform .2s cubic-bezier(.25,.46,.45,.94)}.shelf-item:active{transform:scale(.95)}.shelf-item-cover{background:var(--cream-dark);border-radius:8px;width:100px;height:142px;transition:transform .25s cubic-bezier(.25,.46,.45,.94),box-shadow .25s;box-shadow:0 2px 4px #2c28241a,0 6px 16px #2c28241f,0 1px 2px #2c28240f}.shelf-item-title{color:var(--charcoal);text-overflow:ellipsis;white-space:nowrap;width:100px;margin-top:8px;font-family:Barlow Condensed,sans-serif;font-size:12.5px;font-weight:600;line-height:1.2;overflow:hidden}.cinema-section{margin-bottom:32px}.cinema-header{justify-content:space-between;align-items:center;margin-bottom:12px;display:flex}.cinema-label{letter-spacing:.05em;text-transform:uppercase;color:var(--charcoal);align-items:center;gap:8px;font-family:Barlow Condensed,sans-serif;font-size:22px;font-weight:800;display:flex}.cinema-count{color:var(--text-faint);font-family:IBM Plex Mono,monospace;font-size:12px;font-weight:500}.cinema-add{letter-spacing:.04em;color:var(--terracotta);cursor:pointer;font-family:Barlow Condensed,sans-serif;font-size:13px;font-weight:700;transition:color .15s}.cinema-add:hover{color:var(--terra-light)}.cinema-strip{background:linear-gradient(#1a1a2e 0%,#12121f 100%);border-radius:16px;padding:18px 16px 14px;position:relative;overflow:hidden;box-shadow:0 2px 8px #00000026,0 8px 24px #0000001a}.cinema-strip:before{content:"";opacity:.03;pointer-events:none;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");border-radius:16px;position:absolute;inset:0}.cinema-empty{flex-direction:column;justify-content:center;align-items:center;padding:24px 0;display:flex}.cinema-items{scrollbar-width:none;-ms-overflow-style:none;-webkit-overflow-scrolling:touch;z-index:1;gap:14px;padding-bottom:6px;display:flex;position:relative;overflow-x:auto}.cinema-items::-webkit-scrollbar{display:none}.cinema-item{cursor:pointer;flex-shrink:0;transition:transform .2s cubic-bezier(.25,.46,.45,.94)}.cinema-item:active{transform:scale(.95)}.cinema-cover{background:#ffffff0f;border-radius:8px;width:105px;height:150px;transition:transform .25s cubic-bezier(.25,.46,.45,.94),box-shadow .25s;box-shadow:0 2px 6px #0000004d,0 8px 20px #0003}.cinema-title{color:#ffffffb3;text-overflow:ellipsis;white-space:nowrap;width:105px;margin-top:8px;font-family:Barlow Condensed,sans-serif;font-size:12px;font-weight:600;line-height:1.2;overflow:hidden}.cinema-stars{color:#facc15;letter-spacing:1px;white-space:nowrap;width:105px;margin-top:3px;font-size:11px;overflow:hidden}.cinema-tag{letter-spacing:.06em;text-transform:uppercase;border-radius:4px;margin-top:4px;padding:2px 6px;font-family:IBM Plex Mono,monospace;font-size:8px;font-weight:600;display:inline-block}.cinema-tag-active{color:#4ade80;background:#4ade8026}.cinema-tag-playing{color:#7ab8ff;background:linear-gradient(135deg,#4a6fa54d,#3a5a8a4d)}.cinema-tag-beat{color:#4ade80;background:#4ade8026}.cinema-tag-backlog{color:#ffffff59;background:#ffffff0f}.cinema-progress{background:#ffffff14;border-radius:2px;width:105px;height:3px;margin-top:4px;overflow:hidden}.cinema-progress-fill{background:#4ade80;border-radius:2px;height:100%;transition:width .3s}.cinema-see-all{text-align:center;letter-spacing:.04em;color:#fff6;cursor:pointer;z-index:1;padding:10px 0 2px;font-family:Barlow Condensed,sans-serif;font-size:13px;font-weight:600;transition:color .15s;position:relative}.cinema-see-all:hover{color:#ffffffb3}.cinema-strip .strava-card{background:#ffffff0a;border-color:#ffffff0f}.cinema-strip .strava-card-main{border-left-color:#fc4c02}.cinema-strip .strava-card-type,.cinema-strip .strava-card-date{color:#ffffff59}.cinema-strip .strava-card-name{color:#ffffffe6}.cinema-strip .strava-stat-val{color:#ffffffd9}.cinema-strip .strava-stat-label{color:#ffffff59}.cinema-strip .strava-hero{background:#ffffff0a}.cinema-strip .strava-disconnect{color:#ffffff4d}.cinema-strip .strava-disconnect:hover{color:#e94560}.cinema-strip .training-tile{border-color:#ffffff0f}.cinema-strip .training-tile-fallback{background:#ffffff0a}.cinema-strip .expand-btn{color:#fff6}.cinema-strip .expand-btn:hover{color:#ffffffb3}.cinema-strip .strava-nudge{border-color:#ffffff0f}.cinema-strip .strava-nudge-text{color:#ffffff80}.cinema-strip .strava-nudge-dismiss{color:#ffffff4d}.the-mantl{border-radius:16px;margin-bottom:28px;position:relative;overflow:hidden}.mantl-wall{background:linear-gradient(#e8ddd0 0%,#e2d5c5 60%,#ddd0be 100%);min-height:170px;padding:18px 18px 0;position:relative}.mantl-wall:before{content:"";pointer-events:none;background:repeating-linear-gradient(0deg,#0000,#0000 2px,#00000002 2px 4px);position:absolute;inset:0}.mantl-title-row{justify-content:center;align-items:center;margin-bottom:16px;display:flex;position:relative}.mantl-title-line{background:linear-gradient(90deg,#0000,#8b6b4b4d,#0000);flex:1;height:1px}.mantl-title{letter-spacing:.2em;text-transform:uppercase;color:var(--terracotta);white-space:nowrap;padding:0 14px;font-family:Barlow Condensed,sans-serif;font-size:13px;font-weight:900}.mantl-items-row{justify-content:center;align-items:flex-end;gap:16px;padding:0 12px 14px;display:flex}.mantl-items-row::-webkit-scrollbar{display:none}.mantl-piece{cursor:pointer;flex-direction:column;flex-shrink:0;align-items:center;transition:transform .2s;display:flex}.mantl-piece:hover{transform:translateY(-3px)}.mantl-frame{border-radius:3px;position:relative;overflow:hidden;box-shadow:0 4px 12px #00000040,0 1px 3px #00000026,0 8px 6px -6px #0003}.mantl-frame-portrait{width:72px;height:105px}.mantl-frame img{object-fit:cover;width:100%;height:100%;display:block}.mantl-event-overlay{background:linear-gradient(#0000 25%,#000000bf 100%);flex-direction:column;justify-content:flex-end;padding:6px 7px;display:flex;position:absolute;inset:0}.mantl-event-title{letter-spacing:.06em;text-transform:uppercase;color:#fff;text-shadow:0 1px 3px #0009;font-family:Barlow Condensed,sans-serif;font-size:9px;font-weight:800;line-height:1.2}.mantl-event-date{color:#fffc;margin-top:2px;font-family:IBM Plex Mono,monospace;font-size:7px}.mantl-piece-label{color:#503c288c;text-align:center;white-space:nowrap;text-overflow:ellipsis;max-width:76px;margin-top:6px;font-family:Lora,serif;font-size:9px;overflow:hidden}.mantl-ghost{background:#8b6b4b0f;border:1px dashed #8b6b4b33;border-radius:3px;justify-content:center;align-items:center;display:flex}.mantl-ghost-icon{opacity:.2;font-size:18px}.mantl-ledge{background:linear-gradient(#a07850 0%,#8b6b4b 40%,#7a5c3e 100%);height:18px;position:relative;box-shadow:0 4px 12px #0000004d,inset 0 2px 4px #ffffff26,inset 0 -1px 2px #0003}.mantl-ledge:before{content:"";pointer-events:none;background:repeating-linear-gradient(90deg,#0000,#0000 40px,#ffffff08 40px 42px,#0000 42px 80px,#00000005 80px 81px);position:absolute;inset:0}.mantl-ledge:after{content:"";background:linear-gradient(90deg,#ffffff0d,#ffffff26,#ffffff0d);height:2px;position:absolute;top:0;left:0;right:0}.mantl-shadow{background:linear-gradient(#00000014,#0000);border-radius:0 0 16px 16px;height:12px}.mantl-supports{z-index:1;justify-content:space-between;margin-top:-1px;padding:0 24px;display:flex;position:relative}.mantl-bracket{background:linear-gradient(#7a5c3e,#6b4f35);border-radius:0 0 3px 3px;width:16px;height:10px;box-shadow:0 2px 4px #00000026}.public-profile{max-width:480px;margin:0 auto;padding:20px 20px 40px}.public-header{text-align:center;padding:12px 0 20px}.public-brand{letter-spacing:.3em;text-transform:uppercase;color:var(--terracotta);opacity:.6;font-family:Barlow Condensed,sans-serif;font-size:16px;font-weight:900}.public-bio{color:var(--text-dim);text-align:center;padding:10px 0 0;font-family:Lora,serif;font-size:13px;font-style:italic}.public-cta{text-align:center;margin-top:40px;padding:0 10px}.public-cta-line{background:linear-gradient(90deg, transparent, var(--border-med), transparent);height:1px;margin-bottom:32px}.public-cta-inner{padding:0 10px}.public-cta-brand{letter-spacing:.25em;text-transform:uppercase;color:var(--terracotta);margin-bottom:6px;font-family:Barlow Condensed,sans-serif;font-size:28px;font-weight:900}.public-cta-tagline{color:var(--charcoal);margin-bottom:8px;font-family:Lora,serif;font-size:16px;font-style:italic}.public-cta-sub{color:var(--text-dim);margin-bottom:24px;font-family:IBM Plex Mono,monospace;font-size:11px;line-height:1.6}.public-cta-btn{letter-spacing:.12em;text-transform:uppercase;color:#fff;background:linear-gradient(135deg, var(--terracotta), #a0674d);cursor:pointer;border:none;border-radius:12px;padding:14px 48px;font-family:Barlow Condensed,sans-serif;font-size:16px;font-weight:700;transition:all .2s;display:inline-block;box-shadow:0 4px 16px #c4734f59}.public-cta-btn:hover{transform:translateY(-2px);box-shadow:0 6px 20px #c4734f73}.public-cta-footer{letter-spacing:.15em;color:var(--text-faint);margin-top:24px;font-family:IBM Plex Mono,monospace;font-size:10px}.share-link-section{background:var(--cream);border:1px solid var(--border);text-align:center;border-radius:14px;margin-top:20px;padding:16px}.share-link-label{letter-spacing:.1em;text-transform:uppercase;color:var(--text-faint);margin-bottom:8px;font-family:IBM Plex Mono,monospace;font-size:10px}.share-link-url{color:var(--terracotta);word-break:break-all;margin-bottom:10px;font-family:IBM Plex Mono,monospace;font-size:14px;font-weight:600}.share-link-btn{letter-spacing:.1em;text-transform:uppercase;color:#fff;background:var(--terracotta);cursor:pointer;border:none;border-radius:10px;padding:10px 28px;font-family:Barlow Condensed,sans-serif;font-size:13px;font-weight:600;transition:all .15s;display:inline-block}.share-link-btn:hover{opacity:.9}.share-link-btns{justify-content:center;gap:8px;display:flex}.friends-screen{padding:20px}.friends-header{text-transform:uppercase;letter-spacing:.02em;color:var(--charcoal);margin-bottom:8px;font-family:Barlow Condensed,sans-serif;font-size:32px;font-weight:900}.friends-sub{color:var(--text-dim);margin-bottom:24px;font-family:Lora,serif;font-size:14px;font-style:italic}.friends-empty{background:var(--card);text-align:center;border:1px solid var(--border);box-shadow:0 2px 8px var(--shadow);border-radius:16px;padding:48px 24px}.friends-empty-icon{opacity:.4;margin-bottom:16px;font-size:40px}.friends-empty-title{text-transform:uppercase;letter-spacing:.06em;color:var(--charcoal);margin-bottom:8px;font-family:Barlow Condensed,sans-serif;font-size:20px;font-weight:700}.friends-empty-text{color:var(--text-dim);margin-bottom:20px;font-family:Lora,serif;font-size:14px;font-style:italic;line-height:1.5}.friends-search-bar{gap:8px;margin-bottom:16px;display:flex}.friends-search-input{border:1px solid var(--border);background:var(--card);color:var(--charcoal);border-radius:10px;outline:none;flex:1;padding:10px 14px;font-family:Lora,serif;font-size:14px}.friends-search-input:focus{border-color:var(--terracotta)}.friends-search-input::placeholder{color:var(--text-faint)}.friends-share-row{background:#00000005;border-radius:10px;align-items:center;gap:10px;margin-bottom:20px;padding:10px 14px;display:flex}.friends-share-link{color:var(--text-dim);text-overflow:ellipsis;white-space:nowrap;flex:1;font-family:IBM Plex Mono,monospace;font-size:12px;overflow:hidden}.friends-share-btn{letter-spacing:.06em;text-transform:uppercase;color:var(--terracotta);border:1px solid var(--terracotta);cursor:pointer;white-space:nowrap;background:0 0;border-radius:8px;padding:6px 12px;font-family:Barlow Condensed,sans-serif;font-size:12px;font-weight:600}.friends-search-results{margin-bottom:20px}.friends-search-result{border-bottom:1px solid var(--border);cursor:pointer;align-items:center;gap:12px;padding:12px 4px;display:flex}.friends-search-result:last-child{border-bottom:none}.friends-result-avatar{background:var(--sage);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:40px;height:40px;font-size:18px;display:flex;overflow:hidden}.friends-result-avatar img{object-fit:cover;width:100%;height:100%}.friends-result-info{flex:1;min-width:0}.friends-result-name{color:var(--charcoal);font-family:Barlow Condensed,sans-serif;font-size:15px;font-weight:700}.friends-result-username{color:var(--text-faint);letter-spacing:.02em;font-family:IBM Plex Mono,monospace;font-size:11px}.friends-result-action{letter-spacing:.06em;text-transform:uppercase;cursor:pointer;border:none;border-radius:8px;flex-shrink:0;padding:6px 14px;font-family:Barlow Condensed,sans-serif;font-size:12px;font-weight:600}.friends-result-action.add{background:var(--terracotta);color:#fff}.friends-result-action.pending{color:var(--text-faint);border:1px solid var(--border);cursor:default;background:0 0}.friends-result-action.accepted{color:var(--sage);border:1px solid var(--sage);cursor:default;background:0 0}.friends-section-label{letter-spacing:.15em;text-transform:uppercase;color:var(--text-faint);border-bottom:1px solid var(--border);margin:20px 0 10px;padding-bottom:6px;font-family:IBM Plex Mono,monospace;font-size:10px}.friend-request-card{background:var(--card);border:1px solid #c4734f26;border-radius:12px;align-items:center;gap:12px;margin-bottom:8px;padding:14px;display:flex}.friend-request-actions{flex-shrink:0;gap:6px;display:flex}.friend-request-btn{letter-spacing:.04em;text-transform:uppercase;cursor:pointer;border:none;border-radius:8px;padding:6px 14px;font-family:Barlow Condensed,sans-serif;font-size:12px;font-weight:600}.friend-request-btn.accept{background:var(--terracotta);color:#fff}.friend-request-btn.decline{color:var(--text-faint);border:1px solid var(--border);background:0 0}.friend-row{cursor:pointer;border-bottom:1px solid #0000000a;align-items:center;gap:12px;padding:12px 4px;display:flex}.friend-row:last-child{border-bottom:none}.nav-icon-wrap{display:inline-block;position:relative}.nav-badge{background:var(--terracotta);color:#fff;border-radius:8px;justify-content:center;align-items:center;min-width:16px;height:16px;padding:0 4px;font-family:Barlow Condensed,sans-serif;font-size:10px;font-weight:700;display:flex;position:absolute;top:-4px;right:-8px}.friends-no-results{color:var(--text-faint);text-align:center;padding:16px;font-family:Lora,serif;font-size:13px;font-style:italic}.feed-card{border-bottom:1px solid #0000000d;gap:10px;padding:10px 0;display:flex}.feed-card:last-child{border-bottom:none}.feed-avatar{background:var(--sage);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:30px;height:30px;font-size:14px;display:flex;overflow:hidden}.feed-avatar img{object-fit:cover;width:100%;height:100%}.feed-body{flex:1;min-width:0}.feed-action-text{color:var(--text-dim);font-family:Lora,serif;font-size:13px;line-height:1.3}.feed-action-text strong{color:var(--charcoal);font-family:Barlow Condensed,sans-serif;font-size:14px;font-weight:700}.feed-item-row{background:var(--card);border:1px solid var(--border);border-radius:10px;align-items:center;gap:10px;margin-top:5px;padding:8px 10px;display:flex}.feed-item-cover{object-fit:cover;background:var(--border);border-radius:4px;flex-shrink:0;width:54px;height:80px}.feed-item-info{flex:1;min-width:0}.feed-item-title{color:var(--charcoal);white-space:nowrap;text-overflow:ellipsis;font-family:Barlow Condensed,sans-serif;font-size:15px;font-weight:700;overflow:hidden}.feed-item-meta{color:var(--text-faint);margin-top:1px;font-family:Lora,serif;font-size:11px}.feed-item-rating{letter-spacing:1px;margin-top:2px;font-size:13px}.feed-loading,.feed-empty{text-align:center;color:var(--text-faint);padding:32px 16px;font-family:Lora,serif;font-size:13px;font-style:italic}.feed-reaction-btn{border:1px solid var(--border);background:var(--card);cursor:pointer;border-radius:20px;align-items:center;gap:3px;padding:3px 7px;font-size:12px;transition:all .15s;display:inline-flex}.feed-reaction-btn:hover{background:#c4734f0f}.feed-reaction-btn.active{border-color:var(--terracotta);background:#c4734f1a}.feed-reaction-count{color:var(--text-dim);font-family:IBM Plex Mono,monospace;font-size:10px;font-weight:600}.feed-reaction-btn.active .feed-reaction-count{color:var(--terracotta)}.feed-wishlist-btn{border:1px solid var(--border);background:var(--card);cursor:pointer;color:var(--text-dim);letter-spacing:.02em;border-radius:20px;align-items:center;gap:4px;padding:3px 8px;font-family:Barlow Condensed,sans-serif;font-size:11px;font-weight:600;transition:all .15s;display:inline-flex}.feed-wishlist-btn:hover{border-color:var(--terracotta);background:#c4734f0f}.feed-wishlist-btn.added{border-color:var(--terracotta);color:var(--terracotta);background:#c4734f1a}.feed-comments-section{background:var(--card);border:1px solid var(--border);border-radius:10px;margin-top:6px;padding:8px 10px}.feed-comment{border-bottom:1px solid #0000000a;gap:8px;padding:6px 0;display:flex}.feed-comment:last-of-type{border-bottom:none}.feed-comment-avatar{background:var(--sage);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:22px;height:22px;font-size:10px;display:flex;overflow:hidden}.feed-comment-avatar img{object-fit:cover;width:100%;height:100%}.feed-comment-body{flex:1;min-width:0}.feed-comment-name{color:var(--charcoal);font-family:Barlow Condensed,sans-serif;font-size:12px;font-weight:700}.feed-comment-text{color:var(--text-dim);margin-top:1px;font-family:Lora,serif;font-size:12px;line-height:1.4}.feed-comment-time{color:var(--text-faint);margin-top:2px;font-family:IBM Plex Mono,monospace;font-size:9px}.feed-comment-input-row{align-items:center;gap:8px;margin-top:8px;display:flex}.feed-comment-input{border:1px solid var(--border);color:var(--charcoal);background:#fff;border-radius:20px;outline:none;flex:1;padding:6px 12px;font-family:Lora,serif;font-size:12px}.feed-comment-input:focus{border-color:var(--terracotta)}.feed-comment-send{background:var(--terracotta);color:#fff;cursor:pointer;border:none;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:28px;height:28px;font-size:12px;display:flex}.feed-comment-send:disabled{opacity:.4;cursor:default}.btn-outline{color:var(--terracotta);letter-spacing:.1em;text-transform:uppercase;border:1.5px solid var(--terracotta);cursor:pointer;background:0 0;border-radius:10px;padding:12px 24px;font-family:Barlow Condensed,sans-serif;font-size:15px;font-weight:700;transition:all .15s;display:inline-flex}.btn-outline:hover{background:var(--terra-glow)}.profile-screen{padding:20px}.profile-screen-header{align-items:center;gap:8px;margin-bottom:24px;display:flex}.profile-back{letter-spacing:.15em;color:var(--text-dim);cursor:pointer;text-transform:uppercase;background:0 0;border:none;padding:8px 0;font-family:IBM Plex Mono,monospace;font-size:12px}.profile-back:hover{color:var(--charcoal)}.profile-big-avatar{background:var(--terra-glow);border:3px solid var(--border-med);border-radius:50%;justify-content:center;align-items:center;width:80px;height:80px;margin-bottom:16px;font-size:40px;display:flex;position:relative;overflow:hidden}.profile-big-avatar img{object-fit:cover;width:100%;height:100%}.avatar-upload-wrap{cursor:pointer;display:inline-block;position:relative}.avatar-upload-overlay{color:#fff;letter-spacing:.05em;background:#0000008c;justify-content:center;align-items:center;height:28px;font-family:IBM Plex Mono,monospace;font-size:13px;display:flex;position:absolute;bottom:0;left:0;right:0}.avatar-upload-input{display:none}.avatar-uploading{background:#00000080;border-radius:50%;justify-content:center;align-items:center;display:flex;position:absolute;inset:0}.profile-big-name{text-transform:uppercase;color:var(--charcoal);margin-bottom:4px;font-family:Barlow Condensed,sans-serif;font-size:32px;font-weight:900}.profile-big-handle{color:var(--text-dim);margin-bottom:20px;font-family:IBM Plex Mono,monospace;font-size:13px}.profile-bio{color:var(--text-dim);margin-bottom:24px;font-family:Lora,serif;font-size:14px;font-style:italic;line-height:1.5}.settings-section{border-top:1px solid var(--border);margin-top:32px;padding-top:24px}.settings-label{letter-spacing:.2em;text-transform:uppercase;color:var(--text-faint);margin-bottom:16px;font-family:IBM Plex Mono,monospace;font-size:10px}.settings-item{border-bottom:1px solid var(--border);cursor:pointer;justify-content:space-between;align-items:center;padding:14px 0;display:flex}.settings-item-text{color:var(--text-dim);font-family:Lora,serif;font-size:15px}.settings-item-arrow{color:var(--text-muted);font-size:20px}.btn-signout{color:#c45043;letter-spacing:.1em;text-transform:uppercase;cursor:pointer;background:0 0;border:1px solid #c4504333;border-radius:10px;width:100%;margin-top:16px;padding:14px;font-family:Barlow Condensed,sans-serif;font-size:15px;font-weight:600;transition:background .15s}.btn-signout:hover{background:#c450430d}.recap-screen{background:#111;min-height:100vh;padding:0 0 40px}.recap-header{z-index:10;background:#1a1a1a;border-bottom:1px solid #ffffff0f;justify-content:space-between;align-items:center;padding:16px 20px;display:flex;position:sticky;top:0}.recap-back{color:#c4734f;cursor:pointer;letter-spacing:.04em;background:0 0;border:none;font-family:Barlow Condensed,sans-serif;font-size:14px;font-weight:600}.recap-title{text-transform:uppercase;letter-spacing:.08em;color:#f4f0ea;font-family:Barlow Condensed,sans-serif;font-size:16px;font-weight:800}.recap-month-picker{justify-content:center;align-items:center;gap:16px;padding:20px;display:flex}.recap-month-arrow{color:#f4f0ea66;cursor:pointer;background:0 0;border:none;padding:8px;font-size:20px}.recap-month-arrow:hover{color:#f4f0ea}.recap-month-label{text-transform:uppercase;letter-spacing:.04em;color:#f4f0ea;text-align:center;min-width:180px;font-family:Barlow Condensed,sans-serif;font-size:20px;font-weight:800}.recap-card-wrapper{justify-content:center;padding:0 16px;display:flex}.recap-actions{justify-content:center;gap:10px;padding:24px 20px;display:flex}.recap-btn{letter-spacing:.06em;text-transform:uppercase;cursor:pointer;border:none;border-radius:10px;padding:12px 28px;font-family:Barlow Condensed,sans-serif;font-size:14px;font-weight:700;transition:opacity .15s}.recap-btn:hover{opacity:.85}.recap-btn.primary{color:#fff;background:#c4734f}.recap-btn.secondary{color:#c4734f;background:0 0;border:1px solid #c4734f4d}.recap-empty{text-align:center;color:#f4f0ea59;padding:60px 24px;font-family:Lora,serif;font-size:15px;font-style:italic}.edit-profile-form{background:#00000005;border-radius:10px;flex-direction:column;gap:12px;margin-top:-4px;margin-bottom:8px;padding:16px;display:flex}.btn-save-profile{background:var(--terracotta);color:#fff;letter-spacing:.08em;text-transform:uppercase;cursor:pointer;border:none;border-radius:10px;padding:12px;font-family:Barlow Condensed,sans-serif;font-size:14px;font-weight:700;transition:opacity .15s}.btn-save-profile:hover{opacity:.9}.btn-save-profile:disabled{opacity:.5;cursor:default}.manage-shelves-panel{margin-top:-4px;margin-bottom:8px;padding:12px 0 8px}.shelf-toggle-row{border-bottom:1px solid #0000000a;align-items:center;gap:6px;padding:10px 4px;display:flex}.shelf-toggle-row:last-child{border-bottom:none}.shelf-drag-handle{color:var(--text-dim);cursor:grab;-webkit-user-select:none;user-select:none;-webkit-tap-highlight-color:transparent;touch-action:none;flex-shrink:0;padding:4px 6px;font-size:16px;line-height:1}.shelf-drag-handle:active{cursor:grabbing}.shelf-toggle-row.shelf-dragging{z-index:10;background:var(--cream);border-color:var(--terracotta);border-radius:10px;transition:transform .15s,box-shadow .15s;position:relative;transform:scale(1.02);box-shadow:0 6px 20px #0000001f}.shelf-toggle-row.shelf-dragging .shelf-drag-handle{color:var(--terracotta)}.shelf-toggle-row.shelf-drag-over{padding-top:48px;transition:padding .2s;position:relative}.shelf-toggle-row.shelf-drag-over:before{content:"";border:2px dashed var(--terracotta);opacity:.6;background:#c4734f0a;border-radius:8px;height:38px;position:absolute;top:4px;left:4px;right:4px}.shelf-toggle-info{flex:1;align-items:center;gap:10px;display:flex}.shelf-toggle-icon{text-align:center;width:28px;font-size:18px}.shelf-toggle-label{color:var(--text-dim);font-family:Lora,serif;font-size:14px}.shelf-toggle-label.disabled{color:var(--text-faint)}.shelf-toggle-switch{background:var(--border);cursor:pointer;border-radius:12px;flex-shrink:0;width:42px;height:24px;transition:background .2s;position:relative}.shelf-toggle-switch.on{background:var(--terracotta)}.shelf-toggle-switch:after{content:"";background:#fff;border-radius:50%;width:20px;height:20px;transition:transform .2s;position:absolute;top:2px;left:2px;box-shadow:0 1px 3px #00000026}.shelf-toggle-switch.on:after{transform:translate(18px)}.shelf-toggle-permanent{letter-spacing:.08em;text-transform:uppercase;color:var(--text-faint);background:#00000008;border-radius:6px;padding:4px 8px;font-family:IBM Plex Mono,monospace;font-size:9px}.nav-bar{-webkit-backdrop-filter:blur(20px);width:100%;max-width:430px;padding:6px 0 0;padding-bottom:max(env(safe-area-inset-bottom,8px), 8px);z-index:100;background:#fdfbf7f5;border-top:1px solid #0000000f;justify-content:space-around;align-items:center;display:flex;position:fixed;bottom:0;left:50%;transform:translate(-50%)}.nav-item{cursor:pointer;color:var(--text-dim,#9a9080);-webkit-tap-highlight-color:transparent;background:0 0;border:none;flex-direction:column;align-items:center;gap:3px;padding:8px 20px 6px;transition:color .2s;display:flex;position:relative}.nav-item.active{color:var(--terracotta)}.nav-item.active .nav-label{font-weight:700}.nav-icon{justify-content:center;align-items:center;height:24px;font-size:20px;display:flex}.nav-icon svg{transition:transform .2s}.nav-item.active .nav-icon svg{stroke-width:2.2px;transform:scale(1.08)}.nav-label{letter-spacing:.08em;text-transform:uppercase;font-family:Barlow Condensed,sans-serif;font-size:10px;font-weight:500;transition:font-weight .2s}.fab{background:linear-gradient(135deg, var(--terracotta), var(--terra-light));width:54px;height:54px;color:var(--warm-white);cursor:pointer;-webkit-tap-highlight-color:transparent;border:none;border-radius:50%;justify-content:center;align-items:center;margin-top:-20px;font-size:26px;transition:transform .15s,box-shadow .15s;display:flex;box-shadow:0 4px 16px #c4734f59,0 2px 6px #c4734f33}.fab:active{transform:scale(.92);box-shadow:0 2px 8px #c4734f4d}.fab-label{letter-spacing:.1em;text-transform:uppercase;color:var(--terracotta);margin-top:4px;font-family:IBM Plex Mono,monospace;font-size:8px}.modal-overlay{-webkit-backdrop-filter:blur(4px);z-index:200;background:#2c282473;justify-content:center;align-items:flex-end;animation:.2s fadeIn;display:flex;position:fixed;inset:0}.modal-sheet{background:var(--warm-white);width:100%;max-width:430px;padding:24px 20px;padding-bottom:max(env(safe-area-inset-bottom,24px), 24px);border-radius:20px 20px 0 0;min-height:70vh;max-height:92vh;animation:.3s slideUp;overflow-y:auto}.modal-handle{background:var(--border-med);border-radius:2px;width:36px;height:4px;margin:0 auto 20px}.modal-title{text-transform:uppercase;letter-spacing:.04em;color:var(--charcoal);margin-bottom:4px;font-family:Barlow Condensed,sans-serif;font-size:28px;font-weight:900}.modal-sub{color:var(--text-dim);margin-bottom:20px;font-family:Lora,serif;font-size:14px;font-style:italic}.search-input{background:var(--cream);border:1px solid var(--border-med);width:100%;color:var(--charcoal);border-radius:12px;outline:none;margin-bottom:16px;padding:14px 16px;font-family:Lora,serif;font-size:16px;transition:border-color .15s}.search-input::placeholder{color:var(--text-faint)}.search-input:focus{border-color:var(--terracotta)}.category-pills{scrollbar-width:none;gap:8px;margin-bottom:20px;display:flex;overflow-x:auto}.category-pills::-webkit-scrollbar{display:none}.pill{letter-spacing:.06em;border:1px solid var(--border-med);color:var(--text-dim);cursor:pointer;text-transform:uppercase;background:0 0;border-radius:20px;flex-shrink:0;padding:8px 16px;font-family:IBM Plex Mono,monospace;font-size:11px;transition:all .15s}.pill.active{background:var(--terracotta);color:var(--warm-white);border-color:var(--terracotta)}.search-placeholder{text-align:center;padding:32px 0}.search-placeholder-icon{opacity:.3;margin-bottom:12px;font-size:32px}.search-placeholder-text{color:var(--text-faint);font-family:Lora,serif;font-size:14px;font-style:italic}.search-results{flex-direction:column;gap:6px;display:flex}.search-result{cursor:pointer;border-radius:12px;align-items:center;gap:14px;padding:10px;transition:background .15s,transform .15s;display:flex}.search-result:hover{background:var(--cream)}.search-result:active{background:var(--cream-dark);transform:scale(.99)}.result-poster{background:var(--cream-dark);width:52px;height:74px;box-shadow:1px 2px 8px var(--shadow-med);object-fit:cover;border-radius:6px;flex-shrink:0}.result-info{flex:1;min-width:0}.result-title{color:var(--charcoal);white-space:nowrap;text-overflow:ellipsis;font-family:Barlow Condensed,sans-serif;font-size:17px;font-weight:700;overflow:hidden}.result-meta{color:var(--text-dim);margin-top:2px;font-family:IBM Plex Mono,monospace;font-size:11px}.result-type-badge{letter-spacing:.1em;text-transform:uppercase;background:var(--terra-glow);color:var(--terracotta);border-radius:6px;padding:3px 8px;font-family:IBM Plex Mono,monospace;font-size:9px}.search-loading{text-align:center;color:var(--text-faint);padding:24px 0;font-family:IBM Plex Mono,monospace;font-size:12px}.shelf-detail{padding:4px 0}.shelf-detail-back{letter-spacing:.15em;color:var(--text-dim);cursor:pointer;text-transform:uppercase;background:0 0;border:none;margin-bottom:16px;padding:4px 0;font-family:IBM Plex Mono,monospace;font-size:11px}.shelf-detail-back:hover{color:var(--charcoal)}.shelf-detail-hero{gap:18px;margin-bottom:20px;display:flex}.shelf-detail-poster{width:110px;height:158px;box-shadow:2px 4px 16px var(--shadow-med), 0 1px 3px #2c282414;object-fit:cover;background:var(--cream-dark);border-radius:8px;flex-shrink:0}.shelf-detail-info{flex:1}.shelf-detail-title{text-transform:uppercase;color:var(--charcoal);margin-bottom:4px;font-family:Barlow Condensed,sans-serif;font-size:26px;font-weight:900;line-height:1.1}.shelf-detail-meta{color:var(--text-dim);margin-bottom:2px;font-family:IBM Plex Mono,monospace;font-size:12px}.shelf-detail-overview{color:var(--text-dim);-webkit-line-clamp:3;-webkit-box-orient:vertical;margin-bottom:20px;font-family:Lora,serif;font-size:13px;line-height:1.5;display:-webkit-box;overflow:hidden}.rating-section{margin-bottom:20px}.rating-label{letter-spacing:.2em;text-transform:uppercase;color:var(--terracotta);margin-bottom:10px;font-family:IBM Plex Mono,monospace;font-size:10px}.star-row{gap:4px;display:flex}.star-btn{border:1px solid var(--border-med);background:var(--cream);cursor:pointer;border-radius:10px;justify-content:center;align-items:center;width:46px;height:46px;font-size:24px;transition:all .15s;display:flex;position:relative;overflow:hidden}.star-half-zone{cursor:pointer;z-index:2;width:50%;position:absolute;top:0;bottom:0}.star-half-zone.left{left:0}.star-half-zone.right{right:0}.star-btn.full{background:var(--terra-glow);border-color:var(--terracotta)}.star-btn.half{background:linear-gradient(90deg, var(--terra-glow) 50%, var(--cream) 50%);border-color:var(--terracotta)}.rating-display{color:var(--text-dim);margin-top:4px;font-family:IBM Plex Mono,monospace;font-size:11px}.shelf-item-stars{color:var(--terracotta);letter-spacing:1px;white-space:nowrap;width:100px;margin-top:3px;font-size:11px;overflow:hidden}.shelf-item-progress{background:var(--cream-dark);border-radius:2px;width:100px;height:4px;margin-top:4px;overflow:hidden}.shelf-item-progress-fill{background:var(--sage);border-radius:2px;height:100%}.shelf-item-reading-tag{color:var(--sage);letter-spacing:.05em;text-transform:uppercase;width:100px;margin-top:2px;font-family:IBM Plex Mono,monospace;font-size:8px;overflow:hidden}.shelf-add-more{background:var(--cream);border:1.5px dashed var(--border-med);cursor:pointer;border-radius:8px;flex-direction:column;flex-shrink:0;justify-content:center;align-items:center;width:100px;height:142px;transition:border-color .15s,background .15s;display:flex}.shelf-add-more:hover{border-color:var(--terracotta);background:var(--terra-glow)}.shelf-add-more-icon{color:var(--text-faint);margin-bottom:4px;font-size:20px}.shelf-add-more-text{letter-spacing:.06em;text-transform:uppercase;color:var(--text-faint);font-family:IBM Plex Mono,monospace;font-size:8px}.item-detail-overlay{-webkit-backdrop-filter:blur(4px);z-index:200;background:#2c282473;justify-content:center;align-items:flex-end;animation:.2s fadeIn;display:flex;position:fixed;inset:0}.item-detail-sheet{background:var(--warm-white);width:100%;max-width:430px;padding:24px 20px;padding-bottom:max(env(safe-area-inset-bottom,32px), 32px);border-radius:20px 20px 0 0;min-height:50vh;max-height:90vh;animation:.3s slideUp;overflow-y:auto}.item-detail-close{letter-spacing:.15em;color:var(--text-dim);cursor:pointer;text-transform:uppercase;background:0 0;border:none;margin-bottom:16px;padding:4px 0;font-family:IBM Plex Mono,monospace;font-size:11px}.item-detail-actions{border-top:1px solid var(--border);gap:10px;margin-top:20px;padding-top:16px;display:flex}.btn-edit-rating{letter-spacing:.08em;text-transform:uppercase;background:var(--cream);color:var(--charcoal);border:1px solid var(--border-med);cursor:pointer;border-radius:10px;flex:1;padding:12px;font-family:Barlow Condensed,sans-serif;font-size:13px;font-weight:600;transition:all .15s}.btn-edit-rating:hover{border-color:var(--terracotta)}.btn-remove{letter-spacing:.08em;text-transform:uppercase;background:var(--cream);color:#9e3c2f;cursor:pointer;border:1px solid #e8c4be;border-radius:10px;padding:12px 16px;font-family:Barlow Condensed,sans-serif;font-size:13px;font-weight:600;transition:all .15s}.btn-remove:hover{background:#fdf0ee;border-color:#9e3c2f}.btn-pin-mantl{letter-spacing:.08em;text-transform:uppercase;color:var(--terracotta);background:var(--terra-glow);cursor:pointer;border:1px solid #c4734f4d;border-radius:8px;align-items:center;gap:6px;padding:8px 16px;font-family:Barlow Condensed,sans-serif;font-size:12px;font-weight:600;transition:all .15s;display:flex}.btn-pin-mantl:hover{border-color:var(--terracotta)}.btn-pin-mantl.pinned{background:var(--terracotta);color:#fff;border-color:var(--terracotta)}.pin-picker{z-index:200;background:#fff;border-radius:16px 16px 0 0;flex-direction:column;max-height:75vh;animation:.25s slideUp;display:flex;position:fixed;bottom:0;left:0;right:0;box-shadow:0 -4px 24px #00000026}.pin-picker-header{justify-content:space-between;align-items:center;padding:16px 20px 8px;display:flex}.pin-picker-title{text-transform:uppercase;letter-spacing:.06em;color:var(--charcoal);font-family:Barlow Condensed,sans-serif;font-size:18px;font-weight:800}.pin-picker-close{color:var(--text-faint);cursor:pointer;padding:4px 8px;font-size:18px}.pin-picker-search{border:1px solid var(--border);color:var(--charcoal);background:#fff;border-radius:10px;outline:none;margin:0 16px 8px;padding:10px 14px;font-family:Lora,serif;font-size:14px}.pin-picker-search:focus{border-color:var(--terracotta)}.pin-picker-list{flex:1;padding:0 16px 24px;overflow-y:auto}.pin-picker-cat{letter-spacing:.1em;text-transform:uppercase;color:var(--text-faint);margin:16px 0 6px;font-family:IBM Plex Mono,monospace;font-size:10px}.pin-picker-item{cursor:pointer;border-radius:10px;align-items:center;gap:12px;padding:8px;transition:background .15s;display:flex}.pin-picker-item:hover{background:#c4734f0f}.pin-picker-item.pinned{background:#c4734f1a}.pin-picker-item.disabled{opacity:.35;cursor:not-allowed}.pin-picker-item-cover{background:#8b6b4b14;border-radius:3px;flex-shrink:0;justify-content:center;align-items:center;width:40px;height:56px;font-size:16px;display:flex;overflow:hidden}.pin-picker-item-cover img{object-fit:cover;width:100%;height:100%}.pin-picker-item-info{flex:1;min-width:0}.pin-picker-item-title{color:var(--charcoal);white-space:nowrap;text-overflow:ellipsis;font-family:Barlow Condensed,sans-serif;font-size:14px;font-weight:700;overflow:hidden}.pin-picker-item-meta{color:var(--text-faint);margin-top:2px;font-family:IBM Plex Mono,monospace;font-size:10px}.pin-picker-item-action{color:var(--terracotta);text-align:center;flex-shrink:0;width:28px;font-size:18px;font-weight:700}.pin-picker-empty{text-align:center;color:var(--text-faint);padding:40px 20px;font-family:Lora,serif;font-size:14px}.event-form-label{letter-spacing:.1em;text-transform:uppercase;color:var(--text-faint);margin-bottom:4px;font-family:IBM Plex Mono,monospace;font-size:10px;font-weight:600}.event-form-input{border:1px solid var(--border);width:100%;color:var(--charcoal);box-sizing:border-box;background:#fff;border-radius:10px;outline:none;padding:10px 14px;font-family:Lora,serif;font-size:14px}.event-form-input:focus{border-color:var(--terracotta)}.event-form-hint{color:var(--text-faint);margin-top:4px;font-family:IBM Plex Mono,monospace;font-size:9px;font-style:italic}.event-add-goal{color:var(--terracotta);cursor:pointer;letter-spacing:.04em;margin-top:10px;font-family:IBM Plex Mono,monospace;font-size:11px}.event-add-goal:hover{text-decoration:underline}.location-suggestions{background:var(--cream);border:1px solid var(--border);z-index:10;border-top:none;border-radius:0 0 8px 8px;max-height:180px;position:absolute;top:100%;left:0;right:0;overflow-y:auto;box-shadow:0 4px 12px #00000014}.location-suggestion{color:var(--charcoal);cursor:pointer;padding:8px 12px;font-family:IBM Plex Mono,monospace;font-size:12px}.location-suggestion:hover{background:#c4734f14}.shelf-add-btn{letter-spacing:.04em;color:var(--terracotta);cursor:pointer;font-family:Barlow Condensed,sans-serif;font-size:13px;font-weight:700;transition:color .15s}.shelf-add-btn:hover{color:var(--terra-light)}.expand-btn{text-align:center;letter-spacing:.06em;color:var(--terracotta);cursor:pointer;margin-top:4px;padding:12px;font-family:Barlow Condensed,sans-serif;font-size:13px;font-weight:600;transition:color .15s}.expand-btn:hover{color:var(--terra-light)}.training-grid{border-radius:14px;gap:8px;display:grid;overflow:hidden}.training-grid-1{grid-template-columns:1fr}.training-grid-2,.training-grid-3{grid-template-columns:1fr 1fr}.training-grid-3 .training-tile:first-child{grid-column:1/-1}.training-grid-4{grid-template-columns:1fr 1fr}.training-tile{cursor:pointer;aspect-ratio:1;border-radius:14px;transition:transform .15s;position:relative;overflow:hidden}.training-tile:hover{transform:scale(1.02)}.training-grid-1 .training-tile{aspect-ratio:1.4}.training-grid-3 .training-tile:first-child{aspect-ratio:2.2}.training-tile-bg{filter:brightness(.5);background-position:50%;background-size:cover;position:absolute;inset:0}.training-tile-fallback{filter:none;background:linear-gradient(135deg,#8b9e7e40,#8b9e7e1a);justify-content:center;align-items:center;font-size:36px;display:flex}.training-tile-content{z-index:1;box-sizing:border-box;text-shadow:0 1px 4px #00000080;flex-direction:column;justify-content:flex-end;height:100%;padding:14px;display:flex;position:relative}.training-tile-fallback+.training-tile-content{text-shadow:none}.training-tile-title{letter-spacing:.04em;text-transform:uppercase;color:#fff;font-family:Barlow Condensed,sans-serif;font-size:18px;font-weight:800;line-height:1.15}.training-tile-fallback+.training-tile-content .training-tile-title{color:var(--charcoal)}.training-tile-detail{color:#ffffffd9;margin-top:2px;font-family:Lora,serif;font-size:12px}.training-tile-fallback+.training-tile-content .training-tile-detail{color:var(--text-dim)}.training-tile-date{color:#ffffffb3;letter-spacing:.04em;margin-top:4px;font-family:IBM Plex Mono,monospace;font-size:10px}.training-tile-fallback+.training-tile-content .training-tile-date{color:var(--text-faint)}.training-tile-ready{color:#d4a843;letter-spacing:.03em;text-transform:uppercase;margin-top:6px;font-family:Barlow Condensed,sans-serif;font-size:10px;font-weight:600;animation:2s ease-in-out infinite pulse-ready}.training-tile-fallback+.training-tile-content .training-tile-ready{color:var(--terracotta)}@keyframes pulse-ready{0%,to{opacity:1}50%{opacity:.6}}.training-grid-4 .training-tile-title,.training-grid-3 .training-tile:not(:first-child) .training-tile-title{font-size:14px}.training-grid-4 .training-tile-detail,.training-grid-3 .training-tile:not(:first-child) .training-tile-detail{font-size:10px}.training-grid-4 .training-tile-content,.training-grid-3 .training-tile:not(:first-child) .training-tile-content{padding:10px}.strava-powered{align-items:center;gap:4px;display:flex}.strava-logo-tiny{opacity:.5;height:14px}.strava-loading{text-align:center;color:var(--text-faint);padding:24px;font-family:Lora,serif;font-size:13px}.strava-nudge{background:#fc4c020a;border:1px solid #fc4c021a;border-radius:10px;justify-content:space-between;align-items:center;margin-top:8px;padding:10px 14px;display:flex}.strava-nudge-text{color:var(--text-dim);cursor:pointer;letter-spacing:.02em;font-family:IBM Plex Mono,monospace;font-size:10px}.strava-nudge-text:hover{color:var(--charcoal)}.strava-nudge-dismiss{color:var(--text-faint);cursor:pointer;flex-shrink:0;margin-left:8px;padding:2px 4px;font-size:13px}.strava-nudge-dismiss:hover{color:var(--charcoal)}.strava-empty{text-align:center;color:var(--text-faint);padding:24px;font-family:Lora,serif;font-size:13px}.strava-cards{flex-direction:column;gap:8px;display:flex}.strava-card{border:1px solid var(--border);background:#fff;border-radius:14px;overflow:hidden}.strava-card-main{border-left:3px solid #fc4c02}.strava-card-main>.strava-card-header,.strava-card-main>.strava-card-name,.strava-card-main>.strava-card-stats{padding-left:16px;padding-right:16px}.strava-card-main>.strava-card-header{padding-top:14px}.strava-card-main>.strava-card-stats{padding-bottom:14px}.strava-hero{background:var(--cream,#f5f0e8);width:100%;height:160px;position:relative;overflow:hidden}.strava-hero-img{object-fit:cover;width:100%;height:100%}.strava-hero-map{background:#2a2a2a;justify-content:center;align-items:center;display:flex}.strava-route-svg{width:100%;height:100%}.strava-card-header{align-items:center;gap:6px;margin-bottom:6px;display:flex}.strava-card-icon{font-size:16px}.strava-card-type{letter-spacing:.08em;text-transform:uppercase;color:var(--text-faint);flex:1;font-family:IBM Plex Mono,monospace;font-size:10px}.strava-card-date{color:var(--text-faint);font-family:IBM Plex Mono,monospace;font-size:10px}.strava-card-name{color:var(--charcoal);margin-bottom:10px;font-family:Barlow Condensed,sans-serif;font-size:17px;font-weight:700}.strava-card-stats{flex-wrap:wrap;gap:16px;display:flex}.strava-stat{min-width:0}.strava-stat-val{color:var(--charcoal);font-family:Barlow Condensed,sans-serif;font-size:16px;font-weight:700;line-height:1.1}.strava-stat-label{letter-spacing:.08em;text-transform:uppercase;color:var(--text-faint);margin-top:2px;font-family:IBM Plex Mono,monospace;font-size:9px}.strava-footer{justify-content:center;padding:8px 0 0;display:flex}.strava-disconnect{color:var(--text-faint);cursor:pointer;letter-spacing:.04em;font-family:IBM Plex Mono,monospace;font-size:10px}.strava-disconnect:hover{color:var(--terracotta);text-decoration:underline}.passport-tabs{background:#00000008;border-radius:10px;gap:0;margin-bottom:12px;padding:3px;display:flex}.passport-tab{text-align:center;letter-spacing:.04em;text-transform:uppercase;color:var(--text-faint);cursor:pointer;border-radius:8px;flex:1;padding:8px 12px;font-family:Barlow Condensed,sans-serif;font-size:13px;font-weight:600;transition:all .15s}.passport-tab.active{color:var(--charcoal);background:#fff;box-shadow:0 1px 4px #00000014}.passport-tab-count{color:var(--text-faint);margin-left:4px;font-size:11px;font-weight:400}.passport-empty-tab{text-align:center;color:var(--text-faint);padding:20px;font-family:Lora,serif;font-size:13px;font-style:italic}.passport-list{flex-direction:column;gap:0;display:flex}.passport-row{cursor:pointer;border-bottom:1px solid #0000000a;align-items:center;gap:10px;padding:9px 4px;transition:background .12s;display:flex}.passport-row:last-child{border-bottom:none}.passport-row:active{background:#00000008}.passport-row-flag{object-fit:cover;border-radius:2px;flex-shrink:0;width:28px;height:20px;box-shadow:0 1px 3px #0000001f}.passport-row-name{color:var(--charcoal);letter-spacing:.02em;white-space:nowrap;text-overflow:ellipsis;flex:1;min-width:0;font-family:Barlow Condensed,sans-serif;font-size:14px;font-weight:600;overflow:hidden}.passport-row-year{color:var(--text-faint);letter-spacing:.04em;flex-shrink:0;font-family:IBM Plex Mono,monospace;font-size:10px}.passport-map-overlay{z-index:1000;background:var(--cream);flex-direction:column;animation:.25s fadeIn;display:flex;position:fixed;inset:0}.passport-map-header{border-bottom:1px solid #0000000f;flex-shrink:0;justify-content:space-between;align-items:center;padding:16px 20px;display:flex}.passport-map-title{text-transform:uppercase;letter-spacing:.04em;color:var(--charcoal);font-family:Barlow Condensed,sans-serif;font-size:20px;font-weight:800}.passport-map-close{cursor:pointer;color:var(--text-faint);padding:4px 8px;font-size:22px;line-height:1}.passport-map-body{-webkit-overflow-scrolling:touch;flex-direction:column;flex:1;align-items:center;padding:20px 12px;display:flex;overflow:auto}.passport-map-container{background:#a6c8de1f;border-radius:16px;width:100%;max-width:900px;overflow:hidden;box-shadow:inset 0 0 40px #00000008}.passport-map-container svg{width:100%;height:auto;display:block}.passport-map-container svg path{transition:fill .15s}.passport-map-container svg path.visited-country,.passport-map-container svg path.bucket-country{cursor:pointer}.passport-map-container svg path.visited-country:hover,.passport-map-container svg path.bucket-country:hover{filter:brightness(1.1)}.passport-map-stats{justify-content:center;gap:16px;padding:16px 0 8px;display:flex}.passport-map-stat{text-align:center}.passport-map-stat-num{color:var(--charcoal);font-family:Barlow Condensed,sans-serif;font-size:28px;font-weight:800;line-height:1}.passport-map-stat-label{color:var(--text-faint);text-transform:uppercase;letter-spacing:.08em;margin-top:4px;font-family:IBM Plex Mono,monospace;font-size:9px}.passport-map-legend{justify-content:center;gap:20px;padding:12px 0 4px;display:flex}.passport-map-legend-item{color:var(--text-faint);text-transform:uppercase;letter-spacing:.06em;align-items:center;gap:6px;font-family:IBM Plex Mono,monospace;font-size:10px;display:flex}.passport-map-legend-dot{border-radius:3px;width:10px;height:10px}.passport-map-loading{height:200px;color:var(--text-faint);letter-spacing:.04em;justify-content:center;align-items:center;font-family:IBM Plex Mono,monospace;font-size:12px;display:flex}.passport-map-country-tooltip{background:var(--charcoal);color:#fff;letter-spacing:.02em;pointer-events:none;z-index:1010;white-space:nowrap;border-radius:8px;padding:6px 12px;font-family:Barlow Condensed,sans-serif;font-size:13px;font-weight:600;position:fixed;transform:translate(-50%,-120%);box-shadow:0 2px 8px #0003}.passport-map-country-tooltip .tooltip-flag{object-fit:cover;vertical-align:middle;border-radius:1px;width:18px;height:13px;margin-right:6px}.passport-detail-hero{background-position:50%;background-size:cover;height:160px;position:relative}.passport-detail-hero-overlay{background:linear-gradient(#0000 30%,#0009);align-items:flex-end;gap:10px;padding:16px 20px;display:flex;position:absolute;inset:0}.passport-detail-flag-img{border-radius:4px;width:48px;height:auto;box-shadow:0 1px 6px #0000004d}.passport-detail-name{text-transform:uppercase;letter-spacing:.04em;color:#fff;text-shadow:0 1px 6px #0006;font-family:Barlow Condensed,sans-serif;font-size:24px;font-weight:900}.confirm-delete{background:#fdf0ee;border:1px solid #e8c4be;border-radius:12px;margin-top:12px;padding:16px;animation:.2s fadeIn}.confirm-delete-text{color:#9e3c2f;margin-bottom:12px;font-family:Lora,serif;font-size:14px;line-height:1.5}.confirm-delete-btns{gap:10px;display:flex}.btn-confirm-yes{letter-spacing:.08em;text-transform:uppercase;color:#fff;cursor:pointer;background:#9e3c2f;border:none;border-radius:10px;flex:1;padding:12px;font-family:Barlow Condensed,sans-serif;font-size:13px;font-weight:600}.btn-confirm-yes:disabled{opacity:.5}.btn-confirm-no{letter-spacing:.08em;text-transform:uppercase;background:var(--cream);color:var(--charcoal);border:1px solid var(--border-med);cursor:pointer;border-radius:10px;flex:1;padding:12px;font-family:Barlow Condensed,sans-serif;font-size:13px;font-weight:600}.edit-rating-section{background:var(--cream);border:1px solid var(--border-med);border-radius:12px;margin-top:12px;padding:16px;animation:.2s fadeIn}.edit-rating-btns{gap:10px;margin-top:12px;display:flex}.item-detail-notes{color:var(--text-dim);background:var(--cream);border:1px solid var(--border);border-radius:12px;margin-top:16px;padding:16px;font-family:Lora,serif;font-size:15px;font-style:italic;line-height:1.6}.item-detail-notes-label{letter-spacing:.15em;text-transform:uppercase;color:var(--terracotta);margin-top:20px;margin-bottom:8px;font-family:IBM Plex Mono,monospace;font-size:10px}.reading-log{margin-top:20px}.reading-log-header{letter-spacing:.15em;text-transform:uppercase;color:var(--terracotta);cursor:pointer;justify-content:space-between;align-items:center;margin-bottom:10px;padding:8px 0;font-family:IBM Plex Mono,monospace;font-size:10px;display:flex}.reading-log-toggle{color:var(--text-faint);font-size:11px;transition:transform .2s}.reading-log-toggle.open{transform:rotate(180deg)}.reading-log-count{color:var(--text-faint);letter-spacing:.05em;font-size:10px;font-weight:400}.log-entry{background:var(--cream);border:1px solid var(--border);border-radius:10px;margin-bottom:6px;transition:border-color .15s;overflow:hidden}.log-entry:hover{border-color:var(--border-med)}.log-entry-header{cursor:pointer;justify-content:space-between;align-items:center;gap:10px;padding:12px 14px;display:flex}.log-entry-pages{color:var(--charcoal);white-space:nowrap;font-family:IBM Plex Mono,monospace;font-size:12px;font-weight:500}.log-entry-date{color:var(--text-faint);white-space:nowrap;font-family:IBM Plex Mono,monospace;font-size:10px}.log-entry-preview{color:var(--text-dim);white-space:nowrap;text-overflow:ellipsis;flex:1;min-width:0;font-family:Lora,serif;font-size:13px;overflow:hidden}.log-entry-toggle{color:var(--text-faint);flex-shrink:0;font-size:12px;transition:transform .2s}.log-entry-toggle.open{transform:rotate(180deg)}.log-entry-body{color:var(--text-dim);border-top:1px solid var(--border);padding:12px 14px 14px;font-family:Lora,serif;font-size:14px;line-height:1.6}.log-empty{color:var(--text-faint);text-align:center;padding:16px 0;font-family:Lora,serif;font-size:13px;font-style:italic}.update-notes-input{background:var(--cream);border:1px solid var(--border-med);width:100%;color:var(--charcoal);resize:none;border-radius:10px;outline:none;min-height:50px;margin-top:12px;padding:12px 14px;font-family:Lora,serif;font-size:14px;transition:border-color .15s}.update-notes-input::placeholder{color:var(--text-faint);font-style:italic}.update-notes-input:focus{border-color:var(--terracotta)}.save-status{letter-spacing:.06em;border-radius:10px;justify-content:center;align-items:center;gap:8px;margin-top:12px;padding:10px 16px;font-family:IBM Plex Mono,monospace;font-size:12px;animation:.2s fadeIn;display:flex}.save-status.saving{background:var(--cream);color:var(--text-dim);border:1px solid var(--border-med)}.save-status.saved{color:#2d6a2e;background:#e8f5e2;border:1px solid #b8ddb5}.save-status.error{color:#9e3c2f;background:#fdf0ee;border:1px solid #e8c4be}.save-spinner{border:2px solid var(--border-med);border-top-color:var(--terracotta);border-radius:50%;width:14px;height:14px;animation:.6s linear infinite spin}.btn-spinner{border:2px solid #ffffff4d;border-top-color:#fff;border-radius:50%;flex-shrink:0;width:12px;height:12px;animation:.6s linear infinite spin}.saving-toast{z-index:1100;background:var(--charcoal);color:#fff;letter-spacing:.06em;border-radius:100px;align-items:center;gap:8px;padding:10px 20px;font-family:IBM Plex Mono,monospace;font-size:11px;animation:.25s savingToastIn;display:flex;position:fixed;top:16px;left:50%;transform:translate(-50%);box-shadow:0 4px 16px #0003}.saving-toast .btn-spinner{border-color:#fff3;border-top-color:var(--terracotta)}@keyframes savingToastIn{0%{opacity:0;transform:translate(-50%)translateY(-10px)}to{opacity:1;transform:translate(-50%)translateY(0)}}.notes-input{background:var(--cream);border:1px solid var(--border-med);width:100%;color:var(--charcoal);resize:none;border-radius:10px;outline:none;min-height:60px;margin-bottom:20px;padding:12px 14px;font-family:Lora,serif;font-size:14px;transition:border-color .15s}.notes-input::placeholder{color:var(--text-faint);font-style:italic}.notes-input:focus{border-color:var(--terracotta)}.btn-shelf-it{background:linear-gradient(135deg, var(--terracotta), var(--terra-light));width:100%;color:var(--warm-white);letter-spacing:.12em;text-transform:uppercase;cursor:pointer;border:none;border-radius:12px;padding:16px;font-family:Barlow Condensed,sans-serif;font-size:18px;font-weight:700;transition:opacity .15s,transform .1s;box-shadow:0 4px 16px #c4734f4d,0 2px 6px #c4734f26}.btn-shelf-it:hover{opacity:.9}.btn-shelf-it:active{transform:scale(.98)}.btn-shelf-it:disabled{opacity:.4;cursor:not-allowed}.book-status-toggle{border:1px solid var(--border-med);border-radius:10px;gap:0;margin-bottom:20px;display:flex;overflow:hidden}.book-status-btn{letter-spacing:.05em;text-transform:uppercase;background:var(--cream);color:var(--text-dim);border:none;border-right:1px solid var(--border);cursor:pointer;flex:1;padding:10px 6px;font-family:Barlow Condensed,sans-serif;font-size:12px;font-weight:600;transition:all .15s}.book-status-btn:last-child{border-right:none}.book-status-btn.active{background:var(--terracotta);color:var(--warm-white)}.page-tracker{margin-bottom:20px}.page-tracker-row{align-items:center;gap:10px;display:flex}.page-input{background:var(--cream);border:1px solid var(--border-med);width:80px;color:var(--charcoal);text-align:center;-moz-appearance:textfield;border-radius:10px;outline:none;padding:10px 12px;font-family:IBM Plex Mono,monospace;font-size:16px;font-weight:500;transition:border-color .15s}.page-input::-webkit-outer-spin-button{-webkit-appearance:none}.page-input::-webkit-inner-spin-button{-webkit-appearance:none}.page-input:focus{border-color:var(--terracotta)}select.page-input{appearance:none;cursor:pointer;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%23666' d='M6 8L1 3h10z'/%3E%3C/svg%3E");background-position:right 8px center;background-repeat:no-repeat;padding-right:24px}.page-separator{color:var(--text-faint);font-family:IBM Plex Mono,monospace;font-size:14px}.page-label-text{color:var(--text-dim);font-family:IBM Plex Mono,monospace;font-size:11px}.page-progress-bar{background:var(--cream-dark);border-radius:3px;width:100%;height:6px;margin-top:10px;overflow:hidden}.page-progress-fill{background:var(--terracotta);border-radius:3px;height:100%;transition:width .3s}.event-cards{flex-direction:column;gap:10px;display:flex}.event-card{cursor:pointer;min-height:100px;box-shadow:0 2px 8px var(--shadow), 0 4px 16px #2c28240a;border-radius:16px;transition:transform .2s cubic-bezier(.25,.46,.45,.94);position:relative;overflow:hidden}.event-card:hover{transform:scale(1.01)}.event-card-bg{filter:brightness(.55);background-position:50%;background-size:cover;position:absolute;inset:0}.event-card-bg-fallback{justify-content:center;align-items:center;font-size:36px;display:flex;position:absolute;inset:0}.event-card-icon.trophy-bg{background:linear-gradient(135deg,#d4a84326,#c4734f1a)}.event-card-icon.ondeck-bg{background:linear-gradient(135deg,#8b9e7e33,#8b9e7e14)}.event-card-content{z-index:1;flex-direction:column;justify-content:flex-end;min-height:100px;padding:18px 20px;display:flex;position:relative}.event-card-content.has-image{text-shadow:0 1px 4px #00000080}.event-card-title{letter-spacing:.06em;text-transform:uppercase;color:var(--charcoal);font-family:Barlow Condensed,sans-serif;font-size:20px;font-weight:700;line-height:1.2}.event-card-content.has-image .event-card-title{color:#fff}.event-card-detail{color:var(--terracotta);margin-top:4px;font-family:IBM Plex Mono,monospace;font-size:11px}.event-card-content.has-image .event-card-detail{color:#ffffffd9}.event-card-date{color:var(--text-faint);margin-top:2px;font-family:IBM Plex Mono,monospace;font-size:10px}.event-card-content.has-image .event-card-date{color:#ffffffb3}.trophy-hero{cursor:pointer;border-radius:12px;position:relative;overflow:hidden}.trophy-hero img{aspect-ratio:2.2;object-fit:cover;width:100%;display:block}.trophy-hero-fallback{aspect-ratio:2.2;background:linear-gradient(135deg,#d4a84326,#c4734f1a);justify-content:center;align-items:center;width:100%;font-size:42px;display:flex}.trophy-hero-gradient{pointer-events:none;background:linear-gradient(#0000 0%,#14100ccc 100%);height:70%;position:absolute;bottom:0;left:0;right:0}.trophy-hero-content{color:#fff;justify-content:space-between;align-items:flex-end;gap:10px;padding:14px 16px;display:flex;position:absolute;bottom:0;left:0;right:0}.trophy-hero-event{letter-spacing:.04em;text-transform:uppercase;text-shadow:0 1px 3px #0000004d;font-family:Barlow Condensed,sans-serif;font-size:17px;font-weight:900}.trophy-hero-meta{color:#ffffffa6;margin-top:2px;font-family:IBM Plex Mono,monospace;font-size:9px}.trophy-hero-time{color:#fff;white-space:nowrap;text-shadow:0 1px 3px #0000004d;font-family:IBM Plex Mono,monospace;font-size:15px;font-weight:600}.trophy-minis{gap:8px;margin-top:10px;display:flex}.trophy-mini{cursor:pointer;border:1px solid var(--border);border-radius:8px;flex:1;position:relative;overflow:hidden}.trophy-mini img{aspect-ratio:16/10;object-fit:cover;width:100%;display:block}.trophy-mini-fallback{aspect-ratio:16/10;background:linear-gradient(135deg,#d4a8431a,#c4734f0f);justify-content:center;align-items:center;width:100%;font-size:20px;display:flex}.trophy-mini-label{letter-spacing:.03em;text-transform:uppercase;color:#fff;background:linear-gradient(#0000,#14100cbf);padding:4px 6px;font-family:Barlow Condensed,sans-serif;font-size:9px;font-weight:700;position:absolute;bottom:0;left:0;right:0}.trophy-mini-more{background:var(--cream-dark);border:1px solid var(--border);color:var(--text-dim);cursor:pointer;border-radius:8px;flex:1;justify-content:center;align-items:center;min-height:52px;font-size:10px;font-weight:600;display:flex}.trophy-case-list{flex-direction:column;gap:14px;padding:14px 16px;display:flex}.trophy-overlay-card{cursor:pointer;border-radius:12px;position:relative;overflow:hidden}.trophy-overlay-card img{aspect-ratio:16/10;object-fit:cover;width:100%;display:block}.trophy-overlay-card-fallback{aspect-ratio:16/10;background:linear-gradient(135deg,#d4a84326,#c4734f1a);justify-content:center;align-items:center;width:100%;font-size:48px;display:flex}.trophy-overlay-gradient{pointer-events:none;background:linear-gradient(#0000 0%,#14100c66 40%,#14100cd9 100%);height:65%;position:absolute;bottom:0;left:0;right:0}.trophy-overlay-content{color:#fff;justify-content:space-between;align-items:flex-end;gap:10px;padding:14px 16px;display:flex;position:absolute;bottom:0;left:0;right:0}.trophy-overlay-event{letter-spacing:.05em;text-transform:uppercase;text-shadow:0 1px 3px #0000004d;font-family:Barlow Condensed,sans-serif;font-size:19px;font-weight:900}.trophy-overlay-meta{color:#ffffffa6;margin-top:3px;font-family:IBM Plex Mono,monospace;font-size:9px}.trophy-overlay-result{-webkit-backdrop-filter:blur(8px);color:#fff;white-space:nowrap;background:#ffffff26;border:1px solid #fff3;border-radius:14px;align-items:center;gap:4px;padding:4px 10px;font-family:IBM Plex Mono,monospace;font-size:13px;font-weight:600;display:inline-flex}.trophy-photo-area{cursor:pointer;border-radius:14px;width:100%;height:160px;margin-bottom:16px;position:relative;overflow:hidden}.trophy-photo-area img{object-fit:cover;width:100%;height:100%}.trophy-photo-overlay-btn{-webkit-backdrop-filter:blur(6px);color:#fff;background:#00000080;border-radius:50%;justify-content:center;align-items:center;width:32px;height:32px;font-size:14px;display:flex;position:absolute;bottom:8px;right:8px}.trophy-photo-empty{border:2px dashed var(--border);background:#c4734f0a;border-radius:14px;flex-direction:column;justify-content:center;align-items:center;gap:4px;width:100%;height:100%;display:flex}.trophy-repo-controls{background:linear-gradient(#0000,#000000b3);justify-content:space-between;align-items:center;padding:8px 10px;display:flex;position:absolute;bottom:0;left:0;right:0}.trophy-repo-hint{color:#fffc;letter-spacing:.04em;font-family:IBM Plex Mono,monospace;font-size:10px}.trophy-repo-btn{background:var(--terracotta);color:#fff;cursor:pointer;border:none;border-radius:6px;padding:5px 14px;font-family:IBM Plex Mono,monospace;font-size:11px;font-weight:600}.trophy-repo-cancel{-webkit-backdrop-filter:blur(6px);background:#fff3}.toast{background:var(--charcoal);color:var(--cream);z-index:500;border-radius:10px;padding:12px 20px;font-family:IBM Plex Mono,monospace;font-size:12px;animation:.35s cubic-bezier(.34,1.56,.64,1) toastIn;position:fixed;top:20px;left:50%;overflow:hidden;transform:translate(-50%);box-shadow:0 4px 20px #0003,0 0 0 1px #ffffff0f}.toast:after{content:"";background:linear-gradient(90deg, var(--terracotta), #d4a84399);border-radius:0 0 10px 10px;height:2px;animation:2.2s linear forwards toastProgress;position:absolute;bottom:0;left:0}.toast-exit{animation:.3s cubic-bezier(.4,0,1,1) forwards toastOut}.toast-exit:after{width:0;animation:none}@keyframes toastIn{0%{opacity:0;transform:translate(-50%)translateY(-16px)scale(.95)}to{opacity:1;transform:translate(-50%)translateY(0)scale(1)}}@keyframes toastOut{0%{opacity:1;transform:translate(-50%)translateY(0)scale(1)}to{opacity:0;transform:translate(-50%)translateY(-12px)scale(.95)}}@keyframes toastProgress{0%{width:100%}to{width:0%}}.overlay-slide-up{animation:.3s cubic-bezier(.2,.9,.3,1) overlaySlideUp}@keyframes overlaySlideUp{0%{opacity:0;transform:translateY(40px)}to{opacity:1;transform:translateY(0)}}.ptr-indicator{justify-content:center;align-items:center;height:0;transition:height .2s;display:flex;overflow:hidden}.ptr-indicator.pulling{transition:none}.ptr-spinner{border:2px solid #c4734f33;border-top-color:var(--terracotta);border-radius:50%;width:22px;height:22px;animation:.6s linear infinite ptrSpin}.ptr-arrow{color:var(--text-faint);font-size:16px;transition:transform .2s}.ptr-arrow.ready{color:var(--terracotta);transform:rotate(180deg)}@keyframes ptrSpin{to{transform:rotate(360deg)}}.loading-screen{background:var(--cream);flex-direction:column;justify-content:center;align-items:center;min-height:100vh;animation:.3s loadFadeIn;display:flex}@keyframes loadFadeIn{0%{opacity:0}to{opacity:1}}@keyframes splashDots{0%,to{opacity:.2;transform:scale(.8)}50%{opacity:.8;transform:scale(1.2)}}.loading-brand{letter-spacing:.08em;text-transform:uppercase;color:var(--charcoal);font-family:Barlow Condensed,sans-serif;font-size:44px;font-weight:900;position:relative}.loading-brand-line{background:var(--terracotta);border-radius:2px;height:3px;margin-top:4px;display:block}.loading-spinner{border:2px solid var(--border-med);border-top-color:var(--terracotta);border-radius:50%;width:24px;height:24px;margin-top:24px;animation:.8s linear infinite spin}.skel-shimmer{background:linear-gradient(90deg, var(--card) 25%, #ffffff0f 50%, var(--card) 75%);background-size:800px 100%;border-radius:10px;animation:1.6s ease-in-out infinite shimmer}.skel-section{margin-bottom:28px}.skel-label{border-radius:7px;width:120px;height:14px;margin-bottom:12px}.skel-surface{background:var(--card);border:1px solid var(--border);border-radius:14px;padding:20px}.skel-training-grid{grid-template-columns:1fr 1fr;gap:8px;display:grid}.skel-training-tile{aspect-ratio:1;border-radius:14px}.skel-cover-row{gap:10px;display:flex}.skel-cover{border-radius:4px;flex-shrink:0;width:68px;height:96px}@keyframes spin{to{transform:rotate(360deg)}}
