:root{
  --cct-app-bg:#050505;
  --cct-app-panel:#0b0b0e;
  --cct-app-panel-2:#111114;
  --cct-app-text:#f4f1ea;
  --cct-app-muted:#a7a29a;
  --cct-app-line:rgba(255,255,255,.12);
  --cct-app-soft:rgba(255,255,255,.06);
  --cct-app-accent:#d8c7a1;
  --cct-app-accent-2:#e6d7b8;
}

.cct-natal-tool{position:relative;margin:30px auto;overflow:hidden}
.cct-natal-tool>div{position:relative;z-index:1}
.cct-natal-tool>div:first-child{min-width:0}
.cct-natal-form.astro-search{grid-template-columns:repeat(2,minmax(0,1fr));align-items:end;max-width:720px}
.cct-natal-form .field{min-width:0}
.cct-natal-form .field input{min-width:0;width:100%}
.cct-natal-form button{position:relative;grid-column:1/-1;width:100%;min-width:0;overflow:hidden}
.cct-natal-form button:after{content:"";position:absolute;inset:0;background:linear-gradient(90deg,transparent,rgba(255,255,255,.22),transparent);transform:translateX(-120%);transition:transform .55s ease}
.cct-natal-form button:hover:after{transform:translateX(120%)}
.cct-loading{display:inline-block;width:18px;height:18px;margin-right:9px;border:1px solid rgba(244,241,234,.25);border-top-color:var(--cct-app-accent);border-radius:999px;vertical-align:-4px;animation:cctSpin .75s linear infinite}

.cct-natal-pro{position:relative;margin-top:34px;border:1px solid var(--cct-app-line);background:var(--cct-app-bg);color:var(--cct-app-text);overflow:hidden;animation:cctResultIn .62s cubic-bezier(.2,.8,.2,1) both}
.cct-natal-pro:before{content:"";position:absolute;inset:0;pointer-events:none;background-image:radial-gradient(rgba(255,255,255,.12) .6px,transparent .8px);background-size:42px 42px;opacity:.17;mask-image:linear-gradient(#000,transparent 72%)}
.cct-natal-pro:after{content:"";position:absolute;inset:0;pointer-events:none;background:linear-gradient(180deg,rgba(255,255,255,.04),transparent 28%),radial-gradient(circle at 28% 12%,rgba(216,199,161,.09),transparent 34%)}

.cct-result-hero{position:relative;z-index:1;display:grid;grid-template-columns:minmax(0,1.08fr) minmax(300px,.92fr);gap:52px;align-items:center;padding:62px 64px;border-bottom:1px solid var(--cct-app-line);background:linear-gradient(135deg,#050505 0%,#0b0b0e 62%,#151310 100%)}
.cct-result-hero-copy h2{font-family:"Playfair Display",Cinzel,Georgia,serif;font-size:clamp(46px,7vw,96px);font-weight:700;line-height:.92;letter-spacing:.015em;margin:22px 0 26px;max-width:850px;background:linear-gradient(180deg,#fffaf1,#a7a29a);-webkit-background-clip:text;background-clip:text;color:transparent}
.cct-result-hero .mini-label,.cct-section-title span{display:block;color:var(--cct-app-accent);font-size:11px;font-weight:800;letter-spacing:.18em;text-transform:uppercase}
.cct-result-meta{display:flex;flex-wrap:wrap;gap:9px;margin:0;color:var(--cct-app-muted);font-size:13px;line-height:1.7}
.cct-result-meta span{display:inline-flex;align-items:center;min-height:32px;padding:0 11px;border:1px solid var(--cct-app-line);border-radius:999px;background:rgba(255,255,255,.035)}
.cct-result-chart{display:grid;place-items:center;min-width:0}
.cct-chart-fallback{display:grid;place-items:center;width:min(420px,100%);aspect-ratio:1;border:1px solid var(--cct-app-line);border-radius:999px;color:var(--cct-app-accent);font-size:52px}

.cct-result-shell{position:relative;z-index:1;display:grid;grid-template-columns:minmax(0,1fr) 340px;gap:34px;padding:42px 64px 24px}
.cct-result-main,.cct-result-side{min-width:0}
.cct-result-side{display:flex;flex-direction:column;gap:18px}
.cct-section-title{margin:0 0 18px}
.cct-section-title h3{margin:7px 0 0;color:var(--cct-app-text);font-family:"Playfair Display",Cinzel,Georgia,serif;font-size:clamp(25px,3vw,38px);font-weight:650;letter-spacing:.01em}

.cct-core-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px;margin-bottom:34px}
.cct-core-card{position:relative;min-height:220px;padding:24px;border:1px solid var(--cct-app-line);background:linear-gradient(180deg,rgba(255,255,255,.06),rgba(255,255,255,.02));transition:transform .24s ease,border-color .24s ease,background .24s ease}
.cct-core-card:hover{transform:translateY(-3px);border-color:rgba(230,215,184,.38);background:rgba(255,255,255,.075)}
.cct-core-glyph{font-family:Georgia,serif;font-size:48px;line-height:1;color:var(--cct-app-accent);margin-bottom:30px}
.cct-core-card small{display:block;color:var(--cct-app-muted);font-size:11px;font-weight:800;letter-spacing:.13em;text-transform:uppercase}
.cct-core-card strong{display:block;margin:10px 0 7px;color:var(--cct-app-text);font-family:"Playfair Display",Georgia,serif;font-size:31px;font-weight:650;line-height:1.08}
.cct-core-card p{margin:0;color:var(--cct-app-muted);font-size:14px}
.cct-core-card em{position:absolute;left:24px;bottom:22px;color:var(--cct-app-accent-2);font-style:normal;font-size:13px}

.cct-interpretation,.cct-energy-card,.cct-share-card{border:1px solid var(--cct-app-line);background:var(--cct-app-panel)}
.cct-interpretation{padding:28px;margin-bottom:34px}
.cct-interpretation article{padding:22px 0;border-top:1px solid var(--cct-app-line)}
.cct-interpretation article:first-of-type{border-top:0}
.cct-interpretation b{display:block;margin-bottom:8px;color:var(--cct-app-accent);font-size:12px;letter-spacing:.18em;text-transform:uppercase}
.cct-interpretation p{margin:0;color:#d8d3ca;line-height:1.78;font-size:15px}
.cct-interpretation small{display:block;margin-top:8px;color:var(--cct-app-muted);line-height:1.6}

.cct-planetary-breakdown{margin-bottom:16px}
.cct-planet-grid{display:grid;grid-template-columns:1fr;gap:8px}
.cct-planet-card{display:grid;grid-template-columns:44px minmax(0,1fr) auto auto;gap:14px;align-items:center;min-height:74px;padding:14px 16px;border:1px solid var(--cct-app-line);background:rgba(255,255,255,.025);transition:background .22s ease,border-color .22s ease,transform .22s ease}
.cct-planet-card:hover{transform:translateX(3px);border-color:rgba(230,215,184,.34);background:rgba(255,255,255,.06)}
.cct-planet-icon{display:grid;place-items:center;width:42px;height:42px;border:1px solid var(--cct-app-line);border-radius:999px;color:var(--cct-app-accent);font-family:Georgia,serif;font-size:22px}
.cct-planet-name strong{display:block;color:var(--cct-app-text);font-size:15px;font-weight:700}
.cct-planet-name small{display:block;margin-top:2px;color:var(--cct-app-muted);font-size:11px;text-transform:uppercase;letter-spacing:.12em}
.cct-planet-sign{text-align:right}
.cct-planet-sign span{display:block;color:var(--cct-app-text);font-weight:700}
.cct-planet-sign em{display:block;margin-top:3px;color:var(--cct-app-muted);font-style:normal;font-size:12px}
.cct-retro-badge{display:grid;place-items:center;width:26px;height:26px;border:1px solid rgba(216,199,161,.46);border-radius:999px;color:var(--cct-app-accent);font-size:11px;font-weight:900}

.cct-energy-card{position:sticky;top:22px;padding:24px}
.cct-energy-card .cct-section-title h3{font-size:28px}
.cct-energy-row{margin-top:20px}
.cct-energy-row div{display:flex;justify-content:space-between;gap:16px;margin-bottom:9px;color:var(--cct-app-muted);font-size:13px}
.cct-energy-row strong{color:var(--cct-app-text)}
.cct-energy-row i{display:block;height:4px;background:rgba(255,255,255,.1);overflow:hidden}
.cct-energy-row b{display:block;height:100%;background:linear-gradient(90deg,#f4f1ea,var(--cct-app-accent));animation:cctFill 1.05s cubic-bezier(.2,.8,.2,1) both}
.cct-share-card{display:grid;grid-template-columns:1fr 1fr;gap:8px;padding:12px}
.cct-share-card button{min-height:42px;border:1px solid var(--cct-app-line);background:transparent;color:var(--cct-app-text);font-weight:700;cursor:pointer;transition:background .2s ease,color .2s ease}
.cct-share-card button:hover{background:var(--cct-app-text);color:var(--cct-app-bg)}

.cct-natal-wheel{width:min(470px,100%);height:auto;filter:drop-shadow(0 24px 52px rgba(0,0,0,.44))}
.cct-natal-wheel circle,.cct-natal-wheel line,.cct-natal-wheel path{stroke:rgba(244,241,234,.28);stroke-width:1;vector-effect:non-scaling-stroke}
.cct-natal-wheel text{fill:var(--cct-app-text);font:700 14px Inter,Arial,sans-serif;letter-spacing:0}
.cct-natal-wheel circle[fill],.cct-natal-wheel .planet-dot{animation:cctPulse 3.8s ease-in-out infinite}

.cct-natal-warning{margin:16px 0 0;padding:13px 15px;border:1px solid rgba(216,199,161,.34);background:rgba(216,199,161,.08);color:var(--cct-app-accent-2);line-height:1.6}
.cct-natal-cta{position:relative;z-index:1;display:flex;gap:10px;flex-wrap:wrap;padding:6px 64px 58px}
.cct-cta-button{display:inline-flex;align-items:center;justify-content:center;min-height:46px;padding:0 19px;border:1px solid var(--cct-app-line);border-radius:0;background:transparent;color:var(--cct-app-text);font-weight:800;text-decoration:none;transition:background .2s ease,color .2s ease,border-color .2s ease}
.cct-cta-button:hover{background:var(--cct-app-text);border-color:var(--cct-app-text);color:var(--cct-app-bg)}

body.light .cct-natal-pro{background:#050505;color:var(--cct-app-text)}
body.light .cct-natal-wheel text{fill:var(--cct-app-text)}

@keyframes cctResultIn{from{opacity:0;transform:translateY(18px)}to{opacity:1;transform:none}}
@keyframes cctSpin{to{transform:rotate(360deg)}}
@keyframes cctFill{from{width:0}}
@keyframes cctPulse{0%,100%{opacity:.72}50%{opacity:1}}

@media(max-width:1100px){
  .cct-result-hero,.cct-result-shell{grid-template-columns:1fr}
  .cct-result-side{display:grid;grid-template-columns:1fr 1fr;align-items:start}
  .cct-energy-card{position:relative;top:auto}
}

@media(max-width:860px){
  .cct-natal-form.astro-search{grid-template-columns:1fr;max-width:none}
  .cct-result-hero,.cct-result-shell,.cct-natal-cta{padding-left:28px;padding-right:28px}
  .cct-core-grid{grid-template-columns:1fr}
  .cct-result-side{grid-template-columns:1fr}
  .cct-result-hero-copy h2{font-size:clamp(38px,12vw,62px)}
}

@media(max-width:560px){
  .cct-result-hero{gap:30px;padding-top:38px;padding-bottom:34px}
  .cct-result-shell{padding-top:30px}
  .cct-result-meta{display:grid}
  .cct-core-card{min-height:176px}
  .cct-planet-card{grid-template-columns:38px minmax(0,1fr);align-items:start}
  .cct-planet-icon{width:36px;height:36px;font-size:19px}
  .cct-planet-sign{text-align:left;grid-column:2}
  .cct-retro-badge{position:absolute;right:14px;top:14px}
  .cct-natal-cta{flex-direction:column}
  .cct-cta-button{width:100%}
}

/* Homepage hero form: keep the location field readable on desktop. */
.hero-copy #zodiacForm.astro-search{
  width:min(100%,860px);
  padding:18px;
  grid-template-columns:minmax(160px,1fr) minmax(140px,.86fr) minmax(230px,1.35fr);
  gap:14px;
}
.hero-copy #zodiacForm .field label{
  font-size:13px;
  margin-bottom:8px;
}
.hero-copy #zodiacForm .field input{
  height:58px;
  border-radius:17px;
  font-size:15px;
  padding:0 18px;
}
.hero-copy #zodiacForm button{
  grid-column:1/-1;
  width:100%;
  height:58px;
  border-radius:17px;
  font-size:16px;
}
@media(min-width:1800px){
  .hero-copy #zodiacForm.astro-search{
    grid-template-columns:minmax(175px,1fr) minmax(150px,.9fr) minmax(255px,1.4fr) auto;
  }
  .hero-copy #zodiacForm button{
    grid-column:auto;
    width:auto;
    min-width:230px;
  }
}
@media(max-width:767px){
  .hero-copy #zodiacForm.astro-search{
    grid-template-columns:1fr;
    width:100%;
  }
}

/* Homepage quick chart form uses the same compact class, but needs full input width. */
.tools-section .cct-chart-tool.astro-search{
  grid-column:1/-1;
  width:100%;
  padding:18px;
  grid-template-columns:minmax(170px,1fr) minmax(150px,.9fr) minmax(260px,1.35fr);
  gap:14px;
}
.tools-section .cct-chart-tool .field input{
  height:58px;
  border-radius:17px;
  font-size:15px;
  padding:0 18px;
}
.tools-section .cct-chart-tool button{
  grid-column:1/-1;
  width:100%;
  height:58px;
  border-radius:17px;
  font-size:16px;
}
@media(min-width:1800px){
  .tools-section .cct-chart-tool.astro-search{
    grid-template-columns:minmax(180px,1fr) minmax(155px,.9fr) minmax(280px,1.4fr) auto;
  }
  .tools-section .cct-chart-tool button{
    grid-column:auto;
    width:auto;
    min-width:230px;
  }
}
@media(max-width:767px){
  .tools-section .cct-chart-tool.astro-search{
    grid-template-columns:1fr;
  }
}

.cct-seo-page{background:#090918;color:var(--text)}
.cct-seo-hero{position:relative;overflow:hidden;padding:148px 0 76px;background:radial-gradient(circle at 72% 22%,rgba(108,92,231,.25),transparent 32%),linear-gradient(135deg,#080815,#10102a 58%,#070713)}
.cct-seo-hero>.container{position:relative;z-index:2}
.cct-seo-hero h1{font-family:Cinzel,serif;font-size:clamp(44px,6vw,84px);line-height:1.04;margin:12px 0 18px;color:#fff}
.cct-seo-hero p{max-width:820px;color:#d6d0ee;line-height:1.85;font-size:18px}
.cct-breadcrumb{display:flex;gap:9px;flex-wrap:wrap;margin-bottom:22px;color:#bdb7d8;font-size:14px}
.cct-breadcrumb a{color:#ffe08a}.cct-breadcrumb strong{color:#fff}
.cct-seo-section{padding:70px 0;position:relative}
.cct-seo-section h2{font-family:Cinzel,serif;color:#fff;font-size:clamp(30px,4vw,48px);margin:0 0 20px}
.cct-zodiac-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:18px}
.cct-zodiac-card,.cct-info-grid article,.cct-empty-state,.cct-seo-cta,.cct-side-card,.cct-fact-grid div,.cct-compat-box,.cct-faq-list article{background:linear-gradient(180deg,rgba(255,255,255,.09),rgba(255,255,255,.04));border:1px solid var(--border);border-radius:24px;box-shadow:var(--shadow);backdrop-filter:blur(16px)}
.cct-zodiac-card{padding:26px;display:flex;flex-direction:column;min-height:290px}
.cct-zodiac-glyph{font-size:46px;color:var(--gold);line-height:1;margin-bottom:18px}
.cct-zodiac-card h2{font-size:24px;margin-bottom:8px}.cct-zodiac-card p{color:#cfc9e9;line-height:1.7}.cct-card-meta{color:#ffe08a!important;font-weight:700}
.cct-outline-link{display:inline-flex;align-items:center;justify-content:center;min-height:44px;margin-top:auto;padding:0 16px;border:1px solid rgba(255,224,138,.32);border-radius:999px;color:#ffe08a;font-weight:800}
.cct-outline-link:hover{background:#ffe08a;color:#121020}
.cct-info-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:18px}
.cct-info-grid article{padding:26px}.cct-info-grid h3,.cct-info-grid h2{font-family:Cinzel,serif;font-size:26px;margin:0 0 12px;color:#fff}.cct-info-grid p{color:#cfc9e9;line-height:1.8}.cct-info-grid a{color:#ffe08a;margin-right:10px}
.cct-elements-band{background:radial-gradient(circle at 15% 20%,rgba(255,224,138,.12),transparent 35%),#0d0d22}
.cct-seo-cta{display:grid;grid-template-columns:1fr auto;gap:24px;align-items:center;padding:34px}.cct-seo-cta p{color:#cfc9e9;line-height:1.8;max-width:760px}
.cct-zodiac-hero-grid{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:40px;align-items:center}.cct-zodiac-symbol{font-size:clamp(120px,18vw,240px);line-height:1;color:#ffe08a;text-shadow:0 0 80px rgba(255,224,138,.28)}
.cct-hero-links,.cct-chip-row,.cct-internal-links{display:flex;gap:10px;flex-wrap:wrap;margin-top:20px}.cct-hero-links a,.cct-chip-row a,.cct-internal-links a{padding:10px 14px;border:1px solid var(--border);border-radius:999px;color:#fff;background:rgba(255,255,255,.06)}
.cct-content-layout{display:grid;grid-template-columns:minmax(0,1fr) 320px;gap:28px}.cct-main-content{min-width:0}.cct-main-content section{margin-bottom:34px}.cct-main-content p,.cct-main-content li{color:#d6d0ee;line-height:1.85}.cct-main-content h2{font-size:34px}
.cct-fact-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px;margin-bottom:34px}.cct-fact-grid div{padding:18px}.cct-fact-grid span{display:block;color:#bdb7d8;font-size:12px;text-transform:uppercase;letter-spacing:.1em}.cct-fact-grid strong{display:block;color:#fff;margin-top:6px}
.cct-two-col{display:grid;grid-template-columns:1fr 1fr;gap:22px}.cct-sidebar{display:flex;flex-direction:column;gap:16px}.cct-side-card{padding:22px;position:sticky;top:100px}.cct-side-card+ .cct-side-card{position:static}.cct-side-card h3{color:#fff}.cct-side-card a{display:block;color:#d6d0ee;margin:9px 0}.cct-side-card p{color:#bdb7d8;line-height:1.7}
.cct-faq-list{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:16px}.cct-faq-list article{padding:24px}.cct-faq-list h3{color:#fff;font-size:20px}.cct-faq-list p{color:#cfc9e9;line-height:1.75}
.cct-compat-box{padding:26px}.cct-compat-form{display:grid;grid-template-columns:1fr 1fr auto;gap:14px;align-items:end}.cct-compat-form label{display:grid;gap:8px;color:#bdb7d8;font-weight:700}.cct-compat-form select{height:54px;border:1px solid var(--border);border-radius:16px;background:#101026;color:#fff;padding:0 14px}.cct-compat-form button{height:54px;border:0;border-radius:16px;background:linear-gradient(135deg,var(--primary),var(--accent));color:#fff;font-weight:900;padding:0 20px}.cct-compat-result{margin-top:18px;padding:18px;border:1px solid rgba(255,224,138,.24);border-radius:18px;color:#f7e7a6;background:rgba(255,224,138,.08)}.cct-compat-score{display:flex;gap:12px;align-items:baseline}.cct-compat-score strong{font-size:46px;color:#fff}.cct-compat-score span{text-transform:uppercase;letter-spacing:.12em;font-weight:900}
@media(max-width:991px){.cct-zodiac-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.cct-info-grid,.cct-content-layout,.cct-zodiac-hero-grid,.cct-seo-cta,.cct-compat-form{grid-template-columns:1fr}.cct-fact-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.cct-sidebar{display:grid;grid-template-columns:1fr 1fr}.cct-side-card{position:static}.cct-faq-list{grid-template-columns:1fr}}
@media(max-width:575px){.cct-seo-hero{padding-top:118px}.cct-zodiac-grid,.cct-fact-grid,.cct-two-col,.cct-sidebar{grid-template-columns:1fr}.cct-zodiac-symbol{font-size:110px}.cct-seo-section{padding:48px 0}}

/* Vietnamese-safe typography refresh. */
body,
button,
input,
select,
textarea,
.main-nav a,
.hero-desc,
.cct-seo-page,
.cct-natal-pro{
  font-family:"Be Vietnam Pro",system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;
}
.brand-text,
.hero-copy h1,
.section-head h2,
.chart-box h2,
.newsletter h2,
.cct-result-hero-copy h2,
.cct-section-title h3,
.cct-core-card strong,
.cct-seo-hero h1,
.cct-seo-section h2,
.cct-info-grid h2,
.cct-info-grid h3,
.cct-main-content h2{
  font-family:"Noto Serif",Georgia,"Times New Roman",serif;
  letter-spacing:0;
}
.hero-copy h1,
.cct-seo-hero h1,
.cct-result-hero-copy h2{
  font-weight:800;
}

/* Header navigation: shorter, user-focused, no awkward line breaks. */
.header-inner{
  gap:18px;
}
.brand-text{
  font-size:clamp(20px,1.7vw,25px);
  white-space:nowrap;
}
.main-nav{
  flex:1 1 auto;
  justify-content:center;
  gap:clamp(12px,1.45vw,22px);
  min-width:0;
}
.main-nav a{
  white-space:nowrap;
  font-size:14px;
  line-height:1;
}
.header-actions{
  flex:0 0 auto;
  gap:10px;
}
.header-actions .btn-glow{
  padding:13px 18px;
  white-space:nowrap;
}
@media(max-width:1180px){
  .header-actions .btn-glow{
    display:none;
  }
  .main-nav{
    gap:14px;
  }
}
@media(max-width:991px){
  .main-nav{
    justify-content:flex-start;
    gap:18px;
  }
  .main-nav a{
    white-space:normal;
    line-height:1.35;
  }
}
