/* ============================================================
   Hare Krishna Mala Counter — UTSSites.com
   Main stylesheet (themes, navigation, pages, components)
   ============================================================ */

/* ---------- THEME VARIABLES ---------- */
:root, html[data-theme="dark"]{
  --bg:#0b1026; --bg2:#141a3a;
  --panel:rgba(255,255,255,0.04); --panel-border:rgba(255,255,255,0.10);
  --ink:#eaf0ff; --muted:#9aa6cf;
  --accent:#7c9cff; --accent2:#c08bff; --teal:#5be0c8; --rose:#ff8fb0;
  --shadow:0 24px 60px rgba(0,0,0,0.45); --radius:22px;
  --orb-op:.5;
  --grad1:rgba(124,156,255,.22); --grad2:rgba(192,139,255,.18); --grad3:rgba(91,224,200,.12);
  --field-bg:rgba(255,255,255,.06); --field-bg-focus:rgba(255,255,255,.09);
  --h1grad:#ffffff;
  --statnum:#ffffff; --tnumgrad:#ffffff; --head-ink:#f3f6ff;
  --card-grad:linear-gradient(160deg,rgba(124,156,255,.10),rgba(192,139,255,.06));
  --option-bg:#141a3a; --row-hover:rgba(124,156,255,.06); --th-bg:rgba(255,255,255,.03);
  --btn-ink:#0b1026; --mantra-ink:#cdd8ff; --field-ink:#c3cdf2;
  --nav-bg:rgba(13,18,42,0.92);
}
html[data-theme="light"]{
  --bg:#eef2ff; --bg2:#e3e9ff;
  --panel:rgba(255,255,255,0.72); --panel-border:rgba(40,55,120,0.12);
  --ink:#1a2150; --muted:#4a5586;
  --accent:#4f6dff; --accent2:#9a5bff; --teal:#1bb89c; --rose:#e0436f;
  --shadow:0 20px 48px rgba(40,55,120,0.16); --radius:22px;
  --orb-op:.35;
  --grad1:rgba(79,109,255,.18); --grad2:rgba(154,91,255,.14); --grad3:rgba(27,184,156,.12);
  --field-bg:rgba(255,255,255,.85); --field-bg-focus:#ffffff;
  --h1grad:#241a6b;
  --statnum:#1a2150; --tnumgrad:#241a6b; --head-ink:#1a2150;
  --card-grad:linear-gradient(160deg,rgba(79,109,255,.07),rgba(154,91,255,.04));
  --option-bg:#ffffff; --row-hover:rgba(79,109,255,.08); --th-bg:rgba(40,55,120,.05);
  --btn-ink:#ffffff; --mantra-ink:#2a2170; --field-ink:#33406e;
  --nav-bg:rgba(255,255,255,0.92);
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:'Inter',system-ui,sans-serif;color:var(--ink);
  background:
    radial-gradient(1100px 600px at 12% -8%, var(--grad1), transparent 60%),
    radial-gradient(900px 600px at 95% 5%, var(--grad2), transparent 55%),
    radial-gradient(800px 700px at 50% 120%, var(--grad3), transparent 60%),
    linear-gradient(160deg,var(--bg),var(--bg2));
  background-attachment:fixed;
  min-height:100vh;
  padding-bottom:96px; /* space for bottom nav */
  overflow-x:hidden;
  transition:color .35s ease, background .35s ease;
}
.orb{position:fixed;border-radius:50%;filter:blur(60px);opacity:var(--orb-op);z-index:0;animation:float 14s ease-in-out infinite;pointer-events:none}
.orb.a{width:300px;height:300px;background:#5b6cff;top:-60px;left:-80px}
.orb.b{width:260px;height:260px;background:#b06bff;bottom:60px;right:-60px;animation-delay:-5s}
@keyframes float{0%,100%{transform:translateY(0)}50%{transform:translateY(28px)}}

.wrap{position:relative;z-index:1;max-width:760px;margin:0 auto;padding:clamp(14px,4vw,28px)}

/* ---------- APP HEADER (user bar) ---------- */
.appbar{
  position:relative;z-index:1;max-width:760px;margin:0 auto;
  display:flex;align-items:center;justify-content:space-between;gap:12px;
  padding:18px clamp(14px,4vw,28px) 4px;
}
.user{display:flex;align-items:center;gap:12px;min-width:0}
.avatar{
  width:46px;height:46px;border-radius:50%;flex-shrink:0;
  display:flex;align-items:center;justify-content:center;
  font-family:'Fraunces',serif;font-weight:900;font-size:20px;color:#fff;
  background:linear-gradient(135deg,#5566ff,#9944ee);
  box-shadow:0 6px 18px rgba(124,156,255,.35);
  text-shadow:0 1px 3px rgba(0,0,0,.4);
}
.user .uinfo{min-width:0}
.user .hello{font-size:12px;color:var(--muted)}
.user .uname{font-family:'Fraunces',serif;font-weight:600;font-size:18px;color:var(--ink);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.theme-toggle{
  display:flex;align-items:center;gap:7px;flex-shrink:0;
  background:var(--panel);border:1px solid var(--panel-border);color:var(--ink);
  border-radius:50px;padding:8px 14px;cursor:pointer;
  font-family:'Inter',sans-serif;font-weight:600;font-size:13px;
  backdrop-filter:blur(14px);transition:.25s;
}
.theme-toggle:hover{border-color:var(--accent)}
.theme-toggle .ic{font-size:15px;line-height:1}

/* ---------- PAGE TITLES ---------- */
.page{display:none;animation:fadein .4s ease}
.page.active{display:block}
@keyframes fadein{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}
.page-title{font-family:'Fraunces',serif;font-weight:900;font-size:clamp(26px,6vw,38px);color:var(--head-ink);margin-bottom:4px}
.page-sub{font-family:'Tiro Devanagari Hindi',serif;color:var(--muted);font-size:14px;margin-bottom:22px;line-height:1.6}

/* ---------- CARDS ---------- */
.card{background:var(--panel);border:1px solid var(--panel-border);border-radius:var(--radius);padding:clamp(18px,4vw,28px);box-shadow:var(--shadow);backdrop-filter:blur(14px);animation:rise .7s ease both}
.card+.card{margin-top:20px}
@keyframes rise{from{opacity:0;transform:translateY(18px)}to{opacity:1;transform:none}}
.card h2{font-family:'Fraunces',serif;font-weight:600;font-size:21px;margin-bottom:6px}
.card .hint{font-family:'Tiro Devanagari Hindi',serif;color:var(--muted);font-size:14px;margin-bottom:20px}

/* ---------- MANTRA CARD (animated) ---------- */
.mantra-card{text-align:center;margin-bottom:20px}
/* ===== Daily Shlok card ===== */
.shlok-card{background:radial-gradient(130% 100% at 50% 0%, rgba(224,179,74,.12), transparent 65%), var(--panel);border:1px solid var(--panel-border);border-radius:20px;padding:22px;margin-bottom:20px;position:relative;box-shadow:0 12px 40px rgba(224,179,74,.08)}
.shlok-card .sh-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px;gap:10px}
.shlok-card .sh-title{font-family:'Fraunces',serif;font-weight:700;font-size:16px;color:var(--gold,#e0b34a);display:flex;align-items:center;gap:8px}
.shlok-card .sh-ref{font-size:11.5px;color:var(--muted);background:rgba(224,179,74,.12);border:1px solid rgba(224,179,74,.25);padding:3px 10px;border-radius:20px;white-space:nowrap}
.shlok-card .sh-sanskrit{font-family:'Tiro Devanagari Hindi',serif;font-size:20px;line-height:1.95;text-align:center;color:#f3e7c8;margin-bottom:14px}
.shlok-card .langtog{display:flex;gap:6px;margin-bottom:14px;background:rgba(0,0,0,.2);padding:4px;border-radius:12px;width:fit-content}
.shlok-card .langtog button{background:none;border:none;color:var(--muted);font-family:'Inter',sans-serif;font-size:12.5px;font-weight:600;padding:6px 16px;border-radius:9px;cursor:pointer;transition:all .2s}
.shlok-card .langtog button.active{background:rgba(224,179,74,.18);color:var(--gold,#e0b34a)}
.shlok-card .sh-more{max-height:0;overflow:hidden;transition:max-height .4s ease}
.shlok-card .sh-more.open{max-height:400px}
.shlok-card .sh-divider{height:1px;background:linear-gradient(90deg,transparent,rgba(224,179,74,.3),transparent);margin:4px 0 14px}
.shlok-card .sh-label{font-size:11px;letter-spacing:.12em;color:var(--gold,#e0b34a);text-transform:uppercase;margin-bottom:6px;font-weight:600}
.shlok-card .sh-meaning{font-size:18px;line-height:1.7;color:var(--ink)}
.shlok-card .sh-toggle{width:100%;background:rgba(224,179,74,.10);border:1px solid rgba(224,179,74,.25);color:var(--gold,#e0b34a);font-family:'Inter',sans-serif;font-size:13px;font-weight:600;padding:10px;border-radius:12px;cursor:pointer;margin-top:12px;display:flex;align-items:center;justify-content:center;gap:6px;transition:background .2s}
.shlok-card .sh-toggle:hover{background:rgba(224,179,74,.18)}
.shlok-card .sh-toggle .arr{transition:transform .3s}
.shlok-card .sh-toggle.open .arr{transform:rotate(180deg)}
.mantra{
  position:relative;font-family:'Tiro Devanagari Hindi',serif;font-style:italic;
  color:var(--mantra-ink);font-size:clamp(24px,4.8vw,36px);
  background:radial-gradient(120% 100% at 50% 0%, rgba(124,156,255,.16), transparent 70%), var(--panel);
  border:1px solid transparent;border-radius:20px;padding:30px 26px 26px;display:inline-block;width:100%;
  line-height:2.1;letter-spacing:.3px;background-clip:padding-box;
  box-shadow:0 0 0 1px var(--panel-border), 0 12px 40px rgba(124,156,255,.12);
  animation:mantraGlow 4.5s ease-in-out infinite;overflow:hidden;isolation:isolate;
}
.mantra::before{content:'';position:absolute;z-index:-1;top:50%;left:50%;width:160%;aspect-ratio:1;transform:translate(-50%,-50%);
  background:conic-gradient(from 0deg,transparent 0deg,rgba(124,156,255,.16) 60deg,transparent 130deg,rgba(192,139,255,.16) 210deg,transparent 290deg,rgba(91,224,200,.12) 340deg,transparent 360deg);
  animation:auraSpin 16s linear infinite;pointer-events:none}
@keyframes auraSpin{to{transform:translate(-50%,-50%) rotate(360deg)}}
.mantra .orn{display:block;font-family:'Inter',sans-serif;font-size:16px;letter-spacing:.55em;color:var(--accent);margin-bottom:18px;text-indent:.55em}
.mantra .orn .star{display:inline-block;animation:starPulse 3s ease-in-out infinite}
@keyframes starPulse{0%,100%{transform:scale(1) rotate(0);opacity:.85}50%{transform:scale(1.35) rotate(180deg);opacity:1;text-shadow:0 0 14px var(--accent)}}
.mantra .mline{display:block;background:linear-gradient(100deg,var(--mantra-ink) 0%,var(--mantra-ink) 42%,#ffd27a 50%,var(--accent) 54%,var(--mantra-ink) 62%,var(--mantra-ink) 100%);background-size:300% 100%;-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;animation:mlineIn .9s ease both, shimmer 4s linear infinite}
@keyframes shimmer{from{background-position:130% 0}to{background-position:-30% 0}}
.mantra .m1{animation-delay:.15s,0s}
.mantra .m2{animation-delay:.45s,1.2s}
@keyframes mlineIn{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:none}}
.mantra .foot{display:block;font-style:normal;font-size:13.5px;letter-spacing:.18em;color:var(--muted);margin-top:18px}
@keyframes mantraGlow{0%,100%{box-shadow:0 0 0 1px var(--panel-border),0 12px 40px rgba(124,156,255,.12)}50%{box-shadow:0 0 0 1px rgba(124,156,255,.5),0 16px 54px rgba(124,156,255,.28)}}

/* ---------- FORM FIELDS ---------- */
.grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:14px}
label{display:block;font-size:13px;color:var(--muted);margin-bottom:7px;font-weight:600}
.field{font-family:'Tiro Devanagari Hindi',serif;font-size:13.5px;color:var(--field-ink)}
input,select{width:100%;padding:13px 15px;border-radius:13px;background:var(--field-bg);border:1px solid var(--panel-border);color:var(--ink);font-size:15px;font-family:'Inter',sans-serif;transition:.2s}
input:focus,select:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px rgba(124,156,255,.22);background:var(--field-bg-focus)}
select option{background:var(--option-bg);color:var(--ink)}
.btn{margin-top:22px;width:100%;padding:15px;border:none;border-radius:14px;cursor:pointer;font-family:'Inter',sans-serif;font-weight:700;font-size:16px;color:var(--btn-ink);background:linear-gradient(120deg,var(--teal),var(--accent));transition:.25s}
.btn:hover{transform:translateY(-2px);box-shadow:0 14px 30px rgba(91,224,200,.3)}
.btn:active{transform:translateY(0)}

/* ---------- PREVIEW + STAT CARDS ---------- */
.preview{margin-top:22px;display:grid;grid-template-columns:repeat(auto-fit,minmax(130px,1fr));gap:14px}
.stat{background:linear-gradient(150deg,rgba(124,156,255,.14),rgba(192,139,255,.10));border:1px solid var(--panel-border);border-radius:16px;padding:18px 16px;text-align:center}
.stat .num{font-family:'Fraunces',serif;font-weight:900;font-size:clamp(22px,4vw,30px);color:var(--statnum)}
.stat .lbl{font-family:'Tiro Devanagari Hindi',serif;font-size:13px;color:var(--muted);margin-top:4px}
.topstats{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin-bottom:20px}
.topstat{background:linear-gradient(150deg,rgba(124,156,255,.14),rgba(192,139,255,.10));border:1px solid var(--panel-border);border-radius:18px;padding:20px 18px;text-align:center;animation:rise .7s ease both}
.topstat .big{font-family:'Fraunces',serif;font-weight:900;font-size:clamp(26px,6vw,40px);color:var(--statnum);line-height:1}
.topstat .cap{font-size:13px;color:var(--muted);margin-top:7px}
.topstat .fire{font-size:22px}
.totals{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}
.tcard{background:linear-gradient(150deg,rgba(91,224,200,.14),rgba(124,156,255,.10));border:1px solid var(--panel-border);border-radius:18px;padding:22px 18px;text-align:center}
.tcard .tnum{font-family:'Fraunces',serif;font-weight:900;font-size:clamp(24px,5vw,38px);color:var(--head-ink)}
.tcard .tlbl{font-family:'Tiro Devanagari Hindi',serif;font-size:13px;color:var(--muted);margin-top:6px}

/* ---------- GOAL PROGRESS ---------- */
.goal-head{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:10px;margin-bottom:14px}
.goal-edit{display:flex;align-items:center;gap:8px}
.goal-edit input{width:90px;padding:9px 11px;font-size:14px}
.progress-track{height:16px;border-radius:50px;background:var(--field-bg);border:1px solid var(--panel-border);overflow:hidden}
.progress-fill{height:100%;border-radius:50px;background:linear-gradient(90deg,var(--teal),var(--accent));width:0;transition:width .5s ease}
.goal-meta{display:flex;justify-content:space-between;margin-top:10px;font-size:13.5px;color:var(--muted)}
.goal-meta b{color:var(--ink)}

/* ---------- LIVE JAP COUNTER ---------- */
.japwrap{text-align:center}
.jap-count{font-family:'Fraunces',serif;font-weight:900;font-size:clamp(54px,16vw,90px);line-height:1;color:var(--statnum)}
.jap-sub{color:var(--muted);font-size:14px;margin-top:4px}
.jap-malas{color:var(--accent);font-weight:700;margin-top:8px;font-size:15px}
.tap-btn{margin:22px auto 0;width:min(220px,70vw);aspect-ratio:1;border-radius:50%;border:none;cursor:pointer;
  background:radial-gradient(circle at 50% 35%,var(--accent),var(--accent2));color:#fff;
  font-family:'Inter',sans-serif;font-weight:700;font-size:20px;letter-spacing:.05em;
  box-shadow:0 18px 50px rgba(124,156,255,.4), inset 0 -6px 18px rgba(0,0,0,.18);transition:transform .08s ease}
.tap-btn:active{transform:scale(.94)}
.jap-actions{display:flex;gap:10px;margin-top:20px}
.jap-actions .minibtn{flex:1}

/* ---------- BADGES / SUMMARY / CHART ---------- */
.summary{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:14px}
.scard{position:relative;background:var(--card-grad);border:1px solid var(--panel-border);border-radius:18px;padding:20px 18px;overflow:hidden;transition:transform .2s ease,border-color .2s ease,box-shadow .2s ease}
.scard:hover{transform:translateY(-4px);border-color:var(--accent);box-shadow:0 16px 34px rgba(124,156,255,.18)}
.scard .sc-ic{width:42px;height:42px;border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:20px;margin-bottom:12px;background:linear-gradient(135deg,rgba(124,156,255,.22),rgba(192,139,255,.16))}
.scard .sh{font-size:12.5px;color:var(--muted);margin-bottom:6px;font-weight:600}
.scard .sv{font-family:'Fraunces',serif;font-weight:900;font-size:26px;color:var(--head-ink)}
.scard .sv span{font-size:13px;color:var(--muted);font-weight:400;font-family:'Inter',sans-serif}
.sc-a .sc-ic{background:linear-gradient(135deg,rgba(124,156,255,.25),rgba(124,156,255,.12))}
.sc-b .sc-ic{background:linear-gradient(135deg,rgba(91,224,200,.25),rgba(91,224,200,.12))}
.sc-c .sc-ic{background:linear-gradient(135deg,rgba(192,139,255,.25),rgba(192,139,255,.12))}
.sc-d .sc-ic{background:linear-gradient(135deg,rgba(240,192,96,.25),rgba(240,192,96,.12))}
.badges{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:14px}
.badge{display:flex;align-items:center;gap:12px;background:var(--field-bg);border:1px solid var(--panel-border);border-radius:14px;padding:16px 18px;font-size:14px;min-width:0}
.badge.unlocked{border-color:var(--teal);box-shadow:0 0 0 1px var(--teal),0 8px 22px rgba(91,224,200,.18)}
.badge.locked{opacity:.62}
.badge .bic{font-size:24px;flex-shrink:0}
.badge .bt{font-weight:700;color:var(--ink)}
.badge .bs{font-size:12px;color:var(--muted)}
.chartwrap{overflow-x:hidden}
.barchart{display:flex;align-items:flex-end;gap:6px;height:170px;width:100%;padding:10px 0 0}
.barcol{flex:1;min-width:0;display:flex;flex-direction:column;align-items:center;gap:6px;height:100%;justify-content:flex-end}
.bar{width:100%;max-width:34px;border-radius:8px 8px 0 0;background:linear-gradient(180deg,var(--accent),var(--accent2));min-height:3px;transition:height .5s ease;position:relative}
.bar:hover::after{content:attr(data-v);position:absolute;top:-22px;left:50%;transform:translateX(-50%);background:var(--bg);border:1px solid var(--panel-border);color:var(--ink);font-size:11px;padding:2px 7px;border-radius:6px;white-space:nowrap}
.barlbl{font-size:10px;color:var(--muted);white-space:nowrap}

/* ---------- TABLES ---------- */
.tablewrap{overflow-x:auto;border-radius:14px;border:1px solid var(--panel-border)}
table{width:100%;border-collapse:collapse;min-width:520px}
/* city-wise table: fit all 4 columns on mobile (no horizontal scroll) */
.city-table{min-width:0}
.city-table th,.city-table td{padding:12px 8px;font-size:13px}
.city-table th:first-child,.city-table td:first-child{padding-left:14px}
.city-table th:not(:first-child),.city-table td:not(:first-child){text-align:right;white-space:nowrap}
.city-table th:last-child,.city-table td:last-child{padding-right:14px}
.total-row td{border-top:2px solid var(--accent);background:linear-gradient(150deg,rgba(124,156,255,.14),rgba(192,139,255,.10));color:var(--ink);font-size:14px}
.total-row td b{color:var(--accent)}
th,td{padding:13px 14px;text-align:left;font-size:14px;border-bottom:1px solid var(--panel-border)}
th{font-family:'Tiro Devanagari Hindi',serif;color:var(--muted);font-weight:600;background:var(--th-bg)}
td{color:var(--ink)}
tr:last-child td{border-bottom:none}
tr:hover td{background:var(--row-hover)}
.empty{font-family:'Tiro Devanagari Hindi',serif;text-align:center;color:var(--muted);padding:30px;font-size:15px}
.del{background:rgba(255,143,176,.14);border:1px solid rgba(255,143,176,.3);color:var(--rose);border-radius:9px;padding:6px 12px;cursor:pointer;font-size:13px;font-weight:600}
.edit{background:rgba(124,156,255,.14);border:1px solid rgba(124,156,255,.3);color:var(--accent);border-radius:9px;padding:6px 12px;cursor:pointer;font-size:13px;font-weight:600;margin-right:6px}

/* ---------- FILTER + BUTTONS ---------- */
.filterbar{display:flex;flex-wrap:wrap;gap:12px;margin-bottom:18px}
.filterbar input,.filterbar select{flex:1;min-width:130px}
.minibtn{background:var(--field-bg);border:1px solid var(--panel-border);color:var(--ink);border-radius:11px;padding:10px 15px;cursor:pointer;font-size:13.5px;font-weight:600;transition:.2s;font-family:'Inter',sans-serif}
.minibtn:hover{border-color:var(--accent);transform:translateY(-1px)}
.btnrow{display:flex;flex-wrap:wrap;gap:10px}
.clearall{background:transparent;border:1px solid var(--panel-border);color:var(--muted);border-radius:11px;padding:10px 15px;cursor:pointer;font-size:13.5px;font-weight:600}
.clearall:hover{border-color:var(--rose);color:var(--rose)}

/* ---------- COMBO (city dropdown) ---------- */
.combo{position:relative}
.combo-panel{position:absolute;top:calc(100% + 8px);left:0;right:0;z-index:20;background:var(--bg2);border:1px solid var(--panel-border);border-radius:14px;box-shadow:var(--shadow);max-height:286px;overflow-y:auto;padding:6px;display:none;backdrop-filter:blur(14px);animation:ddrop .18s ease}
.combo-panel.open{display:block}
.combo-panel{scrollbar-width:thin;scrollbar-color:rgba(124,156,255,.4) transparent}
.combo-panel::-webkit-scrollbar{width:5px}
.combo-panel::-webkit-scrollbar-track{background:transparent}
.combo-panel::-webkit-scrollbar-thumb{background:rgba(124,156,255,.35);border-radius:10px}
.combo-panel::-webkit-scrollbar-thumb:hover{background:rgba(124,156,255,.6)}
@keyframes ddrop{from{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:none}}
.combo-group{font-size:11px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--muted);padding:9px 12px 5px}
.combo-item{display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:10px;cursor:pointer;font-size:15px;color:var(--ink)}
.combo-item .ci-ic{font-size:15px;opacity:.9;width:18px;text-align:center}
.combo-item .ci-name b{color:var(--accent);font-weight:700}
.combo-item:hover,.combo-item.active{background:var(--row-hover)}
.combo-empty{padding:14px 12px;color:var(--muted);font-size:14px}
.combo-empty .addnew{color:var(--accent);font-weight:600}

/* ---------- PROFILE ---------- */
.profile-top{text-align:center;padding:10px 0 6px}
.profile-avatar{width:88px;height:88px;border-radius:50%;margin:0 auto 14px;display:flex;align-items:center;justify-content:center;font-family:'Fraunces',serif;font-weight:900;font-size:38px;color:#fff;background:linear-gradient(135deg,var(--accent),var(--accent2));box-shadow:0 10px 30px rgba(124,156,255,.4)}
.profile-name{font-family:'Fraunces',serif;font-weight:600;font-size:24px}
.profile-row{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:15px 0;border-bottom:1px solid var(--panel-border)}
.profile-row:last-child{border-bottom:none}
.profile-row .pl{font-size:15px}
.profile-row .pl small{display:block;color:var(--muted);font-size:12.5px;margin-top:2px}

/* ---------- MODALS ---------- */
.modal-bg{position:fixed;inset:0;background:rgba(0,0,0,.55);backdrop-filter:blur(4px);z-index:50;display:none;align-items:center;justify-content:center;padding:20px}
.modal-bg.open{display:flex}
.modal{background:var(--bg2);border:1px solid var(--panel-border);border-radius:20px;padding:26px;max-width:420px;width:100%;box-shadow:var(--shadow);animation:ddrop .2s ease}
.modal h3{font-family:'Fraunces',serif;font-size:22px;margin-bottom:16px}
.modal label{margin-top:14px}
.modal .mrow{display:flex;gap:10px;margin-top:22px}
.modal .mrow .btn{margin-top:0;flex:1}
.modal .cancel{background:var(--field-bg);color:var(--ink)}
.confirm-modal{text-align:center;max-width:360px}
.confirm-ic{font-size:42px;margin-bottom:8px;line-height:1}
.confirm-modal h3{margin-bottom:10px}
.confirm-msg{font-family:'Tiro Devanagari Hindi',serif;color:var(--muted);font-size:14.5px;line-height:1.6}
.confirm-modal .mrow{justify-content:center}
.confirm-yes{background:linear-gradient(120deg,var(--rose),var(--accent2))}

/* ---------- TOAST ---------- */
.toast{position:fixed;top:80px;bottom:auto;left:50%;transform:translateX(-50%) translateY(-160px);opacity:0;visibility:hidden;pointer-events:none;background:linear-gradient(120deg,var(--teal),var(--accent));color:var(--btn-ink);padding:14px 26px;border-radius:14px;font-weight:700;box-shadow:var(--shadow);transition:transform .4s ease,opacity .4s ease,visibility .4s;z-index:9999;font-size:15px;max-width:80%;text-align:center}
.toast.show{transform:translateX(-50%) translateY(0)!important;opacity:1!important;visibility:visible!important}

/* ---------- BOTTOM NAVIGATION ---------- */
.bottomnav{
  position:fixed;left:0;right:0;bottom:0;z-index:40;
  display:flex;justify-content:space-around;align-items:center;
  background:var(--nav-bg);backdrop-filter:blur(18px);
  border-top:1px solid var(--panel-border);
  padding:8px max(8px,env(safe-area-inset-left)) calc(8px + env(safe-area-inset-bottom));
}
.navbtn{
  flex:1;background:none;border:none;cursor:pointer;
  display:flex;flex-direction:column;align-items:center;gap:3px;
  padding:8px 4px;color:var(--muted);transition:color .2s;
  font-family:'Inter',sans-serif;font-size:11px;font-weight:600;
}
.navbtn .nic{font-size:21px;line-height:1;transition:transform .2s}
.navbtn.active{color:var(--accent)}
.navbtn.active .nic{transform:translateY(-2px) scale(1.12)}
.navbtn:active .nic{transform:scale(.9)}

@media print{
  .bottomnav,.appbar,.theme-toggle,.btn,.minibtn,.edit,.del,.clearall,.filterbar,.orb{display:none!important}
  body{background:#fff;color:#000;padding:0}
  .page{display:block!important}
}
@media (prefers-reduced-motion: reduce){
  .mantra,.mantra::before,.mantra .orn .star,.mantra .mline,.orb{animation:none}
  .mantra .mline{-webkit-text-fill-color:var(--mantra-ink)}
}

/* ---------- Calendar (fully responsive) ---------- */
.cal-head{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-bottom:6px}
.cal-head h2{font-size:clamp(17px,4.5vw,21px);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.cal-nav{min-width:clamp(38px,10vw,46px);padding:8px 0;font-size:clamp(16px,4.5vw,20px);line-height:1;text-align:center}
.calendar{display:grid;grid-template-columns:repeat(7,1fr);gap:clamp(3px,1.2vw,7px);margin-top:14px;width:100%}
.cal-dow{text-align:center;font-size:clamp(9px,2.6vw,12px);color:var(--muted);font-weight:700;padding:4px 0;overflow:hidden}
.cal-day{aspect-ratio:1;display:flex;flex-direction:column;align-items:center;justify-content:center;border-radius:clamp(7px,2vw,11px);background:var(--field-bg);border:1px solid var(--panel-border);font-size:clamp(11px,3.2vw,15px);color:var(--ink);cursor:default;min-width:0;padding:2px;line-height:1.1}
.cal-day.empty{background:none;border:none}
.cal-day.done{background:linear-gradient(150deg,rgba(91,224,200,.30),rgba(124,156,255,.22));border-color:var(--teal);cursor:pointer;font-weight:700}
.cal-day.today{outline:2px solid var(--accent);outline-offset:1px}
.cal-day .cd-mala{font-size:clamp(8px,2.2vw,10px);color:var(--teal);margin-top:1px;line-height:1;white-space:nowrap}
.cal-day.festival{border-color:#e0b34a;box-shadow:inset 0 0 0 1px rgba(224,179,74,.45);cursor:pointer}
.cal-day.ekadashi{border-color:rgba(124,156,255,.55);cursor:pointer}
.cal-day .cd-fest{font-size:clamp(10px,3vw,14px);margin-top:1px;line-height:1}
/* On very wide screens (tablet/desktop) cap the calendar width so cells don't get huge */
@media (min-width:560px){
  .calendar{max-width:480px;margin-left:auto;margin-right:auto}
}

/* ============ NEW JAP COUNTER ============ */
.japcard{text-align:center;padding-top:0;overflow:hidden}
.jap-timer{font-family:'Inter',sans-serif;font-weight:700;font-size:clamp(22px,6vw,30px);letter-spacing:.08em;color:#fff;background:linear-gradient(120deg,var(--accent),var(--accent2));margin:-1px -28px 22px;padding:18px;border-radius:0}
.jap-mantra-select{display:flex;gap:10px;margin-bottom:24px}
.jap-mantra-select select{flex:1;font-size:14px;text-overflow:ellipsis}
.jap-sound-btn{flex-shrink:0;width:52px;border:1px solid var(--panel-border);background:var(--field-bg);border-radius:13px;font-size:20px;cursor:pointer;color:var(--ink)}
.jap-sound-btn.off{opacity:.45}
.jap-ring-wrap{display:flex;align-items:center;justify-content:space-between;gap:8px;margin-bottom:20px}
.jap-side{flex-shrink:0;width:clamp(64px,20vw,86px);background:var(--field-bg);border:1px solid var(--panel-border);border-radius:16px;padding:14px 8px}
.jap-side-lbl{font-size:11px;letter-spacing:.08em;text-transform:uppercase;color:var(--accent);font-weight:700;margin-bottom:6px}
.jap-side-val{font-family:'Fraunces',serif;font-weight:900;font-size:clamp(20px,6vw,28px);color:var(--statnum)}
.jap-ring{position:relative;flex:1;max-width:200px;aspect-ratio:1;margin:0 auto}
.jap-ring svg{width:100%;height:100%;transform:rotate(-90deg)}
.jap-ring .ring-bg{fill:none;stroke:var(--field-bg);stroke-width:8}
.jap-ring .ring-fg{fill:none;stroke:url(#ringGrad);stroke-width:8;stroke-linecap:round;stroke-dasharray:326.7;stroke-dashoffset:326.7;transition:stroke-dashoffset .4s ease;stroke:var(--accent)}
.jap-ring-num{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;font-family:'Fraunces',serif;font-weight:900;font-size:clamp(38px,12vw,60px);color:var(--accent)}
.jap-mantra-text{font-family:'Tiro Devanagari Hindi',serif;font-style:italic;color:var(--mantra-ink);font-size:clamp(15px,4vw,19px);padding-bottom:14px;border-bottom:1px dashed var(--panel-border);margin-bottom:22px}
/* solid single-color tap button, clean design */
.tap-btn-round{position:relative;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px;
  width:100%;padding:38px 20px;margin-top:4px;border:none;cursor:pointer;border-radius:22px;
  background:linear-gradient(135deg,var(--accent),var(--accent2));
  color:#fff;isolation:isolate;
  box-shadow:0 8px 0 rgba(120,100,210,.5), 0 18px 34px rgba(124,156,255,.4);
  transition:transform .1s ease, box-shadow .1s ease;}
.tap-btn-round:active{transform:translateY(6px);box-shadow:0 2px 0 var(--accent2), 0 8px 18px rgba(124,156,255,.35)}
.tap-btn-round .tap-ic{font-size:clamp(44px,12vw,56px);line-height:1;transition:transform .12s ease;z-index:1}
.tap-btn-round.bump .tap-ic{transform:scale(1.18)}
.tap-btn-round .tap-txt{font-family:'Inter',sans-serif;font-weight:800;font-size:clamp(20px,5vw,26px);letter-spacing:.08em;line-height:1.2;z-index:1;white-space:nowrap}
/* floating naam that rises on each tap */
.float-naam{position:absolute;left:50%;top:22%;transform:translate(-50%,0);pointer-events:none;font-family:'Tiro Devanagari Hindi',serif;font-weight:700;font-size:clamp(22px,6vw,32px);color:#fff;text-shadow:0 2px 14px rgba(0,0,0,.4);z-index:5;animation:naamRise 1.1s ease-out forwards;white-space:nowrap}
@keyframes naamRise{0%{opacity:0;transform:translate(-50%,10px) scale(.7)}20%{opacity:1}100%{opacity:0;transform:translate(-50%,-110px) scale(1.3)}}
.jap-actions{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-top:18px}
.jap-reset{color:var(--rose);border-color:rgba(255,143,176,.3)}
.jap-saved{font-size:12px;color:var(--muted);letter-spacing:.05em;text-transform:uppercase}

/* ---------- Profile avatar image + picker ---------- */
.profile-avatar-wrap{position:relative;width:88px;height:88px;margin:0 auto 14px;cursor:pointer}
.profile-avatar-wrap .profile-avatar{margin:0;width:88px;height:88px;background-size:cover;background-position:center}
.avatar-edit-badge{position:absolute;bottom:0;right:0;width:30px;height:30px;border-radius:50%;background:var(--accent);color:#fff;display:flex;align-items:center;justify-content:center;font-size:15px;border:3px solid var(--bg2);box-shadow:0 4px 10px rgba(0,0,0,.25)}
/* top bar avatar shows image too */
.avatar{background-size:cover;background-position:center}
.avatar-presets{display:grid;grid-template-columns:repeat(4,1fr);gap:12px}
.avatar-preset{aspect-ratio:1;border-radius:50%;cursor:pointer;border:2px solid var(--panel-border);display:flex;align-items:center;justify-content:center;font-size:30px;background:linear-gradient(135deg,rgba(124,156,255,.2),rgba(192,139,255,.2));transition:.2s}
.avatar-preset:hover{border-color:var(--accent);transform:scale(1.06)}

/* ---------- Login Activity ---------- */
.login-activity{display:flex;flex-direction:column;gap:10px}
.login-item{display:flex;align-items:flex-start;gap:12px;padding:12px 14px;border-radius:14px;background:var(--field-bg);border:1px solid var(--panel-border)}
.login-item .li-ic{font-size:20px;flex-shrink:0;line-height:1.3}
.login-item .li-main{flex:1;min-width:0}
.login-item .li-time{font-weight:700;font-size:14px;color:var(--ink)}
.login-item .li-meta{font-size:12.5px;color:var(--muted);margin-top:3px;word-break:break-word}
.login-item .li-method{display:inline-block;font-size:11px;font-weight:700;padding:2px 8px;border-radius:20px;background:rgba(124,156,255,.18);color:var(--accent);margin-top:5px}
.login-item.latest{border-color:var(--accent)}
.login-item.latest .li-time::after{content:' · now';color:var(--accent);font-weight:600}

/* toggle "on" state for minibtns (reminder) */
.minibtn.on{background:var(--accent);color:#fff;border-color:var(--accent)}

/* ---------- Announcement banner ---------- */
.announce-banner{display:flex;align-items:flex-start;gap:12px;background:linear-gradient(135deg,rgba(124,156,255,.18),rgba(192,139,255,.14));border:1px solid var(--accent);border-radius:16px;padding:14px 16px;margin-bottom:18px;animation:annSlide .5s ease}
@keyframes annSlide{from{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:none}}
.announce-banner .ab-ic{font-size:20px;flex-shrink:0;line-height:1.4}
.announce-banner .ab-text{flex:1;font-size:14.5px;color:var(--ink);line-height:1.5;white-space:pre-wrap;word-break:break-word}
.announce-banner .ab-close{flex-shrink:0;background:none;border:none;color:var(--muted);font-size:22px;cursor:pointer;line-height:1;padding:0 4px}
.announce-banner .ab-close:hover{color:var(--ink)}
.announce-banner.ann-warning{background:linear-gradient(135deg,rgba(255,170,60,.20),rgba(255,120,80,.12));border-color:#f0a040}
.announce-banner.ann-festival{background:linear-gradient(135deg,rgba(224,179,74,.22),rgba(255,140,180,.12));border-color:#e0b34a}