/* ============================================================
   ASTROLOGICS - shared components: nav, footer, astrologer card,
   category tiles, zodiac, trust strip, app band
   ============================================================ */

/* ——————————————————— Top utility bar ——————————————————— */
.util-bar {
  background: var(--grad-ember); color: #FFE9D2;
  font-size: .82rem; font-weight: 600;
}
.util-bar .wrap { display:flex; align-items:center; justify-content:space-between; min-height:38px; gap:1rem; }
.util-bar a { color:#FFF; font-weight:800; }
.util-bar .util-right { display:flex; gap:1.3rem; align-items:center; }
@media (max-width:680px){ .util-bar .util-right span.hide-sm { display:none; } }

/* ——————————————————— Nav ——————————————————— */
.nav {
  position: sticky; top: 0; z-index: 60;
  background: rgba(255,248,238,.86);
  backdrop-filter: saturate(150%) blur(14px);
  -webkit-backdrop-filter: saturate(150%) blur(14px);
  border-bottom: 1px solid var(--line);
}
.nav .wrap { display:flex; align-items:center; gap:1.2rem; min-height: var(--nav-h); }
.brand { display:flex; align-items:center; gap:.62rem; font-family:var(--font-display); font-weight:600; font-size:1.34rem; color:var(--ink); letter-spacing:-.01em; }
.brand .mark {
  width:38px; height:38px; border-radius:11px; display:grid; place-items:center;
  background: var(--grad-sunrise); color:#fff; font-size:1.15rem;
  box-shadow: 0 6px 14px -4px rgba(232,89,12,.5), inset 0 1px 0 rgba(255,255,255,.4);
  flex:none;
}
.brand b { color: var(--saffron-deep); font-weight:600; }
.brand .bwrap { display:flex; flex-direction:column; line-height:1; }
.brand .btag { font-family:var(--font-body); font-style:normal; font-weight:800; font-size:.54rem; letter-spacing:.14em; text-transform:uppercase; color:var(--gold); margin-top:3px; }
@media(max-width:1180px){ .brand .btag{ display:none; } }
.nav-links { display:flex; align-items:center; gap:.1rem; margin-inline:auto; }
.nav-links a {
  padding:.5rem .62rem; border-radius:var(--r-pill); font-weight:700; font-size:.89rem; color:var(--ink-2);
  transition: color .2s, background .2s; white-space:nowrap;
}
.nav-links a:hover, .nav-links a.active { color:var(--saffron-deep); background:#FFF1DC; }
.nav-cta { display:flex; align-items:center; gap:.6rem; }
.wallet-pill {
  display:flex; align-items:center; gap:.45rem; padding:.5rem .85rem; border-radius:var(--r-pill);
  background:#fff; box-shadow: inset 0 0 0 1.5px var(--line); font-weight:800; font-size:.9rem; color:var(--maroon);
}
.wallet-pill .coin { color:var(--gold); }
.hamburger { display:none; width:44px; height:44px; border-radius:12px; place-items:center; box-shadow:inset 0 0 0 1.5px var(--line); background:#fff; }
.hamburger span, .hamburger span::before, .hamburger span::after {
  content:""; display:block; width:19px; height:2px; background:var(--ink); border-radius:2px; transition:.3s var(--ease); position:relative;
}
.hamburger span::before { position:absolute; top:-6px; } .hamburger span::after { position:absolute; top:6px; }

@media (max-width: 1000px) {
  .nav-links { display:none; }
  .hamburger { display:grid; }
  .nav-cta .btn span.hide-sm { display:none; }
  .wallet-pill { display:none; }
}

/* mobile drawer */
.drawer-scrim { position:fixed; inset:0; background:rgba(39,24,16,.45); backdrop-filter:blur(2px); opacity:0; pointer-events:none; transition:.3s; z-index:90; }
.drawer-scrim.open { opacity:1; pointer-events:auto; }
.drawer {
  position:fixed; top:0; right:0; height:100%; width:min(86vw,360px); z-index:100;
  background:var(--bg); box-shadow:var(--sh-lg); transform:translateX(100%); transition:transform .36s var(--ease-out);
  padding:1.4rem 1.3rem; overflow-y:auto;
}
.drawer.open { transform:none; }
.drawer-head { display:flex; align-items:center; justify-content:space-between; margin-bottom:1rem; }
.drawer-close { width:40px; height:40px; border-radius:11px; box-shadow:inset 0 0 0 1.5px var(--line); display:grid; place-items:center; font-size:1.2rem; }
.drawer a.dl { display:block; padding:.85rem .4rem; font-weight:800; font-size:1.05rem; border-bottom:1px solid var(--line); color:var(--ink); }
.drawer a.dl:hover { color:var(--saffron-deep); }

/* ——————————————————— Trust strip ——————————————————— */
.trust-strip { display:flex; flex-wrap:wrap; gap:1rem 1.8rem; align-items:center; }
.trust-strip .ti { display:flex; align-items:center; gap:.5rem; font-weight:700; font-size:.92rem; color:var(--ink-2); }
.trust-strip .ti b { color:var(--ink); font-family:var(--font-display); font-size:1.05rem; }
.trust-strip .ti svg { color:var(--saffron); flex:none; }

/* ——————————————————— Astrologer card ——————————————————— */
.astro-card {
  background:var(--card); border-radius:var(--r-md); padding:1.15rem; position:relative;
  box-shadow:var(--sh-sm); border:1px solid var(--line-2);
  transition: transform .3s var(--ease), box-shadow .3s var(--ease), border-color .3s;
  display:flex; flex-direction:column;
}
.astro-card:hover { transform:translateY(-5px); box-shadow:var(--sh-md); border-color:var(--gold-soft); }
.astro-card .ac-top { display:flex; gap:.9rem; }
.astro-card .ac-ava { position:relative; flex:none; }
.astro-card .ac-ava img, .astro-card .ac-ava .ava-fallback {
  width:66px; height:66px; border-radius:50%; object-fit:cover;
  box-shadow:0 0 0 3px #fff, 0 0 0 5px var(--gold-soft);
}
.ava-fallback { display:grid; place-items:center; border-radius:50%; font-family:var(--font-display); font-weight:600; font-size:1.5rem; color:#fff; background:var(--grad-sunrise); }
.astro-card .ac-status { position:absolute; bottom:2px; right:2px; width:15px; height:15px; border-radius:50%; border:2.5px solid #fff; background:var(--tulsi); }
.astro-card .ac-status.busy { background:#E0903A; }
.astro-card .ac-status.off { background:#B9A98F; }
.astro-card h3 { font-size:1.08rem; line-height:1.2; }
.astro-card .ac-verified { color:var(--sky); vertical-align:middle; }
.astro-card .ac-skills { color:var(--ink-2); font-size:.86rem; font-weight:600; margin-top:.15rem; }
.astro-card .ac-meta { color:var(--ink-3); font-size:.8rem; margin-top:.3rem; display:flex; flex-wrap:wrap; gap:.2rem .7rem; }
.astro-card .ac-rate-row { display:flex; align-items:center; justify-content:space-between; margin-top:.9rem; padding-top:.8rem; border-top:1px dashed var(--line); }
.astro-card .ac-rate { font-family:var(--font-display); font-weight:600; color:var(--ink); font-size:1.05rem; }
.astro-card .ac-rate s { color:var(--ink-3); font-weight:400; font-size:.82rem; font-family:var(--font-body); margin-right:.3rem; }
.astro-card .ac-rate small { color:var(--tulsi-deep); font-weight:800; font-family:var(--font-body); font-size:.72rem; }
.astro-card .ac-actions { display:flex; gap:.5rem; margin-top:.85rem; }
.astro-card .ac-actions .btn { flex:1; }
.ribbon {
  position:absolute; top:14px; right:-2px; background:var(--grad-gold); color:var(--maroon-deep);
  font-size:.68rem; font-weight:900; letter-spacing:.04em; padding:.3em .7em; border-radius:6px 0 0 6px;
  box-shadow:var(--sh-xs); text-transform:uppercase;
}
.rating-pill { display:inline-flex; align-items:center; gap:.3em; background:#FFF6E2; color:var(--maroon); font-weight:800; font-size:.78rem; padding:.2em .55em; border-radius:var(--r-pill); box-shadow:inset 0 0 0 1px var(--gold-soft); }

/* ——————————————————— Category tiles ——————————————————— */
.cat-grid { display:grid; grid-template-columns:repeat(2,1fr); gap:.8rem; }
@media(min-width:680px){ .cat-grid{ grid-template-columns:repeat(4,1fr);} }
.cat-tile {
  display:flex; flex-direction:column; gap:.55rem; padding:1.15rem 1rem; border-radius:var(--r-md);
  background:var(--card); border:1px solid var(--line-2); box-shadow:var(--sh-xs);
  transition:.3s var(--ease); position:relative; overflow:hidden;
}
.cat-tile:hover { transform:translateY(-4px); box-shadow:var(--sh-md); }
.cat-tile .ci { width:46px; height:46px; border-radius:13px; display:grid; place-items:center; font-size:1.45rem; }
.cat-tile h4 { font-family:var(--font-body); font-weight:800; font-size:.98rem; color:var(--ink); }
.cat-tile p { font-size:.8rem; color:var(--ink-3); }
.cat-tile .ci.love { background:#FCE3EC; } .cat-tile .ci.career{ background:#E7EEFF;} .cat-tile .ci.marriage{ background:#FFE9D6;}
.cat-tile .ci.health{ background:#E7F6EE;} .cat-tile .ci.finance{ background:#FFF3CF;} .cat-tile .ci.edu{ background:#EDE7FB;}
.cat-tile .ci.vastu{ background:#E5F3F8;} .cat-tile .ci.match{ background:#FCE3EC;}

/* ——————————————————— Zodiac wheel ——————————————————— */
.zodiac-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:.7rem; }
@media(min-width:680px){ .zodiac-grid{ grid-template-columns:repeat(6,1fr);} }
.zodiac-tile {
  display:flex; flex-direction:column; align-items:center; gap:.35rem; padding:1rem .5rem; border-radius:var(--r-sm);
  background:var(--card); border:1px solid var(--line-2); box-shadow:var(--sh-xs); transition:.25s var(--ease);
}
.zodiac-tile:hover{ transform:translateY(-3px); border-color:var(--gold-soft); box-shadow:var(--sh-sm); }
.zodiac-tile .zg { width:42px; height:42px; border-radius:50%; display:grid; place-items:center; font-size:1.3rem; background:var(--grad-dawn); box-shadow:inset 0 0 0 1.5px var(--gold-soft); color:var(--maroon); }
.zodiac-tile b{ font-size:.86rem; } .zodiac-tile small{ color:var(--ink-3); font-size:.72rem; }

/* ——————————————————— Steps ——————————————————— */
.steps { counter-reset: step; }
.step .num {
  width:48px; height:48px; border-radius:14px; display:grid; place-items:center;
  font-family:var(--font-display); font-weight:600; font-size:1.3rem; color:#fff; background:var(--grad-saffron);
  box-shadow:var(--sh-sm);
}

/* ——————————————————— App band ——————————————————— */
.app-band { background:var(--ink-panel); color:#FFF1E0; border-radius:var(--r-xl); overflow:hidden; position:relative; }
.app-band::before { content:""; position:absolute; right:-10%; top:-40%; width:60%; height:180%; background:var(--grad-ember); filter:blur(40px); opacity:.5; }

/* ——————————————————— Testimonial ——————————————————— */
.tcard { background:var(--card); border-radius:var(--r-md); padding:1.5rem; box-shadow:var(--sh-sm); border:1px solid var(--line-2); position:relative; }
.tcard .quote { font-family:var(--font-display); font-size:3rem; line-height:.6; color:var(--gold-soft); }
.tcard p { color:var(--ink-2); }
.tcard .who { display:flex; align-items:center; gap:.7rem; margin-top:1rem; }
.tcard .who .ava-fallback{ width:44px; height:44px; font-size:1.1rem; }

/* ——————————————————— Footer ——————————————————— */
.foot { background:var(--ink-panel); color:#E9D8C4; position:relative; z-index:1; margin-top:auto; }
.foot a { color:#D8C4AC; transition:color .2s; } .foot a:hover { color:var(--gold-soft); }
.foot-top { display:grid; gap:2rem; grid-template-columns:1.4fr; padding-block:clamp(48px,7vw,80px); }
@media(min-width:720px){ .foot-top{ grid-template-columns:1.6fr 1fr 1fr 1fr; } }
.foot h5 { font-family:var(--font-body); font-weight:800; font-size:.8rem; letter-spacing:.14em; text-transform:uppercase; color:var(--gold-soft); margin-bottom:1rem; }
.foot ul li { margin-bottom:.55rem; font-size:.92rem; }
.foot .brand { color:#FFF; margin-bottom:.8rem; }
.foot .fcontact { font-size:.9rem; line-height:1.9; color:#CBB59C; }
.foot-social { display:flex; gap:.6rem; margin-top:1rem; }
.foot-social a { width:38px; height:38px; border-radius:10px; display:grid; place-items:center; background:rgba(255,255,255,.06); box-shadow:inset 0 0 0 1px rgba(232,184,75,.25); }
.foot-social a:hover { background:var(--grad-gold); color:var(--maroon-deep); }
.foot-bottom { border-top:1px solid rgba(232,184,75,.18); padding-block:1.3rem; display:flex; flex-wrap:wrap; gap:.6rem 1.4rem; align-items:center; justify-content:space-between; font-size:.84rem; color:#B7A084; }
.foot-bottom .fb-links { display:flex; flex-wrap:wrap; gap:1.1rem; }
.seo-cloud { display:flex; flex-wrap:wrap; gap:.5rem; padding-block:1.6rem; border-top:1px solid rgba(232,184,75,.14); }
.seo-cloud a { font-size:.78rem; padding:.3em .7em; border-radius:var(--r-pill); background:rgba(255,255,255,.05); box-shadow:inset 0 0 0 1px rgba(232,184,75,.18); }

/* page hero (inner pages) */
.page-hero { background:var(--grad-dawn); padding-top:clamp(40px,6vw,72px); padding-bottom:clamp(30px,5vw,56px); position:relative; }
.breadcrumb { font-size:.84rem; color:var(--ink-3); font-weight:700; display:flex; gap:.4rem; }
.breadcrumb a:hover{ color:var(--saffron-deep);}
