/* ═══════════════════════════════════════════════
   Movies — page-specific styles
   Loaded after shared.css.
   ═══════════════════════════════════════════════ */

/* ── Page-identity colour — overrides shared.css cascade ── */
:root{--primary:#1A5FA8;--primary-lt:#E6F0FB;--primary-md:#9BBFDF;--primary-dk:#0D3D70;--bg:#F2F6FC;}
[data-theme]{--primary:#1A5FA8;--primary-lt:#E6F0FB;--primary-md:#9BBFDF;--primary-dk:#0D3D70;}
[data-theme="harvey"]{--primary:#1A5FA8;--primary-lt:#E6F0FB;--primary-md:#9BBFDF;--primary-dk:#0D3D70;}
[data-theme="purple"]{--primary:#1A5FA8;--primary-lt:#E6F0FB;--primary-md:#9BBFDF;--primary-dk:#0D3D70;}
[data-theme="brown"]{--primary:#1A5FA8;--primary-lt:#E6F0FB;--primary-md:#9BBFDF;--primary-dk:#0D3D70;}
[data-theme="green"]{--primary:#1A5FA8;--primary-lt:#E6F0FB;--primary-md:#9BBFDF;--primary-dk:#0D3D70;}
[data-theme="blue"]{--primary:#1A5FA8;--primary-lt:#E6F0FB;--primary-md:#9BBFDF;--primary-dk:#0D3D70;}
[data-theme-override="dark"]{--primary:#1A5FA8;--primary-lt:#E6F0FB;--primary-md:#9BBFDF;--primary-dk:#0D3D70;--bg:#101620;}
[data-theme-override="light"]{--primary:#1A5FA8;--primary-lt:#E6F0FB;--primary-md:#9BBFDF;--primary-dk:#0D3D70;}
@media(prefers-color-scheme:dark){:root:not([data-theme-override="light"]){--bg:#101620;}}

/* ── Direction 3 nav — movies identity colour ── */
.bottom-nav{background:#060F1A !important;}
.nav-btn.active{background:#1A5FA8 !important;color:#fff !important;}

/* ── Back button ── */
.back-btn{display:flex;align-items:center;gap:4px;background:none;border:none;color:var(--primary);font-size:13px;cursor:pointer;font-family:inherit;padding:0;}
.back-btn svg{flex-shrink:0;}

/* ── Page header tweaks ── */
.page-header{padding:max(1rem,env(safe-area-inset-top)) 1.25rem .5rem;}
.icon-btn{background:none;border:0.5px solid var(--border);border-radius:var(--radius-sm);color:var(--muted);cursor:pointer;font-size:13px;font-family:inherit;padding:5px 9px;}

/* ── Loading bar ── */
.loading-bar{height:3px;background:var(--gray-lt);overflow:hidden;display:none;}
.loading-bar.active{display:block;}
.loading-fill{height:100%;background:var(--primary);animation:load 1.2s ease-in-out infinite;transform-origin:left;}
@keyframes load{0%{transform:scaleX(0)translateX(0);}50%{transform:scaleX(.5)translateX(100px);}100%{transform:scaleX(0)translateX(400px);}}

/* ── Search ── */
.search-wrap{padding:0 1.25rem .5rem;position:relative;}
.search-input::placeholder{color:var(--muted);}
.search-icon{position:absolute;left:2rem;top:50%;transform:translateY(-50%);color:var(--muted);pointer-events:none;}
.search-clear{position:absolute;right:2rem;top:50%;transform:translateY(-50%);background:none;border:none;color:var(--muted);cursor:pointer;font-size:15px;display:none;}

/* ── Filter bar ── */
.filter-bar{padding:0 1.25rem .5rem;display:flex;gap:6px;flex-wrap:wrap;align-items:center;position:sticky;top:57px;z-index:19;background:var(--bg);}
.filter-select{background:var(--surface);border:0.5px solid var(--border);border-radius:99px;padding:4px 10px;font-size:12px;color:var(--text);font-family:inherit;outline:none;cursor:pointer;appearance:none;-webkit-appearance:none;}
.filter-select.active-filter{background:var(--primary-lt);border-color:var(--primary);color:var(--primary);font-weight:600;}
.sort-btn{background:var(--surface);border:0.5px solid var(--border);border-radius:99px;padding:4px 10px;font-size:12px;color:var(--muted);font-family:inherit;cursor:pointer;white-space:nowrap;}
.sort-btn.active{background:var(--primary-lt);border-color:var(--primary);color:var(--primary);font-weight:600;}

/* ── Movie cards — compact ── */
.movie-list{padding:0 1.25rem;}
.movie-card{display:flex;gap:10px;background:var(--surface);border:0.5px solid var(--border);border-radius:var(--radius);padding:.65rem;margin-bottom:.5rem;cursor:pointer;}
.movie-poster{width:42px;height:62px;border-radius:5px;background:var(--gray-lt);flex-shrink:0;display:flex;align-items:center;justify-content:center;font-size:18px;overflow:hidden;}
.movie-poster img{width:100%;height:100%;object-fit:cover;border-radius:5px;}
.movie-info{flex:1;min-width:0;}
.movie-top{display:flex;justify-content:space-between;align-items:flex-start;gap:4px;margin-bottom:2px;}
.movie-title{font-size:13px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;flex:1;}
.movie-ratings-top{display:flex;flex-direction:column;gap:1px;flex-shrink:0;align-items:flex-end;}
.movie-rating-row{display:flex;align-items:center;gap:3px;font-size:10px;color:var(--muted);}
.movie-meta{font-size:10px;color:var(--muted);margin-bottom:3px;}
.movie-bottom{display:flex;align-items:center;justify-content:space-between;gap:4px;}
.movie-genres{display:flex;flex-wrap:wrap;gap:3px;}
.genre-tag{font-size:9px;padding:1px 6px;border-radius:99px;background:var(--gray-lt);color:var(--muted);}
.watched-badge{font-size:9px;color:var(--green-dk);background:var(--green-lt);padding:2px 7px;border-radius:99px;white-space:nowrap;flex-shrink:0;}
.watchlist-badge{font-size:9px;color:var(--muted);background:var(--gray-lt);padding:2px 7px;border-radius:99px;}

/* ── Stars display ── */
.star{font-size:11px;color:var(--primary);}
.star.empty{color:var(--gray-lt);}

/* ── Stats ── */
.stat-grid{display:grid;grid-template-columns:1fr 1fr;gap:.65rem;padding:0 1.25rem .75rem;}
.stat-card{background:var(--surface);border:0.5px solid var(--border);border-radius:var(--radius);padding:1rem;}
.stat-num{font-size:22px;font-weight:600;color:var(--primary);margin-bottom:2px;}
.stat-lbl{font-size:11px;color:var(--muted);text-transform:uppercase;letter-spacing:.05em;}
.stat-sub{font-size:12px;color:var(--muted);margin-top:3px;}
.genre-bar-row{display:flex;align-items:center;gap:10px;margin-bottom:.6rem;}
.genre-bar-label{font-size:12px;color:var(--text);width:90px;flex-shrink:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}
.genre-bar-track{flex:1;height:5px;background:var(--gray-lt);border-radius:99px;overflow:hidden;}
.genre-bar-fill{height:100%;background:var(--primary);border-radius:99px;}
.genre-bar-count{font-size:11px;color:var(--muted);width:20px;text-align:right;}
.genre-detail{background:var(--surface);border:0.5px solid var(--border);border-radius:var(--radius);margin:0 1.25rem .65rem;padding:.9rem;cursor:pointer;}
.genre-detail:hover{border-color:var(--primary-md);}
.genre-detail-head{font-size:15px;font-weight:600;display:flex;justify-content:space-between;align-items:center;margin-bottom:.65rem;}
.genre-pill{font-size:10px;background:var(--primary-lt);color:var(--primary-dk);padding:2px 9px;border-radius:99px;}
.genre-mini-grid{display:grid;grid-template-columns:1fr 1fr 1fr;gap:.4rem;margin-bottom:.4rem;}
.genre-mini-num{font-size:15px;font-weight:600;color:var(--primary);}
.genre-mini-lbl{font-size:10px;color:var(--muted);text-transform:uppercase;letter-spacing:.04em;}
.genre-detail-sub{font-size:11px;color:var(--muted);margin-top:3px;}
.genre-films-list{margin-top:.75rem;border-top:0.5px solid var(--border);padding-top:.75rem;display:none;}
.genre-film-row{display:flex;justify-content:space-between;align-items:center;padding:.4rem 0;border-bottom:0.5px solid var(--border);font-size:12px;}
.genre-film-row:last-child{border-bottom:none;}

/* ── Date filter ── */
.date-filter-row{display:flex;align-items:center;gap:8px;padding:0 1.25rem .75rem;flex-wrap:wrap;}
.date-filter-row label{font-size:12px;color:var(--muted);}
.date-filter-row input[type=date]{background:var(--surface);border:0.5px solid var(--border);border-radius:var(--radius-sm);padding:5px 8px;font-size:12px;color:var(--text);font-family:inherit;outline:none;}
.date-filter-row input[type=date]:focus{border-color:var(--primary);}
.clear-date-btn{font-size:12px;color:var(--muted);background:none;border:none;cursor:pointer;font-family:inherit;}
.empty-msg{text-align:center;padding:2.5rem 1.5rem;color:var(--muted);font-size:13px;line-height:1.8;}

/* ── Form extras ── */
.field label .hint{font-size:10px;font-weight:400;text-transform:none;letter-spacing:0;color:var(--muted);font-style:italic;}
.field{margin-bottom:.9rem;}
.search-results{background:var(--surface);border:0.5px solid var(--border);border-radius:var(--radius);margin-bottom:.75rem;overflow:hidden;}
.search-result-item{padding:.75rem 1rem;border-bottom:0.5px solid var(--border);cursor:pointer;}
.search-result-item:last-child{border-bottom:none;}
.search-result-item:active{background:var(--gray-lt);}
.sr-title{font-size:13px;font-weight:500;margin-bottom:2px;}
.sr-meta{font-size:11px;color:var(--muted);}
.searching-msg{padding:1rem;text-align:center;font-size:13px;color:var(--muted);}
.show-more-btn{width:100%;padding:.65rem;background:var(--gray-lt);border:none;border-radius:0 0 var(--radius) var(--radius);font-size:12px;color:var(--primary);cursor:pointer;font-family:inherit;font-weight:600;}
.status-toggle{display:flex;gap:6px;margin-bottom:.9rem;}
.status-btn{flex:1;padding:.6rem;border-radius:var(--radius-sm);border:0.5px solid var(--border);background:transparent;color:var(--muted);font-size:13px;cursor:pointer;font-family:inherit;}
.status-btn.active{background:var(--primary-lt);border-color:var(--primary);color:var(--primary);font-weight:600;}
.star-input{display:flex;gap:2px;}
.star-input-btn{font-size:26px;background:none;border:none;cursor:pointer;padding:0;color:var(--gray-lt);line-height:1;}
.star-input-btn.active{color:var(--primary);}

/* ── Calendar ── */
.cal-header{display:flex;justify-content:space-between;align-items:center;padding:1rem 1.25rem .75rem;border-bottom:0.5px solid var(--border);}
.cal-title-text{font-size:16px;font-weight:600;}
.cal-body{overflow-y:auto;padding:1rem 1.25rem;max-height:80vh;}
.cal-nav-btn{background:var(--gray-lt);border:none;border-radius:var(--radius-sm);padding:5px 13px;color:var(--text);font-size:16px;cursor:pointer;}
.cal-month-lbl{font-size:16px;font-weight:600;}
.cal-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:3px;margin-bottom:.75rem;}
.cal-dow{font-size:10px;font-weight:600;color:var(--muted);text-align:center;padding:4px 0;text-transform:uppercase;}
.cal-day{min-height:38px;border-radius:6px;padding:3px;font-size:11px;cursor:default;text-align:center;}
.cal-day.today .cal-dn{background:var(--primary);color:#fff;border-radius:50%;width:20px;height:20px;display:inline-flex;align-items:center;justify-content:center;}
.cal-day.other{opacity:.3;}
.cal-day.has-event{cursor:pointer;}
.cal-dn{font-size:11px;margin-bottom:2px;display:inline-block;}
.cal-pips{display:flex;justify-content:center;gap:2px;}
.cal-pip{width:5px;height:5px;border-radius:50%;background:var(--primary);}
.cal-ev{display:flex;align-items:flex-start;gap:8px;padding:.65rem .75rem;background:var(--gray-lt);border-radius:var(--radius-sm);margin-bottom:.5rem;cursor:pointer;}
.cal-ev-dot{width:8px;height:8px;border-radius:50%;background:var(--primary);margin-top:4px;flex-shrink:0;}
.cal-ev-name{font-size:13px;font-weight:500;}
.cal-ev-meta{font-size:11px;color:var(--muted);}

/* ── Login screen (movies-local overrides) ── */
.login-title{font-size:26px !important;font-weight:800 !important;letter-spacing:-0.5px !important;}
.login-btn{border-radius:14px !important;font-weight:800 !important;font-size:15px !important;}
.login-avatar{border-radius:16px !important;}
.pin-key{border-radius:16px !important;}

/* ── Hero / savings card overrides (present in source) ── */
.hero-card{border-radius:20px;background:var(--primary-lt) !important;color:var(--primary-dk);}
.hero-amount{font-weight:800 !important;font-size:34px !important;color:var(--primary) !important;}
.hero-meta-val{color:var(--primary) !important;}
.hero-label{color:var(--primary-dk);opacity:0.7;}
