:root{
  --night:#1a1530;
  --night-2:#241c3d;
  --night-3:#2e2350;
  --gold:#d4a857;
  --gold-bright:#e8d3a0;
  --gold-soft:#f0e6c8;
  --ivory:#f5efe0;
  --line: rgba(212,168,87,0.28);
  --line-strong: rgba(212,168,87,0.5);
  --ok:#8fbf9a;
  --err:#e08a72;
}
*{box-sizing:border-box;}
html,body{margin:0;}
body{
  font-family:'Inter',sans-serif;
  background:
    radial-gradient(ellipse at top, var(--night-3) 0%, var(--night-2) 45%, var(--night) 100%);
  color:var(--ivory);
  min-height:100vh;
  -webkit-font-smoothing:antialiased;
}
.display{font-family:'Cormorant Garamond', serif;}
.deva{font-family:'Tiro Devanagari Hindi', serif;}
a{color:var(--gold-bright);}

.app{max-width:980px;margin:0 auto;padding:28px 20px 80px;position:relative;}

/* ---- Header ---- */
header.top{
  display:flex;justify-content:space-between;align-items:center;
  padding:18px 0 30px;border-bottom:1px solid var(--line);margin-bottom:32px;
  position:relative;
}
header.top::after{
  content:'';position:absolute;bottom:-1px;left:50%;transform:translateX(-50%);
  width:120px;height:3px;background:linear-gradient(90deg,transparent,var(--gold),transparent);
}
.brand{display:flex;align-items:center;gap:14px;}
.brand .yantra{width:44px;height:44px;flex-shrink:0;color:var(--gold);}
.brand-text .title{font-family:'Cormorant Garamond',serif;font-size:1.6rem;font-weight:600;letter-spacing:0.04em;line-height:1.1;}
.brand-text .sub{font-size:0.7rem;letter-spacing:0.28em;text-transform:uppercase;color:var(--gold);opacity:0.9;}

/* ---- Hero ---- */
.hero{display:flex;flex-direction:column;align-items:center;text-align:center;padding:44px 0 56px;position:relative;}
.hero .ring-wrap{width:220px;height:220px;margin-bottom:30px;position:relative;}
.hero h1{font-size:3.2rem;margin:0 0 10px;font-weight:600;font-family:'Cormorant Garamond',serif;}
.hero h1 .accent{color:var(--gold-bright);font-style:italic;}
.hero p.tag{max-width:540px;color:var(--gold-soft);font-size:1.08rem;line-height:1.7;margin:0 auto 32px;}
.hero-actions{display:flex;gap:16px;flex-wrap:wrap;justify-content:center;}

/* ---- Decorative divider ---- */
.ornate-divider{display:flex;align-items:center;justify-content:center;gap:14px;margin:8px 0 36px;color:var(--gold);opacity:0.75;}
.ornate-divider .line{flex:1;max-width:140px;height:1px;background:linear-gradient(90deg,transparent,var(--line-strong));}
.ornate-divider .line.right{background:linear-gradient(90deg,var(--line-strong),transparent);}
.ornate-divider svg{width:22px;height:22px;flex-shrink:0;}

/* ---- Buttons ---- */
.btn{
  font-family:'Inter',sans-serif;font-size:0.85rem;letter-spacing:0.07em;font-weight:500;
  padding:14px 30px;border-radius:6px;border:1px solid var(--gold);
  background:transparent;color:var(--gold-bright);cursor:pointer;text-decoration:none;display:inline-block;
  position:relative;transition:transform .15s ease, box-shadow .2s ease, background .2s ease, border-color .2s ease, color .2s ease;
}
.btn.primary{
  background:linear-gradient(135deg, var(--gold-bright), var(--gold));color:var(--night);font-weight:700;
  border-color:var(--gold-bright);box-shadow:0 4px 14px rgba(212,168,87,0.25);
}
.btn.primary:hover{filter:brightness(1.08);box-shadow:0 6px 20px rgba(212,168,87,0.4);transform:translateY(-1px);}
.btn.primary:active{transform:translateY(0);box-shadow:0 2px 8px rgba(212,168,87,0.3);}
.btn:hover{border-color:var(--gold-bright);color:var(--ivory);background:rgba(212,168,87,0.1);transform:translateY(-1px);box-shadow:0 4px 12px rgba(0,0,0,0.2);}
.btn:active{transform:translateY(0);}
.btn.secondary{border-color:var(--line);color:var(--ivory);}
.btn.secondary:hover{border-color:var(--gold);color:var(--gold-bright);}
.btn.full{width:100%;text-align:center;}
.btn[disabled]{opacity:0.4;cursor:not-allowed;transform:none !important;box-shadow:none !important;}
.btn:focus-visible{outline:2px solid var(--gold-bright);outline-offset:2px;}

/* ---- Cards ---- */
.card{
  background:linear-gradient(160deg, rgba(232,192,116,0.04), rgba(255,255,255,0.015));
  border:1px solid var(--line);
  border-radius:6px;
  padding:30px;
  margin-bottom:24px;
  position:relative;
}
.card::before, .card::after{
  content:'';position:absolute;width:18px;height:18px;border:1px solid var(--line-strong);opacity:0.6;
}
.card::before{top:8px;left:8px;border-right:none;border-bottom:none;}
.card::after{bottom:8px;right:8px;border-left:none;border-top:none;}
.card h2{font-family:'Cormorant Garamond',serif;font-size:1.7rem;margin:0 0 8px;font-weight:600;color:var(--ivory);}
.card h2 .num{color:var(--gold-bright);font-style:italic;margin-right:10px;}
.card .lead{color:var(--gold-soft);font-size:0.92rem;margin:0 0 18px;line-height:1.6;}

.grid2{display:grid;grid-template-columns:1fr 1fr;gap:16px;}
@media (max-width:640px){.grid2{grid-template-columns:1fr;}}

/* ---- Form elements ---- */
label{display:block;font-size:0.76rem;letter-spacing:0.08em;text-transform:uppercase;color:var(--gold);margin-bottom:7px;}
input, select, textarea{
  width:100%;padding:13px 14px;border-radius:2px;border:1px solid var(--line);
  background:rgba(0,0,0,0.18);color:var(--ivory);font-family:'Inter',sans-serif;font-size:0.95rem;
  margin-bottom:16px;
}
select{
  appearance:none;-webkit-appearance:none;-moz-appearance:none;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16' fill='none' stroke='%23d4a857' stroke-width='1.5'%3E%3Cpath d='M4 6l4 4 4-4'/%3E%3C/svg%3E");
  background-repeat:no-repeat;background-position:right 14px center;background-size:14px;
  padding-right:38px;cursor:pointer;
}
select option{background:#241c3d;color:var(--ivory);}
input:focus, select:focus, textarea:focus{outline:none;border-color:var(--gold);}
input::placeholder{color:rgba(247,239,225,0.3);}
input:focus-visible, select:focus-visible{outline:2px solid var(--gold-bright);outline-offset:1px;}

.pill{
  display:inline-flex;align-items:center;gap:6px;padding:5px 14px;border-radius:2px;
  font-size:0.72rem;letter-spacing:0.07em;text-transform:uppercase;border:1px solid transparent;
}
.pill.granted{background:rgba(143,191,154,0.12);color:var(--ok);border-color:rgba(143,191,154,0.4);}

/* ---- Palm capture stage ---- */
.palm-stage{
  border:1px dashed var(--line-strong);border-radius:6px;background:rgba(0,0,0,0.25);
  display:flex;align-items:center;justify-content:center;flex-direction:column;
  min-height:320px;position:relative;overflow:hidden;margin-bottom:16px;
}
.palm-stage video, .palm-stage canvas, .palm-stage img.captured{
  width:100%;max-height:380px;object-fit:cover;border-radius:6px;
}
.palm-overlay{position:absolute;inset:0;pointer-events:none;display:flex;align-items:center;justify-content:center;}
.palm-overlay svg{width:60%;opacity:0.6;}
.scan-line{
  position:absolute;left:0;right:0;height:2px;background:linear-gradient(90deg,transparent,var(--gold-bright),transparent);
  animation:scanmove 2.4s linear infinite;
}
@keyframes scanmove{0%{top:8%;}50%{top:88%;}100%{top:8%;}}
.placeholder-text{color:var(--gold-soft);font-size:0.9rem;text-align:center;padding:20px;}

.palm-input-tabs{display:flex;gap:10px;margin-bottom:14px;}
.palm-input-tabs .tab-btn{
  flex:1;padding:11px 16px;border:1px solid var(--line);border-radius:2px;background:rgba(0,0,0,0.15);
  color:var(--gold-soft);cursor:pointer;font-size:0.82rem;letter-spacing:0.05em;text-align:center;transition:all .15s;
}
.palm-input-tabs .tab-btn.active{border-color:var(--gold);color:var(--gold-bright);background:rgba(212,168,87,0.08);}

/* ---- Misc ---- */
.small{font-size:0.8rem;color:var(--gold-soft);}
.center{text-align:center;}
.hidden{display:none !important;}
.row{display:flex;gap:12px;align-items:center;flex-wrap:wrap;}
.msg{padding:13px 16px;border-radius:2px;font-size:0.85rem;margin-bottom:16px;border:1px solid transparent;}
.msg.ok{background:rgba(143,191,154,0.1);color:var(--ok);border-color:rgba(143,191,154,0.35);}
.msg.err{background:rgba(224,138,114,0.1);color:var(--err);border-color:rgba(224,138,114,0.35);}

/* ---- Report pages ---- */
.report-page{
  background:linear-gradient(160deg, rgba(232,192,116,0.05), rgba(0,0,0,0.1));
  border:1px solid var(--line);border-radius:6px;padding:40px;margin-bottom:22px;
  position:relative; overflow:hidden;
}
.report-page::before{
  content:attr(data-page);position:absolute;top:20px;right:26px;
  font-family:'Cormorant Garamond',serif;font-style:italic;color:var(--gold);opacity:0.55;font-size:0.85rem;
  letter-spacing:0.05em;
}
.report-page .corner{position:absolute;width:34px;height:34px;border:1px solid var(--line-strong);opacity:0.5;}
.report-page .corner.tl{top:10px;left:10px;border-right:none;border-bottom:none;}
.report-page .corner.tr{top:10px;right:10px;border-left:none;border-bottom:none;}
.report-page .corner.bl{bottom:10px;left:10px;border-right:none;border-top:none;}
.report-page .corner.br{bottom:10px;right:10px;border-left:none;border-top:none;}
.report-page h2{font-family:'Cormorant Garamond',serif;color:var(--gold-bright);font-size:1.65rem;margin-top:0;padding-bottom:12px;border-bottom:1px solid var(--line);position:relative;}
.report-page h3{font-family:'Cormorant Garamond',serif;font-size:1.2rem;color:var(--gold-soft);margin:20px 0 7px;}
.report-page p{line-height:1.75;font-size:0.96rem;color:rgba(247,239,225,0.92);}

.report-cover{text-align:center;padding:80px 30px;}
.report-cover .yantra{width:150px;height:150px;margin:0 auto 26px;color:var(--gold);}
.report-cover h1{font-family:'Cormorant Garamond',serif;font-size:2.8rem;margin:0 0 8px;}
.report-cover .for{font-size:1.12rem;color:var(--gold-soft);margin-bottom:32px;font-style:italic;}
.report-cover .meta{display:inline-block;text-align:left;font-size:0.88rem;color:rgba(247,239,225,0.85);line-height:1.9;}

/* Month-ahead grid for the year-ahead page */
.month-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:12px;margin-top:18px;}
@media (max-width:560px){.month-grid{grid-template-columns:1fr;}}
.month-card{
  border:1px solid var(--line);border-radius:4px;padding:14px 16px;background:rgba(0,0,0,0.12);
}
.month-card .m-name{font-family:'Cormorant Garamond',serif;color:var(--gold-bright);font-size:1.05rem;margin-bottom:4px;}
.month-card .m-num{color:var(--gold);font-size:0.74rem;letter-spacing:0.06em;text-transform:uppercase;margin-bottom:6px;}
.month-card .m-theme{font-size:0.86rem;color:rgba(247,239,225,0.85);line-height:1.5;}

footer.foot{text-align:center;padding:44px 0 0;color:rgba(247,239,225,0.35);font-size:0.78rem;letter-spacing:0.04em;}

.yantra{color:var(--gold);}

@keyframes spin{from{transform:rotate(0deg);}to{transform:rotate(360deg);}}

@media (prefers-reduced-motion: reduce){
  .scan-line, .ring-wrap svg{animation:none !important;}
}

@media print{
  body{background:#1a1530 !important;}
  .no-print{display:none !important;}
}

/* ---- Account portal additions ---- */
.tabs{display:flex;gap:8px;margin-bottom:24px;flex-wrap:wrap;}
.tabs .tab-btn{
  padding:10px 20px;border:1px solid var(--line);border-radius:2px;background:rgba(0,0,0,0.15);
  color:var(--gold-soft);cursor:pointer;font-size:0.85rem;letter-spacing:0.05em;transition:all .15s;
}
.tabs .tab-btn.active{border-color:var(--gold);color:var(--gold-bright);background:rgba(212,168,87,0.08);}
.tabs .tab-btn .badge{
  display:inline-block;margin-left:6px;background:var(--gold-bright);color:var(--night);
  border-radius:10px;padding:1px 7px;font-size:0.7rem;font-weight:700;
}

.reading-list-item{
  display:flex;justify-content:space-between;align-items:center;gap:12px;
  padding:14px 0;border-bottom:1px solid var(--line);
}
.reading-list-item:last-child{border-bottom:none;}
.reading-list-item .info .r-name{font-family:'Cormorant Garamond',serif;font-size:1.15rem;color:var(--gold-bright);}
.reading-list-item .info .r-meta{font-size:0.8rem;color:var(--gold-soft);margin-top:2px;}

/* Chat */
.chat-thread{
  display:flex;flex-direction:column;gap:10px;max-height:420px;overflow-y:auto;
  padding:6px 4px;margin-bottom:16px;
}
.chat-bubble{
  max-width:78%;padding:11px 15px;border-radius:10px;font-size:0.9rem;line-height:1.5;
  border:1px solid var(--line);
}
.chat-bubble.from-user{align-self:flex-end;background:rgba(212,168,87,0.12);border-color:var(--line-strong);color:var(--ivory);}
.chat-bubble.from-admin{align-self:flex-start;background:rgba(0,0,0,0.18);color:var(--ivory);}
.chat-bubble .meta{display:block;font-size:0.7rem;color:var(--gold-soft);margin-top:5px;opacity:0.7;}
.chat-empty{color:var(--gold-soft);font-size:0.88rem;text-align:center;padding:30px 0;}

.chat-input-row{display:flex;gap:10px;}
.chat-input-row textarea{flex:1;resize:vertical;min-height:48px;margin-bottom:0;}

/* Feed */
.feed-post{
  border:1px solid var(--line);border-radius:6px;padding:22px;margin-bottom:18px;
  background:linear-gradient(160deg, rgba(232,192,116,0.04), rgba(0,0,0,0.08));
  position:relative;
}
.feed-post h3{font-family:'Cormorant Garamond',serif;color:var(--gold-bright);font-size:1.3rem;margin:0 0 6px;}
.feed-post .feed-date{font-size:0.74rem;color:var(--gold-soft);letter-spacing:0.05em;text-transform:uppercase;margin-bottom:10px;}
.feed-post p{line-height:1.7;font-size:0.94rem;color:rgba(247,239,225,0.9);margin:0;white-space:pre-wrap;}
.feed-empty{color:var(--gold-soft);font-size:0.9rem;text-align:center;padding:40px 0;}

/* ---- Mobile layout fixes ---- */
@media (max-width:640px){
  .app{padding:18px 14px 60px;}

  header.top{flex-wrap:wrap;gap:12px;padding:14px 0 22px;justify-content:center;text-align:center;}
  .brand{justify-content:center;}
  .brand .yantra{width:36px;height:36px;}
  .brand-text .title{font-size:1.25rem;}
  .brand-text .sub{font-size:0.62rem;letter-spacing:0.18em;}
  header.top > .row{width:100%;justify-content:center;}
  header.top .row, header.top a.btn, header.top button{font-size:0.72rem !important;padding:8px 14px !important;}

  .hero{padding:20px 0 28px;}
  .hero h1{font-size:1.9rem;}

  .card{padding:20px;}
  .card h2{font-size:1.35rem;}

  .btn{padding:13px 20px;font-size:0.82rem;}
  .btn.full{width:100%;}
  .row > .btn{flex:1;min-width:0;text-align:center;}

  .tabs{flex-wrap:wrap;}
  .tabs .tab-btn{flex:1;min-width:100px;font-size:0.78rem;padding:9px 10px;}

  .reading-list-item{flex-direction:column;align-items:flex-start;gap:8px;}
  .reading-list-item .btn{width:100%;}

  .chat-bubble{max-width:88%;}
  .chat-input-row{flex-direction:column;}
  .chat-input-row .btn{width:100%;}

  .report-page{padding:24px 18px;}
  .report-page::before{font-size:0.7rem;top:14px;right:16px;}
  .report-page .corner{width:22px;height:22px;}
  .report-cover{padding:50px 16px;}
  .report-cover h1{font-size:2rem;}
  .report-cover .yantra{width:100px;height:100px;}
}
