/* ═══════════════════════════════════════════════
   Harvey Family App — Home page styles (index.html)
   Loaded after shared.css.
   ═══════════════════════════════════════════════ */

/* ── Login screen ── */
.login-screen{position:fixed;inset:0;background:linear-gradient(160deg,var(--primary-dk) 0%,var(--primary) 60%,var(--primary-md) 100%);z-index:999;display:flex;flex-direction:column;align-items:center;justify-content:center;max-width:480px;margin:0 auto;padding:2rem;overflow:hidden;}
.login-screen.hidden{display:none;}
.login-screen::before{content:'';position:absolute;top:-80px;right:-80px;width:260px;height:260px;background:rgba(255,255,255,.06);border-radius:50%;pointer-events:none;}
.login-screen::after{content:'';position:absolute;bottom:-60px;left:-60px;width:200px;height:200px;background:rgba(255,255,255,.04);border-radius:50%;pointer-events:none;}
.login-logo{width:72px;height:72px;background:rgba(255,255,255,0.18);border-radius:22px;display:flex;align-items:center;justify-content:center;font-size:36px;font-weight:700;color:#fff;margin-bottom:16px;backdrop-filter:blur(8px);box-shadow:0 4px 24px rgba(0,0,0,.15);}
.login-title{font-size:24px;font-weight:700;color:#fff;margin-bottom:4px;letter-spacing:-.3px;}
.login-sub{font-size:13px;color:rgba(255,255,255,.6);margin-bottom:36px;}
.login-card{background:rgba(255,255,255,0.11);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border:1px solid rgba(255,255,255,.18);border-radius:20px;padding:1.75rem 1.5rem;width:100%;max-width:320px;box-shadow:0 8px 32px rgba(0,0,0,.2);}
/* User avatars */
.login-avatars{display:flex;gap:12px;margin-bottom:1.5rem;}
.login-avatar{flex:1;display:flex;flex-direction:column;align-items:center;gap:8px;padding:1rem .5rem;background:rgba(255,255,255,.1);border:2px solid transparent;border-radius:14px;cursor:pointer;transition:all .2s;font-family:inherit;}
.login-avatar:hover{background:rgba(255,255,255,.15);}
.login-avatar.selected{background:rgba(255,255,255,.22);border-color:rgba(255,255,255,.7);transform:translateY(-2px);box-shadow:0 4px 16px rgba(0,0,0,.15);}
.login-avatar-circle{width:52px;height:52px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:22px;font-weight:700;color:#fff;}
.login-avatar-name{font-size:13px;font-weight:600;color:#fff;}
/* Password area */
.login-pw-area{overflow:hidden;transition:max-height .4s ease,opacity .3s ease;max-height:0;opacity:0;}
.login-pw-area.visible{max-height:520px;opacity:1;}
.login-pw-wrap{position:relative;margin-bottom:.85rem;}
.login-pw-input{width:100%;background:rgba(255,255,255,.15);border:1px solid rgba(255,255,255,.2);border-radius:11px;padding:.8rem 2.75rem .8rem 1rem;font-size:15px;color:#fff;font-family:inherit;outline:none;transition:border-color .15s;}
.login-pw-input:focus{border-color:rgba(255,255,255,.55);}
.login-pw-input::placeholder{color:rgba(255,255,255,.45);}
.login-pw-toggle{position:absolute;right:.85rem;top:50%;transform:translateY(-50%);background:none;border:none;color:rgba(255,255,255,.6);cursor:pointer;font-size:16px;line-height:1;padding:0;}
.login-btn{width:100%;background:#fff;color:var(--primary);border:none;border-radius:11px;padding:.9rem;font-size:15px;font-weight:700;cursor:pointer;font-family:inherit;transition:opacity .15s,transform .1s;letter-spacing:-.1px;}
.login-btn:hover{opacity:.93;}
.login-btn:active{transform:scale(.98);}
.login-btn:disabled{opacity:.5;cursor:default;transform:none;}
.login-error{font-size:12px;color:rgba(255,255,255,.9);text-align:center;margin-top:.65rem;min-height:18px;background:rgba(255,0,0,.15);border-radius:8px;padding:.35rem .75rem;display:none;}
.login-error.visible{display:block;}
.login-forgot{background:none;border:none;color:rgba(255,255,255,.5);font-size:12px;cursor:pointer;font-family:inherit;display:block;margin:.85rem auto 0;text-decoration:underline;transition:color .15s;}
.login-forgot:hover{color:rgba(255,255,255,.8);}
/* ── PIN pad ── */
.pin-area{text-align:center;}
.pin-dots{display:flex;justify-content:center;gap:18px;margin-bottom:1.25rem;}
.pin-dot{width:16px;height:16px;border-radius:50%;border:2px solid rgba(255,255,255,.5);transition:background .15s,border-color .15s;}
.pin-dot.filled{background:#fff;border-color:#fff;}
.pin-dot.shake{animation:pin-shake .35s;}
@keyframes pin-shake{0%,100%{transform:translateX(0);}25%{transform:translateX(-6px);}75%{transform:translateX(6px);}}
.pin-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin-bottom:.75rem;width:100%;}
.pin-key{background:rgba(255,255,255,.18);border:none;border-radius:14px;font-size:26px;font-weight:600;color:#fff;cursor:pointer;font-family:inherit;transition:background .1s;line-height:1;min-height:64px;display:flex;align-items:center;justify-content:center;-webkit-tap-highlight-color:transparent;touch-action:manipulation;}
.pin-key:active{background:rgba(255,255,255,.35);}
.pin-key.empty{background:none;cursor:default;pointer-events:none;}
.pin-key.del{font-size:22px;}
.pin-use-pw{background:none;border:none;color:rgba(255,255,255,.5);font-size:12px;cursor:pointer;font-family:inherit;text-decoration:underline;margin-top:.5rem;}
.pin-use-pw:hover{color:rgba(255,255,255,.8);}
.pin-attempts{font-size:11px;color:rgba(255,80,80,.95);min-height:16px;margin-bottom:.4rem;}
/* Widen card when PIN pad is showing */
.login-card.pin-mode{max-width:380px;padding:1.5rem 1.25rem;}
/* ── Setup PIN prompt ── */
.setup-pin-prompt{background:rgba(255,255,255,.12);border-radius:11px;padding:.85rem 1rem;margin-top:.75rem;text-align:center;}
.setup-pin-prompt p{font-size:12px;color:rgba(255,255,255,.8);margin-bottom:.6rem;line-height:1.4;}
.setup-pin-btn{background:rgba(255,255,255,.2);border:1px solid rgba(255,255,255,.35);border-radius:8px;padding:.45rem 1rem;font-size:12px;font-weight:600;color:#fff;cursor:pointer;font-family:inherit;}

/* ── Home screen ── */
.home-header{background:var(--primary);padding:max(1.5rem,env(safe-area-inset-top)) 1.25rem 1.5rem;display:flex;justify-content:space-between;align-items:flex-start;position:sticky;top:0;z-index:20;}
.menu-btn{background:none;border:none;cursor:pointer;padding:4px;display:flex;flex-direction:column;gap:4px;align-self:center;}
.menu-btn span{display:block;width:20px;height:2px;background:rgba(255,255,255,.8);border-radius:2px;}
.app-menu-overlay{position:fixed;inset:0;z-index:999;display:none;}
.app-menu-overlay.open{display:block;}
.app-menu-backdrop{position:absolute;inset:0;background:rgba(0,0,0,.4);}
.app-menu{position:absolute;top:0;right:0;width:75%;max-width:280px;height:100%;background:var(--surface);box-shadow:-4px 0 20px rgba(0,0,0,.2);display:flex;flex-direction:column;padding:max(3rem,env(safe-area-inset-top)) 0 2rem;overflow-y:auto;}
.app-menu-title{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.07em;color:var(--muted);padding:.75rem 1.25rem .35rem;}
.app-menu-item{display:flex;align-items:center;gap:12px;padding:.75rem 1.25rem;cursor:pointer;font-size:14px;font-weight:500;color:var(--text);text-decoration:none;border:none;background:none;width:100%;font-family:inherit;text-align:left;}
.app-menu-item:active{background:var(--gray-lt);}
.app-menu-icon{width:32px;height:32px;border-radius:8px;display:flex;align-items:center;justify-content:center;flex-shrink:0;}
.home-greeting{font-size:22px;font-weight:700;letter-spacing:-.3px;color:#fff;}
.home-date{font-size:12px;color:rgba(255,255,255,.65);margin-top:3px;}
.home-settings-btn{background:rgba(255,255,255,.18);border:none;border-radius:10px;width:36px;height:36px;display:flex;align-items:center;justify-content:center;cursor:pointer;color:#fff;}

/* ── Widgets ── */
.home-content{padding:.85rem 1.25rem 5rem;}
.widget-section-label{font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--muted);margin:.85rem 0 .4rem;}
.widget{background:var(--surface);border:0.5px solid var(--border);border-radius:var(--radius);overflow:hidden;margin-bottom:.6rem;}
.widget.accent-purple{border-left:3px solid var(--primary);}
.widget.accent-green{border-left:3px solid var(--green);}
.widget.accent-blue{border-left:3px solid var(--blue);}
.widget.accent-amber{border-left:3px solid var(--amber);}
.widget-pad{padding:.85rem 1rem;}
.widget-row{display:grid;grid-template-columns:1fr 1fr;gap:.6rem;margin-bottom:.6rem;}
.widget-lbl{font-size:10px;color:var(--muted);margin-bottom:2px;}
.widget-val{font-size:20px;font-weight:600;color:var(--primary);line-height:1.1;}
.widget-sub{font-size:10px;color:var(--muted);margin-top:3px;}
.widget-title{font-size:11px;font-weight:600;color:var(--muted);text-transform:uppercase;letter-spacing:.04em;margin-bottom:.5rem;}
.widget-item-row{display:flex;justify-content:space-between;align-items:center;padding:.45rem 0;border-bottom:0.5px solid var(--border);}
.widget-item-row:last-child{border-bottom:none;}
.widget-item-name{font-size:12px;color:var(--text);flex:1;min-width:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.widget-item-meta{font-size:11px;color:var(--muted);white-space:nowrap;margin-left:8px;}
.widget-item-meta.urgent{color:var(--red);}
.widget-item-meta.soon{color:var(--amber);}
.widget-dot{width:7px;height:7px;border-radius:50%;flex-shrink:0;margin-right:7px;}
.trip-progress{height:4px;background:var(--gray-lt);border-radius:99px;overflow:hidden;margin:.5rem 0 .3rem;}
.trip-progress-fill{height:100%;background:var(--primary);border-radius:99px;}
.movie-chip{display:inline-block;background:var(--gray-lt);border-radius:99px;font-size:10px;padding:2px 8px;color:var(--muted);margin:2px 2px 0 0;}
.settings-btn{background:var(--primary-lt);border:none;border-radius:10px;width:36px;height:36px;display:flex;align-items:center;justify-content:center;cursor:pointer;color:var(--primary);}

/* ── App grid ── */
.app-grid{display:grid;grid-template-columns:1fr 1fr;gap:.6rem;}
.app-tile{background:var(--surface);border:0.5px solid var(--border);border-radius:var(--radius);padding:.85rem .75rem;cursor:pointer;display:flex;flex-direction:row;align-items:center;gap:10px;transition:border-color .15s;text-decoration:none;color:inherit;}
.app-tile:active{border-color:var(--primary-md);}
.app-tile-icon{width:40px;height:40px;border-radius:11px;display:flex;align-items:center;justify-content:center;flex-shrink:0;}
.app-tile-name{font-size:14px;font-weight:600;line-height:1.2;}
.app-tile-sub{font-size:10px;color:var(--muted);margin-top:2px;line-height:1.3;}
.app-tile.coming-soon{opacity:.5;cursor:default;}

/* ── PIN setup modal dots ── */
.pin-setup-dots{display:flex;justify-content:center;gap:12px;margin-bottom:1.25rem;}
.psd{width:14px;height:14px;border-radius:50%;border:2px solid var(--border);background:transparent;transition:all .15s;}
.psd.filled{background:var(--primary);border-color:var(--primary);}
.psd.error{background:var(--red);border-color:var(--red);}
.pin-setup-pad{display:grid;grid-template-columns:repeat(3,64px);gap:10px;margin:0 auto;}
.psk{width:64px;height:64px;border-radius:50%;background:var(--primary-lt);border:none;font-size:20px;font-weight:500;color:var(--primary);cursor:pointer;display:flex;align-items:center;justify-content:center;font-family:inherit;}
.psk:active{background:var(--primary-md);}
.psk.del{font-size:16px;}
.psk.empty{background:transparent;pointer-events:none;}

/* ── Calendar ── */
.cal-section{padding:0 1.25rem 1rem;}
.cal-nav-row{display:flex;justify-content:space-between;align-items:center;margin-bottom:.75rem;}
.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;transition:opacity .15s;}
#cal-grid-clip{overflow:hidden;}
.cal-view-toggle{display:flex;gap:2px;background:var(--gray-lt);border-radius:8px;padding:2px;margin-bottom:.75rem;}
.cal-toggle-btn{flex:1;border:none;border-radius:6px;padding:4px 0;font-size:12px;font-weight:600;cursor:pointer;font-family:inherit;background:none;color:var(--muted);transition:all .15s;}
.cal-toggle-btn.active{background:var(--surface);color:var(--primary);box-shadow:0 1px 3px rgba(0,0,0,.12);}
.cal-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:2px;margin-bottom:.75rem;}
.cal-dow{font-size:10px;font-weight:600;color:var(--muted);text-align:center;padding:3px 0;text-transform:uppercase;}
.cal-day.cal-day-selected{background:var(--primary-lt);} [data-theme-override="dark"] .cal-day.cal-day-selected,[data-theme="purple"][data-theme-override="dark"] .cal-day.cal-day-selected{background:rgba(107,79,168,0.25);} [data-theme="blue"][data-theme-override="dark"] .cal-day.cal-day-selected{background:rgba(26,95,168,0.25);} [data-theme="green"][data-theme-override="dark"] .cal-day.cal-day-selected{background:rgba(46,125,82,0.25);} [data-theme="brown"][data-theme-override="dark"] .cal-day.cal-day-selected{background:rgba(124,92,62,0.25);}
.cal-ev-bar{pointer-events:none;}
.cal-day{min-height:52px;border-radius:6px;padding:3px 2px;font-size:11px;cursor:pointer;text-align:center;position:relative;}
.cal-day:hover{background:var(--gray-lt);}
.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-month{opacity:.3;}
.cal-dn{font-size:11px;margin-bottom:2px;display:inline-block;width:20px;height:20px;line-height:20px;}
.cal-events-strip{display:flex;flex-direction:column;gap:1px;margin-top:1px;}
.cal-ev-pill{font-size:9px;border-radius:2px;padding:0 3px;line-height:14px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;color:#fff;font-weight:500;}
.cal-ev-pill.pill-start{border-radius:4px 0 0 4px;}
.cal-ev-pill.pill-mid{border-radius:0;}
.cal-ev-pill.pill-end{border-radius:0 4px 4px 0;}
.cal-ev-pill.pill-solo{border-radius:4px;}
.cal-legend{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:.75rem;}
.cal-legend-item{display:flex;align-items:center;gap:4px;font-size:11px;color:var(--muted);}
.cal-legend-dot{width:10px;height:10px;border-radius:2px;}
.cal-upcoming{margin-top:.25rem;}
.cal-upcoming-item{display:flex;align-items:flex-start;gap:10px;padding:.65rem .75rem;background:var(--surface);border:0.5px solid var(--border);border-radius:var(--radius-sm);margin-bottom:.5rem;cursor:pointer;}
.cal-upcoming-dot{width:10px;height:10px;border-radius:2px;margin-top:3px;flex-shrink:0;}
.cal-upcoming-title{font-size:13px;font-weight:500;}
.cal-upcoming-meta{font-size:11px;color:var(--muted);}


/* ═══════════════════════════════════════════════
   Direction 3 — Home page identity & overrides
   Declared last so they win the cascade.
   ═══════════════════════════════════════════════ */

/* Page-identity colour */
:root{--primary:#025548;--primary-lt:#E0F5F0;--primary-md:#99C9B8;--primary-dk:#013630;--bg:#F2FAF7;}
[data-theme]{--primary:#025548;--primary-lt:#E0F5F0;--primary-md:#99C9B8;--primary-dk:#013630;}
[data-theme="harvey"]{--primary:#025548;--primary-lt:#E0F5F0;--primary-md:#99C9B8;--primary-dk:#013630;}
[data-theme="purple"]{--primary:#025548;--primary-lt:#E0F5F0;--primary-md:#99C9B8;--primary-dk:#013630;}
[data-theme="brown"]{--primary:#025548;--primary-lt:#E0F5F0;--primary-md:#99C9B8;--primary-dk:#013630;}
[data-theme="green"]{--primary:#025548;--primary-lt:#E0F5F0;--primary-md:#99C9B8;--primary-dk:#013630;}
[data-theme="blue"]{--primary:#025548;--primary-lt:#E0F5F0;--primary-md:#99C9B8;--primary-dk:#013630;}
[data-theme-override="dark"]{--primary:#025548;--primary-lt:#E0F5F0;--primary-md:#99C9B8;--primary-dk:#013630;--bg:#011C18;}
[data-theme-override="light"]{--primary:#025548;--primary-lt:#E0F5F0;--primary-md:#99C9B8;--primary-dk:#013630;}
@media(prefers-color-scheme:dark){:root:not([data-theme-override="light"]){--bg:#011C18;}}

/* ── Nav colours (home page) ── */
.bottom-nav{background:#011f1a !important;}
.nav-btn.active{background:#025548 !important;color:#fff !important;}

/* ── Home header D3 override ── */
.home-header{background:linear-gradient(150deg,#013630 0%,#025548 55%,#047A68 100%) !important;padding:max(58px,env(safe-area-inset-top)) 24px 20px !important;flex-direction:column !important;align-items:stretch !important;}
.home-header-top{display:flex;justify-content:space-between;align-items:flex-start;}
.header-trip-chip{display:inline-flex;align-items:center;gap:8px;background:rgba(255,255,255,0.14);border:1px solid rgba(255,255,255,0.22);border-radius:99px;padding:7px 14px;margin-top:12px;cursor:pointer;text-decoration:none;width:fit-content;}
.header-trip-chip-dot{width:7px;height:7px;border-radius:50%;background:#4CDFA6;flex-shrink:0;}
.header-trip-chip-name{font-size:13px;font-weight:600;color:#fff;}
.header-trip-chip-meta{font-size:12px;color:rgba(255,255,255,0.6);}
.home-greeting{font-size:28px !important;font-weight:800 !important;letter-spacing:-0.6px !important;}
.home-date{font-size:13px !important;color:rgba(255,255,255,0.6) !important;margin-top:4px !important;}
.home-settings-btn{background:rgba(255,255,255,0.15) !important;border-radius:12px !important;}

/* ── Savings hero card ── */
.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;}

/* ── Login D3 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;}
