: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;
  perspective:800px;
}
.mandala-3d{
  width:100%;height:100%;position:relative;transform-style:preserve-3d;
  transition:transform 0.15s ease-out;
  cursor:grab;touch-action:none;
}
.mandala-3d:active{cursor:grabbing;}
.mandala-layer{
  position:absolute;inset:0;width:100%;height:100%;
  transform-style:preserve-3d;
  animation:spin 90s linear infinite;
}
.mandala-layer.layer-back{opacity:0.55;animation-name:spin-back;}
.mandala-layer.layer-mid{animation-name:spin-mid;}
.mandala-layer.layer-front{animation-direction:reverse;animation-duration:70s;animation-name:spin-front;}
.mandala-layer.layer-front svg{opacity:0.8;}
.mandala-glow{
  position:absolute;inset:-20%;border-radius:50%;
  background:radial-gradient(circle, rgba(212,168,87,0.18) 0%, transparent 70%);
  transform:translateZ(-50px);pointer-events:none;
}
.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;}

.how-it-works-list{
  margin:0;padding-left:0;list-style:none;counter-reset:steps;
  display:flex;flex-direction:column;gap:14px;
}
.how-it-works-list li{
  position:relative;padding-left:42px;color:var(--gold-soft);font-size:0.92rem;line-height:1.6;
  counter-increment:steps;
}
.how-it-works-list li::before{
  content:counter(steps);position:absolute;left:0;top:-1px;
  width:28px;height:28px;border-radius:50%;border:1px solid var(--gold);
  display:flex;align-items:center;justify-content:center;
  font-family:'Cormorant Garamond',serif;font-size:0.95rem;color:var(--gold-bright);
  background:rgba(212,168,87,0.08);
}

.grid2{display:grid;grid-template-columns:1fr 1fr;gap:16px;}

/* ---- Testimonials ---- */
.testimonial-card{
  border:1px solid var(--line);border-radius:6px;padding:18px 20px;margin-bottom:14px;
  background:linear-gradient(160deg, rgba(232,211,160,0.04), rgba(0,0,0,0.08));
}
.testimonial-card .t-stars{color:var(--gold);font-size:0.9rem;margin-bottom:8px;letter-spacing:2px;}
.testimonial-card .t-text{font-size:0.95rem;line-height:1.7;color:rgba(245,239,224,0.92);margin:0 0 10px;font-style:italic;}
.testimonial-card .t-name{font-family:'Cormorant Garamond',serif;color:var(--gold-bright);font-size:1.05rem;}

/* ---- Loading / generating screen ---- */
.loading-stage{
  min-height:50vh;display:flex;flex-direction:column;align-items:center;justify-content:center;
  text-align:center;padding:40px 20px;
}
.loading-stage h2{font-family:'Cormorant Garamond',serif;font-size:1.8rem;margin:24px 0 10px;color:var(--gold-bright);}
.loading-stage .lead{max-width:420px;}
.loading-stars{position:relative;width:160px;height:160px;}
.loading-stars .star{
  position:absolute;color:var(--gold);font-size:1.6rem;
  animation:twinkle 1.6s ease-in-out infinite;
  opacity:0;
}
.loading-stars .s1{top:10%;left:45%;font-size:2.2rem;animation-delay:0s;}
.loading-stars .s2{top:30%;left:10%;animation-delay:0.25s;}
.loading-stars .s3{top:65%;left:25%;font-size:1.2rem;animation-delay:0.5s;}
.loading-stars .s4{top:75%;left:60%;animation-delay:0.75s;}
.loading-stars .s5{top:25%;left:75%;font-size:1.8rem;animation-delay:1s;}
.loading-stars .s6{top:55%;left:50%;font-size:1.1rem;animation-delay:1.25s;}
@keyframes twinkle{
  0%,100%{opacity:0;transform:scale(0.6) rotate(0deg);}
  50%{opacity:1;transform:scale(1.15) rotate(180deg);}
}
@media (prefers-reduced-motion: reduce){
  .loading-stars .star{animation:none;opacity:0.7;}
}

/* ---- Meet Kashvi section ---- */
.kashvi-intro{
  display:grid;grid-template-columns:280px 1fr;gap:36px;align-items:center;
  margin-bottom:36px;
}
.kashvi-intro.compact{
  grid-template-columns:160px 1fr;gap:24px;margin-bottom:24px;
}
.kashvi-intro.compact .kashvi-text h2{font-size:1.4rem;margin-bottom:6px;}
.kashvi-intro.compact .kashvi-text .lead{font-size:0.9rem;line-height:1.6;}
.kashvi-portrait{
  border-radius:8px;overflow:hidden;border:1px solid var(--line-strong);
  box-shadow:0 12px 40px rgba(0,0,0,0.4), 0 0 0 1px rgba(212,168,87,0.08);
  position:relative;
}
.kashvi-portrait::after{
  content:'';position:absolute;inset:0;border-radius:8px;
  box-shadow:inset 0 0 60px rgba(26,21,48,0.5);
  pointer-events:none;
}
.kashvi-portrait img{display:block;width:100%;height:100%;object-fit:cover;aspect-ratio:3/4;}
.kashvi-text h2{font-family:'Cormorant Garamond',serif;font-size:1.8rem;margin:0 0 10px;}
.kashvi-text .num{color:var(--gold-bright);font-style:italic;margin-right:10px;}
.kashvi-text .lead{font-size:0.98rem;line-height:1.75;margin-bottom:12px;}

@media (max-width:760px){
  .kashvi-intro{grid-template-columns:1fr;gap:22px;text-align:center;}
  .kashvi-portrait{max-width:240px;margin:0 auto;}
  .kashvi-intro.compact .kashvi-portrait{max-width:140px;}
}
@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);}}
@keyframes spin-back{from{transform:translateZ(-30px) rotate(0deg);}to{transform:translateZ(-30px) rotate(360deg);}}
@keyframes spin-mid{from{transform:translateZ(0px) rotate(0deg);}to{transform:translateZ(0px) rotate(360deg);}}
@keyframes spin-front{from{transform:translateZ(28px) rotate(0deg);}to{transform:translateZ(28px) rotate(360deg);}}

@media (prefers-reduced-motion: reduce){
  .scan-line, .ring-wrap svg, .mandala-layer{animation:none !important;}
  .mandala-layer.layer-back{transform:translateZ(-30px);}
  .mandala-layer.layer-mid{transform:translateZ(0px);}
  .mandala-layer.layer-front{transform:translateZ(28px);}
}

/* ---- 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:28px 0 36px;}
  .hero .ring-wrap{width:160px;height:160px;margin-bottom:20px;}
  .hero h1{font-size:2.1rem;}
  .hero p.tag{font-size:0.95rem;line-height:1.6;}
  .hero-actions{width:100%;}
  .hero-actions .btn{width:100%;}

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

  .btn{padding:13px 20px;font-size:0.82rem;}
  .btn.full{width:100%;}
  .hero-actions .btn{width:100%;}
  .row:not(.no-print) > .btn, .row.no-print > .btn{flex:1;min-width:0;text-align:center;}

  .palm-input-tabs{flex-direction:row;}
  .palm-input-tabs .tab-btn{font-size:0.76rem;padding:10px 8px;}

  .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;}

  .grid2{gap:0;}

  .ornate-divider .line{max-width:60px;}
}

@media (max-width:400px){
  .hero h1{font-size:1.8rem;}
  .card h2{font-size:1.2rem;}
}

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