:root {
  --crimson: #c1121f;
  --rose: #e63946;
  --blush: #ff6b81;
  --cream: #fff8f0;
  --ivory: #fdf4e8;
  --dark: #1a0a0d;
  --mid: #3d1a20;
  --text: #2d1215;
  --muted: #8a6068;
  --gold: #c9a84c;
  --card-bg: rgba(255,255,255,0.85);
}
* { margin:0; padding:0; box-sizing:border-box; }
html { scroll-behavior: smooth; }
body {
  font-family: 'DM Sans', sans-serif;
  background: var(--cream);
  color: var(--text);
  overflow-x: hidden;
}

/* ── BACKGROUND ── */
body::before {
  content:'';
  position: fixed; inset:0; z-index:-1;
  background:
    radial-gradient(ellipse 80% 60% at 20% 10%, rgba(193,18,31,0.08) 0%, transparent 60%),
    radial-gradient(ellipse 60% 50% at 80% 90%, rgba(201,168,76,0.07) 0%, transparent 60%),
    var(--cream);
}

/* ══ HEADER ══ */
header {
  background: linear-gradient(135deg, var(--dark) 0%, var(--mid) 100%);
  padding: 0 5%;
  display: flex;
  align-items: center;
  justify-content: space-between;
  height: 72px;
  position: sticky; top:0; z-index:100;
  box-shadow: 0 4px 30px rgba(193,18,31,0.3);
}
.logo {
  font-family:'Playfair Display', serif;
  font-size:1.7rem;
  color: #fff;
  letter-spacing:1px;
  text-decoration: none !important;
  display: inline-block;
  transition: opacity 0.2s;
}
a.logo {
  text-decoration: none !important;
  border-bottom: none !important;
}
.logo:hover {
  opacity: 0.9;
  text-decoration: none !important;
}
.logo span { color: var(--blush); }
nav { display:flex; gap:28px; align-items:center; }
nav a {
  color: rgba(255,255,255,0.8);
  text-decoration:none;
  font-size:.9rem;
  font-weight:400;
  letter-spacing:.5px;
  transition: color .2s;
}
nav a:hover { color: var(--blush); }
.nav-cta {
  background: var(--rose);
  color:#fff !important;
  padding: 8px 20px;
  border-radius: 30px;
  font-weight:500 !important;
  transition: transform .2s, background .2s !important;
}
.nav-cta:hover { background: var(--blush); transform: scale(1.04); }
nav a.active { color: var(--blush); }

/* ── Nav Dropdown ── */
.nav-dropdown { position:relative; }
.nav-dropdown-trigger {
  color: rgba(255,255,255,0.8); text-decoration:none; font-size:.9rem;
  font-weight:400; letter-spacing:.5px; cursor:pointer; transition:color .2s;
  display:flex; align-items:center; gap:5px; user-select:none;
  background:none; border:none; font-family:inherit;
}
.nav-dropdown-trigger:hover, .nav-dropdown.active .nav-dropdown-trigger { color: var(--blush); }
.nav-dropdown-trigger .dd-arrow { font-size:.6rem; transition:transform .25s; }
.nav-dropdown:hover .dd-arrow { transform:rotate(180deg); }

.nav-dropdown-menu {
  display:none; position:absolute; top:calc(100% + 12px); left:50%;
  transform:translateX(-50%); background:var(--dark);
  border-radius:18px; padding:14px 0; min-width:480px;
  box-shadow:0 16px 48px rgba(0,0,0,0.45), 0 0 0 1px rgba(255,255,255,0.06);
  z-index:200; animation:ddFadeIn .2s ease;
}
.nav-dropdown-menu::before {
  content:''; position:absolute; top:-8px; left:50%; transform:translateX(-50%);
  border:8px solid transparent; border-bottom-color:var(--dark);
}
.nav-dropdown:hover .nav-dropdown-menu { display:grid; grid-template-columns:1fr 1fr; }
.nav-dropdown-menu a {
  display:flex; align-items:center; gap:10px; padding:11px 22px; font-size:.88rem;
  color:rgba(255,255,255,0.75); text-decoration:none; transition:all .15s; white-space:nowrap;
}
.nav-dropdown-menu a:hover {
  background:rgba(255,107,129,0.10); color:#fff;
}
.nav-dropdown-menu a.dd-active { color:var(--blush); font-weight:500; }
.nav-dropdown-menu .dd-icon { font-size:1rem; width:22px; text-align:center; flex-shrink:0; }
@keyframes ddFadeIn { from{opacity:0;transform:translateX(-50%) translateY(6px);} to{opacity:1;transform:translateX(-50%) translateY(0);} }

/* ── Mobile Tools Toggle ── */
.mobile-tools-header {
  display:flex; justify-content:space-between; align-items:center;
  color:rgba(255,255,255,0.8); padding:14px 0;
  border-bottom:1px solid rgba(255,255,255,0.1);
  font-size:.95rem; cursor:pointer; user-select:none; transition:color .2s;
}
.mobile-tools-header:hover { color:var(--blush); }
.mobile-tools-header .mt-arrow { transition:transform .25s; font-size:.7rem; }
.mobile-tools-header.open .mt-arrow { transform:rotate(180deg); }
.mobile-tools-list {
  max-height:0; overflow:hidden; transition:max-height .35s ease;
}
.mobile-tools-list.open { max-height:800px; }
.mobile-tools-list a {
  display:block; color:rgba(255,255,255,0.65); text-decoration:none;
  padding:11px 0 11px 18px; border-bottom:1px solid rgba(255,255,255,0.05);
  font-size:.88rem; transition:color .2s;
}
.mobile-tools-list a:hover, .mobile-tools-list a.active { color:var(--blush); }

/* ══ HERO ══ */
.hero {
  text-align:center;
  padding: 60px 5% 40px;
  position:relative;
}
.hero-tag {
  display:inline-block;
  background: rgba(193,18,31,0.1);
  border: 1px solid rgba(193,18,31,0.2);
  color: var(--crimson);
  font-size:.8rem;
  letter-spacing:2px;
  text-transform:uppercase;
  padding:5px 16px;
  border-radius:30px;
  margin-bottom:20px;
}
.hero h1 {
  font-family:'Playfair Display', serif;
  font-size: clamp(2.4rem, 6vw, 4.2rem);
  line-height:1.15;
  color: var(--dark);
  margin-bottom:20px;
}
.hero h1 em { color: var(--crimson); font-style:italic; }
.hero p {
  max-width:560px;
  margin:0 auto 36px;
  color: var(--muted);
  font-size:1.05rem;
  line-height:1.7;
}
.floating-hearts {
  position:absolute;
  inset:0;
  pointer-events:none;
  overflow:hidden;
}
.fh {
  position:absolute;
  font-size:1.5rem;
  animation: floatHeart 6s ease-in-out infinite;
  opacity:.2;
}
.fh:nth-child(1){left:5%; top:20%; animation-delay:0s;}
.fh:nth-child(2){left:90%; top:30%; animation-delay:1.5s; font-size:1rem;}
.fh:nth-child(3){left:15%; top:70%; animation-delay:3s; font-size:.8rem;}
.fh:nth-child(4){left:80%; top:70%; animation-delay:2s;}
.fh:nth-child(5){left:50%; top:85%; animation-delay:4s; font-size:1.2rem;}
@keyframes floatHeart {
  0%,100%{ transform: translateY(0) rotate(0deg); }
  50%{ transform: translateY(-18px) rotate(10deg); }
}

/* ══ CALCULATOR CARD ══ */
.calc-card {
  background: #fff;
  border-radius: 28px;
  box-shadow: 0 20px 80px rgba(193,18,31,0.12), 0 4px 20px rgba(0,0,0,0.06);
  max-width: 680px;
  margin: 0 auto 80px;
  padding: 50px 50px 40px;
  position:relative;
  overflow:hidden;
}
.calc-card::before {
  content:'';
  position:absolute;
  top:0; left:0; right:0;
  height:4px;
  background: linear-gradient(90deg, var(--crimson), var(--blush), var(--gold));
}
.calc-card h2 {
  font-family:'Playfair Display', serif;
  font-size:1.6rem;
  text-align:center;
  margin-bottom:32px;
  color: var(--dark);
}
.input-group {
  margin-bottom:20px;
}
.input-group label {
  display:block;
  font-size:.82rem;
  font-weight:500;
  letter-spacing:.5px;
  text-transform:uppercase;
  color: var(--muted);
  margin-bottom:8px;
}
.input-row {
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:16px;
  margin-bottom:20px;
}
.name-input {
  width:100%;
  padding:14px 18px;
  border: 2px solid #ead9dc;
  border-radius:12px;
  font-family:'DM Sans', sans-serif;
  font-size:1rem;
  color: var(--dark);
  background: var(--ivory);
  transition: border-color .2s, box-shadow .2s;
  outline:none;
}
.name-input:focus {
  border-color: var(--blush);
  box-shadow: 0 0 0 4px rgba(255,107,129,0.12);
  background:#fff;
}
.heart-divider {
  text-align:center;
  font-size:1.4rem;
  margin-bottom:20px;
  animation: pulse 1.5s ease-in-out infinite;
}
@keyframes pulse { 0%,100%{transform:scale(1)} 50%{transform:scale(1.2)} }

.btn-calc {
  width:100%;
  padding:16px;
  background: linear-gradient(135deg, var(--crimson), var(--rose));
  color:#fff;
  border:none;
  border-radius:14px;
  font-family:'DM Sans', sans-serif;
  font-size:1.05rem;
  font-weight:500;
  letter-spacing:.5px;
  cursor:pointer;
  transition: transform .2s, box-shadow .2s;
  box-shadow: 0 8px 30px rgba(193,18,31,0.3);
  margin-bottom:16px;
}
.btn-calc:hover { transform: translateY(-2px); box-shadow: 0 12px 40px rgba(193,18,31,0.4); }
.btn-calc:active { transform: translateY(0); }

.btn-reset {
  width:100%;
  padding:12px;
  background: transparent;
  color: var(--muted);
  border: 2px solid #ead9dc;
  border-radius:14px;
  font-family:'DM Sans', sans-serif;
  font-size:.9rem;
  cursor:pointer;
  transition: all .2s;
}
.btn-reset:hover { border-color: var(--blush); color: var(--rose); }

/* Result */
.result-box {
  display:none;
  text-align:center;
  margin-top:32px;
  padding:32px;
  background: linear-gradient(135deg, #fff5f6, #fff8f0);
  border-radius:20px;
  border: 2px solid rgba(193,18,31,0.12);
  animation: fadeIn .5s ease;
}
@keyframes fadeIn { from{opacity:0;transform:translateY(15px)} to{opacity:1;transform:translateY(0)} }
.result-emoji { font-size:3.5rem; margin-bottom:12px; }
.result-label {
  font-size:.8rem;
  letter-spacing:2px;
  text-transform:uppercase;
  color: var(--muted);
  margin-bottom:8px;
}
.result-word {
  font-family:'Playfair Display', serif;
  font-size:2.4rem;
  font-weight:700;
  margin-bottom:8px;
}
.result-desc {
  font-size:.95rem;
  color: var(--muted);
  line-height:1.6;
  max-width:360px;
  margin:0 auto 20px;
}
.result-steps {
  background: #fff;
  border-radius:12px;
  padding:18px;
  text-align:left;
  font-size:.85rem;
  color: var(--muted);
  border:1px solid rgba(0,0,0,0.06);
  line-height:1.8;
}
.result-steps strong { color: var(--dark); }
/* Result colors */
.rf { color: #2563eb; }
.rl { color: var(--crimson); }
.ra { color: #d97706; }
.rm { color: #16a34a; }
.re { color: #7c3aed; }
.rs { color: #0891b2; }

/* ══ FLAMES MEANING ══ */
section { padding: 60px 5%; }
.section-center { text-align:center; }
.section-tag {
  display:inline-block;
  background: rgba(193,18,31,0.08);
  border:1px solid rgba(193,18,31,0.15);
  color: var(--crimson);
  font-size:.75rem;
  letter-spacing:2.5px;
  text-transform:uppercase;
  padding:5px 14px;
  border-radius:30px;
  margin-bottom:16px;
}
.section-title {
  font-family:'Playfair Display', serif;
  font-size: clamp(1.8rem, 4vw, 2.8rem);
  color: var(--dark);
  margin-bottom:16px;
}
.section-sub {
  color: var(--muted);
  max-width:560px;
  margin:0 auto 36px;
  line-height:1.7;
  font-size:1rem;
}

.flames-grid {
  display:grid;
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
  gap:24px;
  max-width:1100px;
  margin:0 auto;
}
.flames-card {
  background: var(--card-bg);
  border-radius:20px;
  padding:32px 28px;
  border:1px solid rgba(0,0,0,0.06);
  box-shadow:0 4px 20px rgba(0,0,0,0.04);
  transition: transform .25s, box-shadow .25s;
  backdrop-filter: blur(8px);
}
.flames-card:hover { transform: translateY(-5px); box-shadow:0 12px 40px rgba(0,0,0,0.1); }
.flames-icon { font-size:2.2rem; margin-bottom:14px; }
.flames-letter {
  font-family:'Playfair Display', serif;
  font-size:1.4rem;
  font-weight:700;
  margin-bottom:6px;
}
.flames-word { font-size:.85rem; letter-spacing:1px; text-transform:uppercase; color: var(--muted); margin-bottom:10px; }
.flames-desc { font-size:.9rem; color: var(--muted); line-height:1.6; }

/* ══ HOW IT WORKS ══ */
.hiw-bg { background: var(--dark); color:#fff; padding: 40px 5% !important; }
.hiw-bg .section-title { color:#fff; }
.hiw-bg .section-sub { color:rgba(255,255,255,0.55); margin-bottom:24px; }
.hiw-bg .section-center { margin-bottom:28px; }
.steps-grid {
  display:grid;
  grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
  gap:20px;
  max-width:1000px;
  margin:0 auto;
}
.step-item { text-align:center; }
.step-num {
  width:56px; height:56px;
  border-radius:50%;
  background: linear-gradient(135deg, var(--crimson), var(--blush));
  color:#fff;
  font-family:'Playfair Display', serif;
  font-size:1.5rem;
  display:grid; place-items:center;
  margin:0 auto 12px;
  box-shadow: 0 8px 24px rgba(193,18,31,0.4);
}
.step-title { font-weight:500; margin-bottom:6px; color:#fff; }
.step-desc { font-size:.88rem; color:rgba(255,255,255,0.55); line-height:1.5; }

/* ══ WHY USE ══ */
.why-section { background: var(--ivory); }
.why-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
  gap: 24px;
  max-width: 1100px;
  margin: 0 auto;
}
.why-card {
  background: #fff;
  border-radius: 20px;
  padding: 34px 28px;
  border: 1px solid rgba(193,18,31,0.08);
  box-shadow: 0 4px 20px rgba(0,0,0,0.05);
  text-align: center;
  transition: transform .25s, box-shadow .25s;
  position: relative;
  overflow: hidden;
}
.why-card::before {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 3px;
  background: linear-gradient(90deg, var(--crimson), var(--blush));
  opacity: 0;
  transition: opacity .3s;
}
.why-card:hover { transform: translateY(-6px); box-shadow: 0 16px 48px rgba(193,18,31,0.12); }
.why-card:hover::before { opacity: 1; }
.why-icon-wrap {
  font-size: 2.4rem;
  margin-bottom: 16px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 64px; height: 64px;
  background: linear-gradient(135deg, rgba(193,18,31,0.08), rgba(255,107,129,0.08));
  border-radius: 18px;
}
.why-title {
  font-family: 'Playfair Display', serif;
  font-size: 1.1rem;
  color: var(--dark);
  margin-bottom: 10px;
  font-weight: 700;
}
.why-desc {
  font-size: .9rem;
  color: var(--muted);
  line-height: 1.65;
}

/* ══ FEATURES ══ */
.features-grid {
  display:grid;
  grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
  gap:24px;
  max-width:1100px;
  margin:0 auto;
}
.feature-card {
  background: linear-gradient(135deg, #fff, var(--ivory));
  border-radius:20px;
  padding:30px;
  border:1px solid rgba(193,18,31,0.08);
  box-shadow:0 4px 16px rgba(0,0,0,0.04);
}
.feature-icon { font-size:2rem; margin-bottom:14px; }
.feature-title { font-weight:500; font-size:1.05rem; margin-bottom:8px; color: var(--dark); }
.feature-desc { font-size:.9rem; color: var(--muted); line-height:1.6; }

/* ══ FAQ ══ */
.faq-wrap { max-width:720px; margin:0 auto; }
.faq-item {
  border-bottom:1px solid rgba(0,0,0,0.08);
  padding:22px 0;
  cursor:pointer;
}
.faq-q {
  display:flex;
  justify-content:space-between;
  align-items:center;
  font-weight:500;
  font-size:1rem;
  color: var(--dark);
  gap:16px;
}
.faq-arrow { transition: transform .3s; color: var(--rose); font-size:1.2rem; flex-shrink:0; }
.faq-item.open .faq-arrow { transform: rotate(180deg); }
.faq-a {
  max-height:0;
  overflow:hidden;
  transition: max-height .4s ease, padding .3s;
  font-size:.92rem;
  color: var(--muted);
  line-height:1.7;
}
.faq-item.open .faq-a { max-height:200px; padding-top:14px; }

/* ══ CTA SECTION ══ */
.cta-section {
  background: linear-gradient(135deg, var(--crimson), #8b0000);
  padding:40px 5%;
  text-align:center;
  color:#fff;
  margin-bottom:48px;
}
.cta-section h2 { font-family:'Playfair Display', serif; font-size:1.8rem; margin-bottom:10px; }
.cta-section p { opacity:.8; max-width:480px; margin:0 auto 20px; line-height:1.6; font-size:.95rem; }
.cta-btn {
  display:inline-block;
  background:#fff;
  color: var(--crimson);
  padding:14px 36px;
  border-radius:40px;
  font-weight:500;
  text-decoration:none;
  font-size:1rem;
  transition: transform .2s, box-shadow .2s;
  box-shadow: 0 8px 24px rgba(0,0,0,0.2);
}
.cta-btn:hover { transform: translateY(-2px); box-shadow: 0 12px 36px rgba(0,0,0,0.3); }

/* ══ FOOTER ══ */
footer {
  background: var(--dark);
  color: rgba(255,255,255,0.6);
  padding:50px 5% 24px;
}
.footer-grid {
  display:grid;
  grid-template-columns: 2fr 1fr 1fr 1fr;
  gap:48px;
  margin-bottom:36px;
}
.footer-brand .logo { font-size:1.5rem; display:block; margin-bottom:14px; }
.footer-brand p { font-size:.88rem; line-height:1.7; max-width:260px; }
.footer-col h4 { color:#fff; font-weight:500; margin-bottom:16px; font-size:.9rem; letter-spacing:.5px; }
.footer-col a { display:block; color:rgba(255,255,255,0.55); text-decoration:none; font-size:.85rem; margin-bottom:10px; transition: color .2s; }
.footer-col a:hover { color: var(--blush); }
.footer-bottom {
  border-top:1px solid rgba(255,255,255,0.08);
  padding-top:24px;
  display:flex;
  justify-content:space-between;
  align-items:center;
  flex-wrap:wrap;
  gap:12px;
  font-size:.82rem;
}
.footer-bottom a { color:rgba(255,255,255,0.5); text-decoration:none; }
.footer-bottom a:hover { color: var(--blush); }

/* ══ COMPATIBILITY METER ══ */
.meter-wrap { margin-top:24px; }
.meter-label { font-size:.82rem; color: var(--muted); margin-bottom:6px; text-align:left; }
.meter-bar {
  background:#f0e4e6;
  border-radius:30px;
  height:10px;
  overflow:hidden;
}
.meter-fill {
  height:100%;
  border-radius:30px;
  background: linear-gradient(90deg, var(--crimson), var(--blush));
  transition: width 1s ease;
  width:0%;
}

/* ══ SHARE BUTTONS ══ */
.share-btns { display:flex; gap:10px; justify-content:center; margin-top:18px; flex-wrap:wrap; }
.share-btn {
  padding:8px 16px;
  border-radius:30px;
  border:none;
  cursor:pointer;
  font-family:'DM Sans', sans-serif;
  font-size:.8rem;
  font-weight:500;
  transition: transform .2s;
}
.share-btn:hover { transform: scale(1.05); }
.share-wa { background:#25d366; color:#fff; }
.share-copy { background: var(--ivory); color: var(--dark); border:1px solid #e0d0d3; }

/* ══ MOBILE MENU ══ */
.mobile-menu-btn {
  display:none; width:40px; height:40px; border:none; background:transparent;
  color:#fff; font-size:1.5rem; cursor:pointer; flex-direction:column;
  justify-content:center; align-items:center; gap:5px; padding:0;
}
.mobile-menu-btn span {
  display:block; width:24px; height:2px; background:#fff;
  transition:all .3s; border-radius:2px;
}
.mobile-menu-btn.active span:nth-child(1) { transform:rotate(45deg) translate(7px,7px); }
.mobile-menu-btn.active span:nth-child(2) { opacity:0; }
.mobile-menu-btn.active span:nth-child(3) { transform:rotate(-45deg) translate(7px,-7px); }

.mobile-nav {
  display:none; position:fixed; top:64px; left:0; right:0;
  background:var(--dark); z-index:99; padding:20px 5%;
  box-shadow:0 4px 20px rgba(0,0,0,0.3); max-height:0;
  overflow:hidden; transition:max-height .3s ease, padding .3s;
}
.mobile-nav.open {
  display:block; max-height:500px; padding:20px 5%;
}
.mobile-nav a {
  display:block; color:rgba(255,255,255,0.8); text-decoration:none;
  padding:14px 0; border-bottom:1px solid rgba(255,255,255,0.1);
  font-size:.95rem; transition:color .2s;
}
.mobile-nav a:last-child { border-bottom:none; }
.mobile-nav a:hover, .mobile-nav a.active { color:var(--blush); }
.mobile-nav .nav-cta {
  margin-top:12px; text-align:center; display:block;
  background:var(--rose); color:#fff; padding:12px 20px;
  border-radius:30px; font-weight:500;
}

/* ══ RESPONSIVE ══ */
/* Large tablets and small desktops */
@media(max-width:1024px){
  .calc-card { max-width:90%; padding:40px 35px; }
  .flames-grid { grid-template-columns:repeat(auto-fit, minmax(250px, 1fr)); gap:20px; }
  .why-grid { grid-template-columns:repeat(auto-fit, minmax(250px, 1fr)); }
  .features-grid { grid-template-columns:repeat(auto-fit, minmax(240px, 1fr)); }
  .steps-grid { grid-template-columns:repeat(auto-fit, minmax(180px, 1fr)); gap:24px; }
  section { padding:50px 4%; }
}

/* Tablets */
@media(max-width:768px){
  header { height:64px; padding:0 4%; }
  .logo { font-size:1.5rem; }
  nav { display:none; }
  .mobile-menu-btn { display:flex; }
  .mobile-nav { top:64px; }
  
  .hero { padding:50px 4% 35px; }
  .hero h1 { font-size:clamp(2rem, 5vw, 3.5rem); margin-bottom:16px; }
  .hero p { font-size:1rem; margin-bottom:28px; }
  
  .calc-card { padding:32px 24px; margin-bottom:60px; max-width:95%; }
  .calc-card h2 { font-size:1.4rem; margin-bottom:24px; }
  .input-row { grid-template-columns:1fr; gap:12px; }
  .name-input { padding:13px 16px; font-size:.95rem; }
  .btn-calc { padding:15px; font-size:1rem; }
  .btn-reset { padding:11px; }
  
  .result-box { padding:28px 20px; margin-top:24px; }
  .result-emoji { font-size:3rem; }
  .result-word { font-size:2rem; }
  .result-desc { font-size:.9rem; }
  
  section { padding:45px 4%; }
  .section-title { font-size:clamp(1.6rem, 4vw, 2.4rem); }
  .section-sub { font-size:.95rem; }
  
  .flames-grid { grid-template-columns:1fr; gap:18px; }
  .why-grid { grid-template-columns:1fr; gap:20px; }
  .features-grid { grid-template-columns:1fr; gap:18px; }
  .steps-grid { grid-template-columns:1fr; gap:20px; }
  .step-num { width:50px; height:50px; font-size:1.3rem; }
  
  .footer-grid { grid-template-columns:1fr 1fr; gap:32px; }
  .footer-bottom { flex-direction:column; text-align:center; gap:8px; }
  
  .history-panel { padding:20px 22px; margin-bottom:40px; }
  .challenge-banner { padding:24px 20px; }
  .challenge-banner h3 { font-size:1.1rem; }
  .challenge-banner p { font-size:.85rem; }
  .challenge-invite-btns { gap:8px; }
  .ch-btn { padding:9px 16px; font-size:.82rem; }
  .challenge-link-row { padding:9px 12px; }
  
  .modal-box { max-width:90%; margin:20px; }
  .modal-top { padding:24px 22px 20px; }
  .modal-body { padding:20px 22px; }
  .modal-btns { flex-direction:column; }
  .modal-send, .modal-cancel { width:100%; }
  
  .pq-box { max-width:90%; }
  .pq-header { padding:26px 22px 22px; }
  .pq-header h2 { font-size:1.3rem; }
  .pq-body { padding:20px 22px 24px; }
  .pq-question { font-size:1.05rem; }
  .pq-opt { padding:12px 14px; font-size:.88rem; }
  
  .share-btns { gap:8px; }
  .share-btn { padding:7px 14px; font-size:.78rem; }
  
  .cta-section { padding:35px 4%; }
  .cta-section h2 { font-size:1.6rem; }
  .cta-btn { padding:13px 32px; font-size:.95rem; }
}

/* Mobile phones */
@media(max-width:480px){
  header { height:60px; padding:0 3%; }
  .logo { font-size:1.3rem; }
  .mobile-nav { top:60px; }
  
  .hero { padding:40px 3% 30px; }
  .hero-tag { font-size:.75rem; padding:4px 14px; margin-bottom:16px; }
  .hero h1 { font-size:clamp(1.8rem, 6vw, 2.8rem); line-height:1.2; margin-bottom:14px; }
  .hero p { font-size:.95rem; margin-bottom:24px; }
  
  .calc-card { padding:24px 18px; margin-bottom:50px; border-radius:20px; }
  .calc-card h2 { font-size:1.25rem; margin-bottom:20px; }
  .input-group label { font-size:.78rem; }
  .name-input { padding:12px 14px; font-size:.9rem; }
  .btn-calc { padding:14px; font-size:.98rem; }
  .btn-reset { padding:10px; font-size:.88rem; }
  .heart-divider { font-size:1.2rem; margin-bottom:16px; }
  
  .mode-tabs { margin-bottom:18px; }
  .mode-tab { padding:9px 6px; font-size:.85rem; }
  
  .result-box { padding:24px 18px; margin-top:20px; border-radius:16px; }
  .result-emoji { font-size:2.5rem; margin-bottom:10px; }
  .result-label { font-size:.75rem; }
  .result-word { font-size:1.8rem; }
  .result-desc { font-size:.88rem; }
  .result-steps { padding:14px; font-size:.82rem; }
  .letter-viz { gap:4px; }
  .l-chip { width:28px; height:28px; font-size:.78rem; }
  
  section { padding:40px 3%; }
  .section-tag { font-size:.7rem; padding:4px 12px; }
  .section-title { font-size:clamp(1.4rem, 5vw, 2rem); margin-bottom:12px; }
  .section-sub { font-size:.9rem; margin-bottom:28px; }
  
  .flames-card { padding:24px 20px; }
  .flames-icon { font-size:1.8rem; }
  .flames-letter { font-size:1.2rem; }
  .flames-word { font-size:.8rem; }
  .flames-desc { font-size:.85rem; }
  
  .why-card { padding:26px 22px; }
  .why-icon-wrap { width:56px; height:56px; font-size:2rem; }
  .why-title { font-size:1rem; }
  .why-desc { font-size:.88rem; }
  
  .feature-card { padding:24px 20px; }
  .feature-icon { font-size:1.8rem; }
  .feature-title { font-size:1rem; }
  .feature-desc { font-size:.88rem; }
  
  .step-num { width:44px; height:44px; font-size:1.2rem; margin-bottom:14px; }
  .step-title { font-size:.95rem; }
  .step-desc { font-size:.85rem; }
  
  .faq-wrap { max-width:100%; }
  .faq-item { padding:18px 0; }
  .faq-q { font-size:.95rem; }
  .faq-a { font-size:.88rem; }
  
  .footer-grid { grid-template-columns:1fr; gap:24px; }
  .footer-brand p { max-width:100%; }
  .footer-bottom { font-size:.8rem; }
  .footer-bottom > div { flex-direction:column; gap:8px; }
  
  .history-panel { padding:18px 16px; }
  .history-panel h3 { font-size:1rem; }
  .history-item { padding:10px 12px; font-size:.85rem; }
  .hist-emoji { font-size:1.2rem; }
  
  .challenge-banner { padding:20px 16px; border-radius:16px; }
  .challenge-banner::before { font-size:80px; right:-10px; }
  .challenge-banner h3 { font-size:1rem; }
  .challenge-banner p { font-size:.82rem; margin-bottom:16px; }
  .challenge-invite-btns { flex-direction:column; gap:8px; }
  .ch-btn { width:100%; justify-content:center; padding:11px 16px; }
  .challenge-link-row { flex-direction:column; gap:8px; padding:10px 12px; }
  .challenge-link-row input { font-size:.8rem; }
  .copy-link-btn { width:100%; padding:9px; }
  
  .modal-overlay { padding:10px; }
  .modal-box { max-width:100%; border-radius:20px; }
  .modal-top { padding:20px 18px 18px; }
  .modal-top .m-icon { font-size:2.5rem; }
  .modal-top h2 { font-size:1.3rem; }
  .modal-top p { font-size:.85rem; }
  .modal-body { padding:18px 20px; }
  .modal-input { padding:12px 14px; font-size:.9rem; }
  .modal-btns { flex-direction:column; gap:8px; }
  .modal-send, .modal-cancel { width:100%; padding:12px; }
  .modal-quick-btns { flex-direction:column; }
  .modal-quick-btn { width:100%; padding:11px; }
  
  .pq-overlay { padding:10px; }
  .pq-box { max-width:100%; border-radius:20px; }
  .pq-header { padding:22px 18px 20px; }
  .pq-header h2 { font-size:1.2rem; }
  .pq-header p { font-size:.82rem; }
  .pq-progress-wrap { padding:16px 18px 0; }
  .pq-body { padding:18px 20px 22px; }
  .pq-question { font-size:1rem; min-height:auto; }
  .pq-opt { padding:11px 12px; font-size:.85rem; gap:10px; }
  .pq-opt-icon { font-size:1.2rem; }
  .pq-result-emoji { font-size:3.5rem; }
  .pq-result-type { font-size:1.6rem; }
  .pq-result-desc { font-size:.85rem; }
  .pq-actions { flex-direction:column; }
  .pq-action-btn { width:100%; padding:12px; }
  
  .quiz-trigger-btn { padding:12px; font-size:.88rem; }
  
  .share-btns { flex-direction:column; }
  .share-btn { width:100%; padding:11px; font-size:.85rem; }
  
  .cta-section { padding:30px 3%; }
  .cta-section h2 { font-size:1.4rem; }
  .cta-section p { font-size:.9rem; }
  .cta-btn { padding:12px 28px; font-size:.9rem; }
  
  .toast { bottom:20px; padding:10px 20px; font-size:.85rem; }
  
  .fortune-box { padding:14px 16px; font-size:.85rem; }
  .meter-wrap { margin-top:20px; }
  .steps-toggle-btn { padding:11px 14px; font-size:.82rem; }
}

/* Extra small phones */
@media(max-width:360px){
  .logo { font-size:1.2rem; }
  .hero h1 { font-size:1.6rem; }
  .calc-card { padding:20px 16px; }
  .result-word { font-size:1.6rem; }
  .section-title { font-size:1.3rem; }
}

/* ══ SHARE COPY TOAST ══ */
.toast {
  position:fixed;
  bottom:32px;
  left:50%;
  transform:translateX(-50%) translateY(80px);
  background: var(--dark);
  color:#fff;
  padding:12px 24px;
  border-radius:30px;
  font-size:.88rem;
  z-index:999;
  transition: transform .4s ease;
  pointer-events:none;
}
.toast.show { transform:translateX(-50%) translateY(0); }

/* ══ TOOL UPGRADES ONLY ══ */

/* Mode toggle tabs */
.mode-tabs {
  display:flex; gap:0; background:#f5eff1; border-radius:12px; padding:4px; margin-bottom:22px;
}
.mode-tab {
  flex:1; padding:10px 8px; border:none; background:transparent;
  border-radius:9px; font-family:'DM Sans',sans-serif; font-size:.88rem;
  color:var(--muted); cursor:pointer; transition:all .25s; font-weight:400;
}
.mode-tab.active {
  background:#fff; color:var(--crimson); font-weight:500;
  box-shadow:0 2px 10px rgba(0,0,0,0.08);
}

/* Group mode names */
.group-name-row { display:flex; gap:8px; align-items:center; margin-bottom:10px; }
.group-name-row .name-input { flex:1; }
.remove-btn {
  width:36px; height:48px; border:none; background:#fde8ea; color:var(--rose);
  border-radius:10px; cursor:pointer; font-size:1.1rem; flex-shrink:0;
  transition:background .2s;
}
.remove-btn:hover { background:#f9c9ce; }
.add-name-btn {
  width:100%; padding:10px; border:2px dashed #ead9dc; background:transparent;
  border-radius:12px; font-family:'DM Sans',sans-serif; font-size:.88rem;
  color:var(--muted); cursor:pointer; transition:all .2s; margin-bottom:20px;
}
.add-name-btn:hover { border-color:var(--blush); color:var(--rose); }

/* Loading state */
.btn-calc.loading { opacity:.8; pointer-events:none; }
@keyframes spin { to { transform:rotate(360deg); } }
.spin-icon { display:inline-block; animation:spin 1s linear infinite; }

/* Letter chips in result */
.letter-viz { display:flex; flex-wrap:wrap; gap:5px; margin:8px 0 12px; }
.l-chip {
  display:inline-flex; width:30px; height:30px; align-items:center; justify-content:center;
  border-radius:7px; font-size:.82rem; font-weight:500; background:#f0e8ea; color:var(--dark);
  transition:all .2s;
}
.l-chip.out {
  background:#ffe0e3; color:#d88; text-decoration:line-through; opacity:.55;
}

/* Meter pct label */
.meter-row { display:flex; justify-content:space-between; align-items:center; margin-bottom:6px; }
.meter-pct { font-size:.88rem; font-weight:500; color:var(--dark); }

/* Fortune message */
.fortune-box {
  margin-top:16px; padding:16px 18px;
  background:linear-gradient(135deg,var(--dark),var(--mid));
  border-radius:14px; color:#fff; font-size:.88rem; line-height:1.65;
  font-style:italic;
}
.fortune-box strong { font-style:normal; color:var(--blush); display:block; margin-bottom:4px; font-size:.75rem; letter-spacing:1px; text-transform:uppercase; }

/* History panel */
.history-panel {
  max-width:680px; margin:0 auto 60px;
  background:#fff; border-radius:20px;
  box-shadow:0 8px 30px rgba(193,18,31,0.07);
  padding:24px 28px;
}
.history-panel h3 {
  font-family:'Playfair Display',serif; font-size:1.1rem; color:var(--dark);
  margin-bottom:16px;
}
.history-list { display:flex; flex-direction:column; gap:8px; }
.history-item {
  display:flex; align-items:center; gap:12px; padding:11px 14px;
  background:var(--ivory); border-radius:12px; cursor:pointer;
  transition:background .2s; font-size:.88rem; border:1px solid transparent;
}
.history-item:hover { background:#fde8ea; border-color:rgba(193,18,31,0.1); }
.hist-emoji { font-size:1.4rem; flex-shrink:0; }
.hist-names { flex:1; }
.hist-names strong { display:block; font-weight:500; color:var(--dark); }
.hist-names span { font-size:.78rem; color:var(--muted); }
.hist-badge { font-weight:600; font-size:.8rem; letter-spacing:.3px; }
.clear-hist-btn {
  width:100%; margin-top:12px; padding:9px; border:2px dashed #ead9dc;
  background:transparent; border-radius:10px; font-family:'DM Sans',sans-serif;
  font-size:.82rem; color:var(--muted); cursor:pointer; transition:all .2s;
}
.clear-hist-btn:hover { border-color:var(--rose); color:var(--rose); }

/* Confetti canvas overlay */
.confetti-canvas {
  position:absolute; inset:0; pointer-events:none; border-radius:20px; z-index:0;
}
.result-box { position:relative; }
.result-box > *:not(.confetti-canvas) { position:relative; z-index:1; }

/* Twitter share button */
.share-tw { background:#1da1f2; color:#fff; }
.share-dl { background:#7c3aed; color:#fff; }

/* Steps accordion toggle */
.steps-toggle-btn {
  width:100%; padding:12px 16px; border:1px solid rgba(0,0,0,0.07);
  background:#fafafa; border-radius:10px; text-align:left;
  font-family:'DM Sans',sans-serif; font-size:.85rem; color:var(--muted);
  cursor:pointer; display:flex; justify-content:space-between; align-items:center;
  transition:background .2s; margin-top:16px;
}
.steps-toggle-btn:hover { background:#f5eff2; }
.steps-toggle-btn .arr { transition:transform .3s; }
.steps-toggle-btn.open .arr { transform:rotate(180deg); }
.steps-collapsible { max-height:0; overflow:hidden; transition:max-height .4s ease; }
.steps-collapsible.open { max-height:400px; }

/* ══ SOCIAL CHALLENGE FEATURE ══ */
.challenge-banner {
  margin-top:20px;
  background: linear-gradient(135deg, #1a0a0d 0%, #3d1a20 100%);
  border-radius:18px; padding:28px 28px 24px;
  text-align:center; position:relative; overflow:hidden;
}
.challenge-banner::before {
  content:'🔥'; position:absolute; font-size:120px;
  right:-20px; top:50%; transform:translateY(-50%);
  opacity:.06; pointer-events:none;
}
.challenge-banner h3 { font-family:'Playfair Display',serif; font-size:1.25rem; color:#fff; margin-bottom:6px; }
.challenge-banner p { font-size:.88rem; color:rgba(255,255,255,0.55); margin-bottom:20px; line-height:1.6; }
.challenge-invite-btns { display:flex; flex-wrap:wrap; gap:10px; justify-content:center; margin-bottom:20px; }
.ch-btn {
  display:flex; align-items:center; gap:7px;
  padding:10px 18px; border-radius:30px; border:none;
  font-family:'DM Sans',sans-serif; font-size:.85rem; font-weight:500;
  cursor:pointer; transition:transform .2s, box-shadow .2s;
}
.ch-btn:hover { transform:translateY(-2px); }
.ch-wa  { background:#25d366; color:#fff; box-shadow:0 4px 16px rgba(37,211,102,0.35); }
.ch-tw  { background:#1da1f2; color:#fff; box-shadow:0 4px 16px rgba(29,161,242,0.3); }
.ch-tg  { background:#229ed9; color:#fff; box-shadow:0 4px 16px rgba(34,158,217,0.3); }
.ch-link{ background:rgba(255,255,255,0.12); color:#fff; border:1px solid rgba(255,255,255,0.2); }
.ch-link:hover { background:rgba(255,255,255,0.2); }
.challenge-link-row {
  display:flex; gap:8px; align-items:center;
  background:rgba(255,255,255,0.08); border:1px solid rgba(255,255,255,0.15);
  border-radius:12px; padding:10px 14px;
  max-width:520px; margin:0 auto;
}
.challenge-link-row input {
  flex:1; background:transparent; border:none; outline:none;
  color:rgba(255,255,255,0.7); font-family:'DM Sans',sans-serif;
  font-size:.82rem; overflow:hidden; text-overflow:ellipsis; white-space:nowrap;
}
.copy-link-btn {
  background:var(--rose); color:#fff; border:none;
  padding:7px 14px; border-radius:8px; font-family:'DM Sans',sans-serif;
  font-size:.78rem; font-weight:500; cursor:pointer; white-space:nowrap;
  transition:background .2s; flex-shrink:0;
}
.copy-link-btn:hover { background:var(--blush); }
.challenge-scoreboard {
  margin-top:20px; padding-top:18px;
  border-top:1px solid rgba(255,255,255,0.1); text-align:left;
}
.challenge-scoreboard h4 {
  font-size:.75rem; letter-spacing:2px; text-transform:uppercase;
  color:rgba(255,255,255,0.4); margin-bottom:12px;
}
.score-list { display:flex; flex-direction:column; gap:8px; }
.score-item { display:flex; align-items:center; gap:10px; font-size:.85rem; color:rgba(255,255,255,0.75); }
.score-rank {
  width:24px; height:24px; border-radius:50%;
  background:rgba(255,255,255,0.1); display:grid; place-items:center;
  font-size:.72rem; color:rgba(255,255,255,0.5); flex-shrink:0;
}
.score-rank.gold   { background:linear-gradient(135deg,#f5c518,#c9a84c); color:#fff; }
.score-rank.silver { background:linear-gradient(135deg,#b0b0b0,#888); color:#fff; }
.score-rank.bronze { background:linear-gradient(135deg,#cd7f32,#a0522d); color:#fff; }
.score-names { flex:1; }
.score-badge { font-size:.78rem; font-weight:600; padding:3px 10px; border-radius:20px; background:rgba(255,255,255,0.1); }

/* Challenge Modal */
.modal-overlay {
  display:none; position:fixed; inset:0; z-index:500;
  background:rgba(0,0,0,0.6); backdrop-filter:blur(4px);
  align-items:center; justify-content:center; padding:20px;
}
.modal-overlay.open { display:flex; }
.modal-box {
  background:#fff; border-radius:24px; max-width:480px; width:100%;
  box-shadow:0 30px 80px rgba(0,0,0,0.3);
  animation:modalPop .35s cubic-bezier(0.175,0.885,0.32,1.275); overflow:hidden;
}
@keyframes modalPop { from{opacity:0;transform:scale(.85)} to{opacity:1;transform:scale(1)} }
.modal-top {
  background:linear-gradient(135deg,var(--crimson),var(--mid));
  padding:30px 28px 24px; text-align:center; color:#fff;
}
.modal-top .m-icon { font-size:3rem; display:block; margin-bottom:10px; }
.modal-top h2 { font-family:'Playfair Display',serif; font-size:1.5rem; margin-bottom:6px; }
.modal-top p { font-size:.88rem; opacity:.75; line-height:1.6; }
.modal-body { padding:24px 28px; }
.modal-input-group { margin-bottom:16px; }
.modal-input-group label {
  display:block; font-size:.78rem; font-weight:500; letter-spacing:.5px;
  text-transform:uppercase; color:var(--muted); margin-bottom:7px;
}
.modal-input {
  width:100%; padding:13px 16px; border:2px solid #ead9dc; border-radius:12px;
  font-family:'DM Sans',sans-serif; font-size:.95rem; color:var(--dark);
  background:var(--ivory); outline:none; transition:border-color .2s;
}
.modal-input:focus { border-color:var(--blush); background:#fff; }
.modal-btns { display:flex; gap:10px; margin-top:6px; }
.modal-send {
  flex:1; padding:13px;
  background:linear-gradient(135deg,var(--rose),var(--crimson));
  color:#fff; border:none; border-radius:12px;
  font-family:'DM Sans',sans-serif; font-size:.95rem; font-weight:500;
  cursor:pointer; transition:transform .2s, box-shadow .2s;
  box-shadow:0 6px 20px rgba(193,18,31,0.3);
}
.modal-send:hover { transform:translateY(-2px); box-shadow:0 10px 28px rgba(193,18,31,0.45); }
.modal-cancel {
  padding:13px 20px; background:transparent; border:2px solid #ead9dc;
  border-radius:12px; font-family:'DM Sans',sans-serif;
  font-size:.9rem; color:var(--muted); cursor:pointer; transition:all .2s;
}
.modal-cancel:hover { border-color:var(--blush); color:var(--rose); }
.modal-or { text-align:center; font-size:.8rem; color:var(--muted); margin:14px 0; }
.modal-quick-btns { display:flex; gap:8px; }
.modal-quick-btn {
  flex:1; padding:10px 8px; border:none; border-radius:10px;
  font-family:'DM Sans',sans-serif; font-size:.8rem; font-weight:500;
  cursor:pointer; transition:transform .2s;
  display:flex; align-items:center; justify-content:center; gap:6px;
}
.modal-quick-btn:hover { transform:scale(1.04); }
.mqb-wa { background:#25d366; color:#fff; }
.mqb-tw { background:#1da1f2; color:#fff; }
.mqb-tg { background:#229ed9; color:#fff; }

/* ══ PERSONALITY QUIZ MODAL ══ */
.pq-overlay {
  display:none; position:fixed; inset:0; z-index:600;
  background:rgba(10,0,4,0.72); backdrop-filter:blur(6px);
  align-items:center; justify-content:center; padding:16px;
}
.pq-overlay.open { display:flex; }

.pq-box {
  background:#fff; border-radius:28px; max-width:540px; width:100%;
  box-shadow:0 40px 100px rgba(0,0,0,0.35);
  animation:pqPop .4s cubic-bezier(0.175,0.885,0.32,1.275);
  overflow:hidden; position:relative;
}
@keyframes pqPop { from{opacity:0;transform:scale(.8) translateY(30px)} to{opacity:1;transform:scale(1) translateY(0)} }

/* Header */
.pq-header {
  background:linear-gradient(135deg, var(--crimson), #7c0014);
  padding:32px 28px 26px; text-align:center; color:#fff; position:relative;
}
.pq-header::after {
  content:''; position:absolute; bottom:-1px; left:0; right:0; height:30px;
  background:#fff; clip-path:ellipse(55% 100% at 50% 100%);
}
.pq-badge {
  display:inline-block; background:rgba(255,255,255,0.18);
  border:1px solid rgba(255,255,255,0.3); color:#fff;
  font-size:.7rem; letter-spacing:2.5px; text-transform:uppercase;
  padding:4px 14px; border-radius:30px; margin-bottom:14px;
}
.pq-header h2 { font-family:'Playfair Display',serif; font-size:1.55rem; margin-bottom:6px; }
.pq-header p { font-size:.85rem; opacity:.75; line-height:1.5; }

/* Progress bar */
.pq-progress-wrap { padding:20px 28px 0; }
.pq-progress-row { display:flex; justify-content:space-between; align-items:center; margin-bottom:8px; }
.pq-q-label { font-size:.75rem; color:var(--muted); font-weight:500; letter-spacing:.5px; text-transform:uppercase; }
.pq-q-count { font-size:.75rem; color:var(--muted); }
.pq-prog-bar { height:5px; background:#f0e8ea; border-radius:5px; overflow:hidden; }
.pq-prog-fill { height:100%; border-radius:5px; background:linear-gradient(90deg,var(--crimson),var(--blush)); transition:width .5s ease; }

/* Dots */
.pq-dots { display:flex; gap:6px; justify-content:center; margin:14px 0 0; }
.pq-dot { width:8px; height:8px; border-radius:50%; background:#ead9dc; transition:all .3s; }
.pq-dot.active { background:var(--crimson); width:22px; border-radius:4px; }
.pq-dot.done { background:var(--blush); }

/* Body */
.pq-body { padding:22px 28px 28px; }
.pq-question {
  font-family:'Playfair Display',serif; font-size:1.15rem; color:var(--dark);
  margin-bottom:20px; line-height:1.5; text-align:center; min-height:52px;
  animation:pqFadeQ .35s ease;
}
@keyframes pqFadeQ { from{opacity:0;transform:translateY(8px)} to{opacity:1;transform:translateY(0)} }

.pq-options { display:flex; flex-direction:column; gap:10px; }
.pq-opt {
  display:flex; align-items:center; gap:12px;
  padding:13px 16px; border:2px solid #ead9dc; border-radius:14px;
  background:var(--ivory); cursor:pointer; font-size:.9rem; color:var(--dark);
  font-family:'DM Sans',sans-serif; transition:all .2s; text-align:left;
  animation:pqFadeQ .35s ease;
}
.pq-opt:hover { border-color:var(--blush); background:rgba(255,107,129,0.05); transform:translateX(4px); }
.pq-opt.selected { border-color:var(--crimson); background:rgba(193,18,31,0.05); color:var(--crimson); }
.pq-opt-icon { font-size:1.3rem; flex-shrink:0; }
.pq-opt-text { flex:1; }

/* Result screen */
.pq-result { text-align:center; animation:pqFadeQ .5s ease; }
.pq-result-emoji { font-size:4.5rem; display:block; margin-bottom:12px; animation:pqPop .5s ease .1s both; }
.pq-result-tag { font-size:.72rem; letter-spacing:3px; text-transform:uppercase; color:var(--muted); margin-bottom:8px; }
.pq-result-type { font-family:'Playfair Display',serif; font-size:2rem; font-weight:700; margin-bottom:10px; }
.pq-result-desc { font-size:.9rem; color:var(--muted); line-height:1.7; margin-bottom:20px; max-width:380px; margin-left:auto; margin-right:auto; }

/* Score rings */
.pq-score-rings { display:flex; gap:10px; justify-content:center; flex-wrap:wrap; margin-bottom:22px; }
.pq-ring {
  display:flex; flex-direction:column; align-items:center; gap:4px;
  padding:10px 14px; border-radius:14px; background:var(--ivory);
  border:2px solid #ede3e6; min-width:70px;
}
.pq-ring-label { font-size:.68rem; color:var(--muted); letter-spacing:.5px; text-transform:uppercase; }
.pq-ring-val { font-family:'Playfair Display',serif; font-size:1.3rem; font-weight:700; }

/* Action buttons */
.pq-actions { display:flex; gap:10px; flex-wrap:wrap; justify-content:center; }
.pq-action-btn {
  padding:11px 22px; border-radius:30px; border:none;
  font-family:'DM Sans',sans-serif; font-size:.88rem; font-weight:500;
  cursor:pointer; transition:transform .2s, box-shadow .2s;
}
.pq-action-btn:hover { transform:translateY(-2px); }
.pq-retry { background:linear-gradient(135deg,var(--rose),var(--crimson)); color:#fff; box-shadow:0 4px 18px rgba(193,18,31,0.3); }
.pq-close-btn { background:var(--ivory); color:var(--dark); border:2px solid #ead9dc; }
.pq-share-btn { background:#25d366; color:#fff; box-shadow:0 4px 14px rgba(37,211,102,0.3); }

/* Trigger button inside result box */
.quiz-trigger-btn {
  width:100%; margin-top:14px; padding:13px;
  background:linear-gradient(135deg, #3d1a20, #1a0a0d);
  color:#fff; border:none; border-radius:14px;
  font-family:'DM Sans',sans-serif; font-size:.92rem; font-weight:500;
  cursor:pointer; display:flex; align-items:center; justify-content:center; gap:8px;
  transition:transform .2s, box-shadow .2s;
  box-shadow:0 6px 22px rgba(0,0,0,0.2);
}
.quiz-trigger-btn:hover { transform:translateY(-2px); box-shadow:0 10px 30px rgba(0,0,0,0.28); }
.quiz-trigger-pulse { animation:pulse 1.8s ease-in-out infinite; }

/* ============================================
   TOOL-SPECIFIC STYLES (moved from inline)
   ============================================ */

/* ===== Love Calculator ===== */
.love-opts-row { display:flex; flex-wrap:wrap; gap:14px 20px; justify-content:center; align-items:center; margin:0 0 18px; font-size:.86rem; color:var(--muted); }
.love-mode-toggle { display:inline-flex; border-radius:999px; overflow:hidden; border:1px solid rgba(0,0,0,.08); background:#fff; }
.love-mode-toggle button { border:none; background:transparent; padding:9px 18px; font-family:inherit; cursor:pointer; font-size:.84rem; color:var(--muted); transition:background .2s,color .2s; }
.love-mode-toggle button.active { background:var(--rose); color:#fff; }
.love-reduce-wrap { display:inline-flex; align-items:center; gap:8px; cursor:pointer; user-select:none; }
.love-reduce-wrap input { width:16px; height:16px; accent-color:var(--rose); cursor:pointer; }
.love-radar { margin:18px auto 6px; text-align:left; max-width:420px; }
.love-radar-title { font-size:.72rem; letter-spacing:.12em; text-transform:uppercase; color:var(--muted); margin-bottom:10px; text-align:center; }
.love-radar-row { display:grid; grid-template-columns:78px 1fr; align-items:center; gap:10px; margin-bottom:9px; font-size:.82rem; color:var(--dark); }
.love-radar-row .meter-bar { height:9px; margin:0; }
.love-radar-row .meter-fill { background:linear-gradient(90deg,#c1121f,#ec4899); }
.love-lucky-row { display:flex; flex-wrap:wrap; gap:14px 22px; justify-content:center; margin:14px 0 4px; font-size:.88rem; color:var(--muted); }
.love-lucky-row strong { color:var(--dark); font-weight:500; }
.love-link-row { display:flex; gap:8px; align-items:center; margin-top:14px; padding:11px 14px; background:var(--ivory); border-radius:12px; border:1px solid rgba(0,0,0,.06); }
.love-link-row input { flex:1; border:none; background:transparent; font-size:.78rem; color:var(--muted); min-width:0; font-family:inherit; }
.share-dl { background:#7c3aed !important; color:#fff !important; }
.share-link { background:#475569 !important; color:#fff !important; }
@media (max-width:520px) {
  .love-opts-row { flex-direction:column; align-items:stretch; text-align:center; }
  .love-mode-toggle { justify-content:center; }
}

/* ===== Red Flag Checker ===== */
.rf-progress { width:100%; height:8px; background:rgba(0,0,0,.06); border-radius:99px; margin:0 0 22px; overflow:hidden; }
.rf-progress-fill { height:100%; width:0%; background:linear-gradient(90deg,var(--crimson),var(--rose)); border-radius:99px; transition:width .4s ease; }
.rf-q-num { font-size:.78rem; color:var(--muted); letter-spacing:.1em; text-transform:uppercase; margin-bottom:8px; text-align:center; }
.rf-question { font-family:'Playfair Display',serif; font-size:1.25rem; color:var(--dark); text-align:center; line-height:1.55; margin-bottom:22px; min-height:60px; }
.rf-options { display:flex; flex-direction:column; gap:10px; max-width:520px; margin:0 auto; }
.rf-opt {
  padding:14px 20px; border-radius:14px; border:2px solid rgba(0,0,0,.06); background:#fff;
  font-size:.95rem; color:var(--dark); cursor:pointer; transition:all .2s; text-align:left;
  font-family:'DM Sans',sans-serif;
}
.rf-opt:hover { border-color:var(--blush); background:rgba(255,107,129,.06); transform:translateY(-1px); }
.rf-opt.selected { border-color:var(--rose); background:rgba(230,57,70,.08); font-weight:500; }
.rf-nav { display:flex; gap:12px; justify-content:center; margin-top:22px; }
.rf-nav button {
  padding:12px 32px; border-radius:30px; border:none; font-family:inherit; font-size:.92rem;
  font-weight:500; cursor:pointer; transition:all .2s;
}
.rf-btn-next { background:linear-gradient(135deg,var(--crimson),var(--rose)); color:#fff; }
.rf-btn-next:hover { transform:scale(1.04); }
.rf-btn-next:disabled { opacity:.4; cursor:not-allowed; transform:none; }
.rf-btn-back { background:var(--ivory); color:var(--dark); border:1px solid rgba(0,0,0,.08) !important; }
.rf-btn-back:hover { border-color:var(--blush) !important; }
.rf-result-flags { display:flex; justify-content:center; gap:6px; margin:12px 0; flex-wrap:wrap; }
.rf-flag { font-size:2rem; animation:rfPop .4s ease both; }
@keyframes rfPop { 0%{transform:scale(0);opacity:0} 60%{transform:scale(1.3)} 100%{transform:scale(1);opacity:1} }
.rf-verdict { font-family:'Playfair Display',serif; font-size:clamp(1.6rem,4vw,2.4rem); color:var(--dark); margin:10px 0 6px; }
.rf-score-pct { font-size:clamp(2.4rem,6vw,3.4rem); font-weight:800; margin:8px 0; }
.rf-name-input-row { display:flex; gap:12px; justify-content:center; align-items:center; flex-wrap:wrap; margin-bottom:18px; }
.rf-name-input-row input { max-width:220px; }
.rf-who-toggle { display:inline-flex; border-radius:999px; overflow:hidden; border:1px solid rgba(0,0,0,.08); background:#fff; margin-bottom:14px; }
.rf-who-toggle button { border:none; background:transparent; padding:9px 18px; font-family:inherit; cursor:pointer; font-size:.84rem; color:var(--muted); transition:background .2s,color .2s; }
.rf-who-toggle button.active { background:var(--rose); color:#fff; }
@media(max-width:520px){
  .rf-question { font-size:1.1rem; }
  .rf-opt { padding:12px 16px; font-size:.88rem; }
}

/* ===== Love Compatibility Calculator ===== */
.lcc-progress { width:100%; height:8px; background:rgba(0,0,0,.06); border-radius:99px; margin:0 0 22px; overflow:hidden; }
.lcc-progress-fill { height:100%; width:0%; background:linear-gradient(90deg,var(--crimson),var(--rose)); border-radius:99px; transition:width .4s ease; }
.lcc-phase-label { text-align:center; font-size:.82rem; color:var(--rose); font-weight:600; letter-spacing:.1em; text-transform:uppercase; margin-bottom:6px; }
.lcc-q-num { font-size:.78rem; color:var(--muted); letter-spacing:.1em; text-transform:uppercase; margin-bottom:8px; text-align:center; }
.lcc-question { font-family:'Playfair Display',serif; font-size:1.25rem; color:var(--dark); text-align:center; line-height:1.55; margin-bottom:22px; min-height:60px; }
.lcc-options { display:flex; flex-direction:column; gap:10px; max-width:520px; margin:0 auto; }
.lcc-opt {
  padding:14px 20px; border-radius:14px; border:2px solid rgba(0,0,0,.06); background:#fff;
  font-size:.95rem; color:var(--dark); cursor:pointer; transition:all .2s; text-align:left;
  font-family:'DM Sans',sans-serif;
}
.lcc-opt:hover { border-color:var(--blush); background:rgba(255,107,129,.06); transform:translateY(-1px); }
.lcc-opt.selected { border-color:var(--rose); background:rgba(230,57,70,.08); font-weight:500; }
.lcc-nav { display:flex; gap:12px; justify-content:center; margin-top:22px; }
.lcc-nav button {
  padding:12px 32px; border-radius:30px; border:none; font-family:inherit; font-size:.92rem;
  font-weight:500; cursor:pointer; transition:all .2s;
}
.lcc-btn-next { background:linear-gradient(135deg,var(--crimson),var(--rose)); color:#fff; }
.lcc-btn-next:hover { transform:scale(1.04); }
.lcc-btn-next:disabled { opacity:.4; cursor:not-allowed; transform:none; }
.lcc-btn-back { background:var(--ivory); color:var(--dark); border:1px solid rgba(0,0,0,.08) !important; }
.lcc-btn-back:hover { border-color:var(--blush) !important; }
.lcc-score-pct { font-size:clamp(2.4rem,6vw,3.4rem); font-weight:800; margin:8px 0; }
.lcc-verdict { font-family:'Playfair Display',serif; font-size:clamp(1.6rem,4vw,2.4rem); color:var(--dark); margin:10px 0 6px; }
.lcc-heart-burst { display:flex; justify-content:center; gap:6px; margin:12px 0; flex-wrap:wrap; }
.lcc-heart { font-size:2rem; animation:lccPop .4s ease both; }
@keyframes lccPop { 0%{transform:scale(0);opacity:0} 60%{transform:scale(1.3)} 100%{transform:scale(1);opacity:1} }
.lcc-radar { margin:18px auto 6px; text-align:left; max-width:420px; }
.lcc-radar-title { font-size:.72rem; letter-spacing:.12em; text-transform:uppercase; color:var(--muted); margin-bottom:10px; text-align:center; }
.lcc-radar-row { display:grid; grid-template-columns:100px 1fr; align-items:center; gap:10px; margin-bottom:9px; font-size:.82rem; color:var(--dark); }
.lcc-radar-row .meter-bar { height:9px; margin:0; }
.lcc-radar-row .meter-fill { background:linear-gradient(90deg,#c1121f,#ec4899); }
@media(max-width:520px){
  .lcc-question { font-size:1.1rem; }
  .lcc-opt { padding:12px 16px; font-size:.88rem; }
}

/* ===== Couple Name Combiner ===== */
.cnc-results-grid { display:grid; grid-template-columns:1fr; gap:14px; margin:20px auto 0; max-width:520px; }
.cnc-name-card {
  background:linear-gradient(135deg, rgba(193,18,31,0.06), rgba(255,107,129,0.08));
  border:2px solid rgba(193,18,31,0.10);
  border-radius:18px; padding:20px 24px; text-align:center;
  cursor:pointer; transition:all .25s; position:relative;
}
.cnc-name-card:hover { border-color:var(--rose); transform:translateY(-2px); box-shadow:0 8px 24px rgba(193,18,31,0.12); }
.cnc-name-card.selected { border-color:var(--crimson); background:linear-gradient(135deg, rgba(193,18,31,0.10), rgba(255,107,129,0.14)); }
.cnc-name-card.selected::after {
  content:'✓ Selected'; position:absolute; top:10px; right:14px; font-size:.72rem;
  background:var(--crimson); color:#fff; padding:3px 10px; border-radius:20px; font-weight:600;
}
.cnc-ship-name {
  font-family:'Playfair Display',serif; font-size:clamp(1.4rem,4vw,2rem);
  color:var(--dark); font-weight:700; margin-bottom:4px;
}
.cnc-ship-from { font-size:.82rem; color:var(--muted); }
.cnc-ship-from strong { color:var(--rose); font-weight:600; }
.cnc-best-label {
  display:inline-block; background:linear-gradient(135deg,var(--crimson),var(--rose));
  color:#fff; font-size:.7rem; font-weight:700; letter-spacing:.08em; text-transform:uppercase;
  padding:4px 12px; border-radius:20px; margin-bottom:10px;
}
.cnc-selected-wrap { text-align:center; margin:24px 0 8px; }
.cnc-selected-big {
  font-family:'Playfair Display',serif; font-size:clamp(2rem,6vw,3rem);
  color:var(--crimson); font-weight:700; margin:6px 0;
}
.cnc-selected-sub { font-size:.92rem; color:var(--muted); margin-bottom:6px; }
.cnc-heart-row { display:flex; justify-content:center; gap:6px; margin:10px 0; }
.cnc-heart { font-size:1.6rem; animation:cncPop .4s ease both; }
@keyframes cncPop { 0%{transform:scale(0);opacity:0} 60%{transform:scale(1.3)} 100%{transform:scale(1);opacity:1} }
.cnc-tag { display:inline-block; background:var(--ivory); border:1px solid rgba(0,0,0,.06); border-radius:20px; padding:6px 16px; font-size:.82rem; color:var(--muted); margin:4px; }
@media(min-width:520px){
  .cnc-results-grid { grid-template-columns:1fr 1fr 1fr; }
}
.cnc-more-btn {
  display:block; margin:18px auto 0; padding:12px 36px; border-radius:30px; border:2px solid var(--rose);
  background:transparent; color:var(--rose); font-family:inherit; font-size:.92rem; font-weight:600;
  cursor:pointer; transition:all .25s;
}
.cnc-more-btn:hover { background:var(--rose); color:#fff; transform:translateY(-1px); }

/* ===== Hashtag Generator ===== */
.hg-category{margin:20px 0}
.hg-cat-title{font-size:.78rem;text-transform:uppercase;letter-spacing:.12em;color:var(--muted);margin-bottom:10px;padding-left:4px}
.hg-tags{display:flex;flex-wrap:wrap;gap:10px}
.hg-tag{display:inline-flex;align-items:center;gap:6px;padding:10px 18px;border-radius:30px;font-size:.88rem;font-weight:600;cursor:pointer;transition:all .2s;font-family:'DM Sans',sans-serif;border:1.5px solid rgba(193,18,31,0.12);background:rgba(255,255,255,0.85);color:var(--dark)}
.hg-tag:hover{background:linear-gradient(135deg,var(--crimson),var(--rose));color:#fff;border-color:transparent;transform:translateY(-1px);box-shadow:0 3px 12px rgba(193,18,31,0.18)}
.hg-tag.copied{background:#22c55e;color:#fff;border-color:transparent}
.hg-copy-icon{font-size:.7rem;opacity:.5}
.hg-selected-wrap{margin:20px 0;padding:18px 20px;background:linear-gradient(145deg,rgba(193,18,31,0.04),rgba(255,107,129,0.08));border:1.5px solid rgba(193,18,31,0.10);border-radius:18px}
.hg-selected-title{font-size:.72rem;text-transform:uppercase;letter-spacing:.12em;color:var(--muted);margin-bottom:10px;text-align:center}
.hg-selected-tags{font-family:'DM Sans',sans-serif;font-size:.95rem;color:var(--crimson);font-weight:600;line-height:2;text-align:center;word-break:break-word}
.hg-regen-btn{display:inline-block;margin:8px auto;padding:9px 22px;border-radius:30px;border:2px solid rgba(193,18,31,0.15);background:#fff;color:var(--crimson);font-size:.84rem;font-weight:600;cursor:pointer;transition:all .2s;font-family:'DM Sans',sans-serif}
.hg-regen-btn:hover{background:var(--crimson);color:#fff;border-color:transparent}
.share-hg{background:#c1121f !important;color:#fff !important}

/* ===== Friendship Calculator ===== */
.fc-radar { margin:18px auto 6px; text-align:left; max-width:420px; }
.fc-radar-title { font-size:.72rem; letter-spacing:.12em; text-transform:uppercase; color:var(--muted); margin-bottom:10px; text-align:center; }
.fc-radar-row { display:grid; grid-template-columns:90px 1fr; align-items:center; gap:10px; margin-bottom:9px; font-size:.82rem; color:var(--dark); }
.fc-radar-row .meter-bar { height:9px; margin:0; }
.fc-radar-row .meter-fill { background:linear-gradient(90deg,#6366f1,#a78bfa); }
.fc-lucky-row { display:flex; flex-wrap:wrap; gap:14px 22px; justify-content:center; margin:14px 0 4px; font-size:.88rem; color:var(--muted); }
.fc-lucky-row strong { color:var(--dark); font-weight:500; }
.fc-badge {
  display:inline-block; margin:14px auto 6px; padding:8px 24px; border-radius:30px;
  font-size:.88rem; font-weight:700; letter-spacing:.04em;
}
.share-fc { background:#6366f1 !important; color:#fff !important; }

/* ===== Crush Calculator ===== */
.cc-radar { margin:18px auto 6px; text-align:left; max-width:420px; }
.cc-radar-title { font-size:.72rem; letter-spacing:.12em; text-transform:uppercase; color:var(--muted); margin-bottom:10px; text-align:center; }
.cc-radar-row { display:grid; grid-template-columns:90px 1fr; align-items:center; gap:10px; margin-bottom:9px; font-size:.82rem; color:var(--dark); }
.cc-radar-row .meter-bar { height:9px; margin:0; }
.cc-radar-row .meter-fill { background:linear-gradient(90deg,#e11d48,#fb7185); }
.cc-lucky-row { display:flex; flex-wrap:wrap; gap:14px 22px; justify-content:center; margin:14px 0 4px; font-size:.88rem; color:var(--muted); }
.cc-lucky-row strong { color:var(--dark); font-weight:500; }
.cc-verdict-pill {
  display:inline-block; margin:14px auto 6px; padding:8px 24px; border-radius:30px;
  font-size:.88rem; font-weight:700; letter-spacing:.04em;
}
.share-cc { background:#e11d48 !important; color:#fff !important; }

/* ===== Love Counter ===== */
.lc-hero-banner {
  background:linear-gradient(135deg,#c1121f,#e63946,#ff6b81);
  border-radius:22px; padding:28px 20px 24px; text-align:center; margin-bottom:20px;
  position:relative; overflow:hidden;
}
.lc-hero-banner::before {
  content:''; position:absolute; inset:0;
  background:radial-gradient(circle at 30% 40%,rgba(255,255,255,0.18),transparent 60%),radial-gradient(circle at 70% 60%,rgba(255,255,255,0.10),transparent 50%);
}
.lc-hero-banner * { position:relative; z-index:1; }
.lc-since-label { font-size:.75rem; text-transform:uppercase; letter-spacing:.18em; color:rgba(255,255,255,0.75); margin-bottom:6px; }
.lc-since-date { font-family:'Playfair Display',serif; font-size:clamp(1.4rem,4vw,2rem); color:#fff; font-weight:700; }
.lc-since-names { font-size:1rem; color:rgba(255,255,255,0.85); margin-top:8px; font-style:italic; }
.lc-tier-badge {
  display:inline-block; margin:8px auto 0; padding:6px 20px; border-radius:30px;
  background:rgba(255,255,255,0.20); backdrop-filter:blur(6px); border:1px solid rgba(255,255,255,0.30);
  font-size:.82rem; font-weight:700; color:#fff; letter-spacing:.03em;
}

.lc-live-wrap {
  display:flex; align-items:center; justify-content:center; gap:12px;
  margin:16px 0; padding:18px 20px; border-radius:18px;
  background:linear-gradient(135deg,rgba(193,18,31,0.06),rgba(255,107,129,0.10));
  border:1px solid rgba(193,18,31,0.12);
}
.lc-pulse-heart { font-size:1.6rem; animation:lcPulse 1s ease-in-out infinite; }
@keyframes lcPulse { 0%,100%{transform:scale(1);} 50%{transform:scale(1.25);} }
.lc-live-counter { font-family:'DM Sans',sans-serif; font-size:clamp(1.05rem,3vw,1.5rem); color:var(--crimson); font-weight:800; text-align:center; font-variant-numeric:tabular-nums; }

.lc-stats-grid { display:grid; grid-template-columns:repeat(auto-fit,minmax(140px,1fr)); gap:14px; margin:20px 0; }
.lc-stat {
  background:linear-gradient(145deg,rgba(193,18,31,0.05),rgba(255,107,129,0.10));
  border:1px solid rgba(193,18,31,0.10); border-radius:20px; padding:20px 14px; text-align:center;
  transition:transform .2s,box-shadow .2s; position:relative; overflow:hidden;
}
.lc-stat:hover { transform:translateY(-3px); box-shadow:0 8px 24px rgba(193,18,31,0.12); }
.lc-stat-icon { font-size:1.6rem; margin-bottom:6px; display:block; }
.lc-stat-num { font-family:'Playfair Display',serif; font-size:clamp(1.5rem,4vw,2rem); color:var(--crimson); font-weight:700; }
.lc-stat-label { font-size:.72rem; color:var(--muted); text-transform:uppercase; letter-spacing:.08em; margin-top:4px; }

.lc-quote-box {
  text-align:center; padding:20px 24px; margin:16px 0;
  background:var(--ivory); border-radius:18px; border:1px solid rgba(0,0,0,.05);
  font-family:'Playfair Display',serif; font-style:italic; font-size:clamp(.92rem,2.5vw,1.08rem);
  color:var(--dark); line-height:1.7;
}
.lc-quote-box::before { content:'\201C'; font-size:2.4rem; color:var(--crimson); line-height:0; vertical-align:-.35em; margin-right:4px; }
.lc-quote-box::after { content:'\201D'; font-size:2.4rem; color:var(--crimson); line-height:0; vertical-align:-.35em; margin-left:2px; }

.lc-countdown-row {
  display:flex; flex-wrap:wrap; gap:12px; justify-content:center; margin:14px 0;
}
.lc-countdown-card {
  background:linear-gradient(135deg,rgba(193,18,31,0.08),rgba(255,107,129,0.12));
  border:1px solid rgba(193,18,31,0.10); border-radius:14px; padding:12px 18px; text-align:center;
  min-width:120px;
}
.lc-countdown-num { font-family:'Playfair Display',serif; font-size:1.3rem; font-weight:700; color:var(--crimson); }
.lc-countdown-lbl { font-size:.7rem; color:var(--muted); text-transform:uppercase; letter-spacing:.06em; margin-top:2px; }

.lc-milestones-title { font-size:.72rem; text-transform:uppercase; letter-spacing:.12em; color:var(--muted); text-align:center; margin-bottom:12px; }
.lc-milestone { display:inline-block; margin:5px; padding:8px 18px; border-radius:30px; font-size:.84rem; font-weight:600; background:var(--ivory); border:1px solid rgba(0,0,0,.06); color:var(--dark); transition:transform .15s; }
.lc-milestone:hover { transform:scale(1.04); }
.lc-milestone.reached { background:linear-gradient(135deg,var(--crimson),var(--rose)); color:#fff; border-color:transparent; box-shadow:0 3px 12px rgba(193,18,31,0.20); }

.lc-date-section {
  margin:8px auto 4px; max-width:460px;
  background:linear-gradient(145deg,rgba(193,18,31,0.04),rgba(255,107,129,0.08),rgba(201,168,76,0.05));
  border:1.5px solid rgba(193,18,31,0.12); border-radius:24px; padding:28px 24px 24px;
  position:relative; overflow:hidden; text-align:center;
}
.lc-date-section::before {
  content:''; position:absolute; top:-40px; right:-40px; width:120px; height:120px;
  background:radial-gradient(circle,rgba(193,18,31,0.08),transparent 70%); border-radius:50%; pointer-events:none;
}
.lc-date-section::after {
  content:''; position:absolute; bottom:-30px; left:-30px; width:100px; height:100px;
  background:radial-gradient(circle,rgba(201,168,76,0.10),transparent 70%); border-radius:50%; pointer-events:none;
}
.lc-date-header {
  display:flex; align-items:center; justify-content:center; gap:10px; margin-bottom:16px;
}
.lc-date-icon {
  width:48px; height:48px; border-radius:14px; display:flex; align-items:center; justify-content:center;
  background:linear-gradient(135deg,var(--crimson),var(--rose)); font-size:1.5rem;
  box-shadow:0 4px 14px rgba(193,18,31,0.25);
}
.lc-date-title { font-family:'Playfair Display',serif; font-size:1.2rem; color:var(--dark); font-weight:700; }
.lc-date-subtitle { font-size:.78rem; color:var(--muted); text-align:left; }
.lc-date-input-wrap {
  position:relative; margin:0 auto; max-width:280px;
}
.lc-date-input-wrap input[type="date"] {
  width:100%; padding:16px 20px; border:2px solid rgba(193,18,31,0.15); border-radius:16px;
  font-family:'DM Sans',sans-serif; font-size:1.05rem; font-weight:600; color:var(--dark);
  background:linear-gradient(135deg,#fff,#fff8f5); text-align:center;
  transition:border-color .25s,box-shadow .25s; cursor:pointer;
  -webkit-appearance:none; appearance:none;
}
.lc-date-input-wrap input[type="date"]:focus {
  border-color:var(--rose); box-shadow:0 0 0 4px rgba(230,57,70,0.12),0 4px 16px rgba(193,18,31,0.10);
  outline:none; background:#fff;
}
.lc-date-input-wrap input[type="date"]::-webkit-calendar-picker-indicator {
  background:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='20' height='20' fill='%23c1121f' viewBox='0 0 16 16'%3E%3Cpath d='M3.5 0a.5.5 0 0 1 .5.5V1h8V.5a.5.5 0 0 1 1 0V1h1a2 2 0 0 1 2 2v11a2 2 0 0 1-2 2H2a2 2 0 0 1-2-2V3a2 2 0 0 1 2-2h1V.5a.5.5 0 0 1 .5-.5zM1 4v10a1 1 0 0 0 1 1h12a1 1 0 0 0 1-1V4H1z'/%3E%3C/svg%3E") no-repeat center;
  cursor:pointer; width:22px; height:22px; opacity:.8; transition:opacity .2s;
}
.lc-date-input-wrap input[type="date"]::-webkit-calendar-picker-indicator:hover { opacity:1; }
.lc-date-presets {
  display:flex; flex-wrap:wrap; gap:8px; justify-content:center; margin-top:14px;
}
.lc-preset-btn {
  padding:7px 14px; border-radius:20px; border:1.5px solid rgba(193,18,31,0.15);
  background:rgba(255,255,255,0.80); color:var(--dark); font-size:.76rem; font-weight:600;
  cursor:pointer; transition:all .2s; font-family:'DM Sans',sans-serif;
}
.lc-preset-btn:hover {
  background:linear-gradient(135deg,var(--crimson),var(--rose)); color:#fff;
  border-color:transparent; box-shadow:0 3px 10px rgba(193,18,31,0.20); transform:translateY(-1px);
}
.lc-date-hint { font-size:.72rem; color:var(--muted); margin-top:12px; font-style:italic; }

.share-lc { background:#c1121f !important; color:#fff !important; }

/* ===== Soulmate Calculator ===== */
.sm-radar{margin:18px auto 6px;text-align:left;max-width:420px}
.sm-radar-title{font-size:.72rem;letter-spacing:.12em;text-transform:uppercase;color:var(--muted);margin-bottom:10px;text-align:center}
.sm-radar-row{display:grid;grid-template-columns:90px 1fr;align-items:center;gap:10px;margin-bottom:9px;font-size:.82rem;color:var(--dark)}
.sm-radar-row .meter-bar{height:9px;margin:0}
.sm-radar-row .meter-fill{background:linear-gradient(90deg,#7c3aed,#c084fc)}
.sm-lucky-row{display:flex;flex-wrap:wrap;gap:14px 22px;justify-content:center;margin:14px 0 4px;font-size:.88rem;color:var(--muted)}
.sm-lucky-row strong{color:var(--dark);font-weight:500}
.sm-badge{display:inline-block;margin:12px auto 4px;padding:8px 24px;border-radius:30px;font-size:.86rem;font-weight:700;letter-spacing:.04em}
.share-sm{background:#7c3aed !important;color:#fff !important}

/* ===== Ai Love Letter Generator ===== */
.ll-mood-grid{display:flex;flex-wrap:wrap;gap:10px;justify-content:center;margin:12px 0 18px}
.ll-mood-btn{padding:10px 20px;border-radius:30px;border:2px solid rgba(193,18,31,0.15);background:rgba(255,255,255,0.80);color:var(--dark);font-size:.88rem;font-weight:600;cursor:pointer;transition:all .2s;font-family:'DM Sans',sans-serif}
.ll-mood-btn:hover,.ll-mood-btn.active{background:linear-gradient(135deg,var(--crimson),var(--rose));color:#fff;border-color:transparent;box-shadow:0 3px 12px rgba(193,18,31,0.20);transform:translateY(-1px)}
.ll-letter-box{background:linear-gradient(145deg,#fffbf5,#fff8f0);border:1.5px solid rgba(193,18,31,0.10);border-radius:20px;padding:28px 24px;margin:18px 0;font-family:'Playfair Display',serif;font-size:clamp(.92rem,2.5vw,1.05rem);color:var(--dark);line-height:1.9;white-space:pre-wrap;position:relative}
.ll-letter-box::before{content:'❤️';position:absolute;top:-14px;left:50%;transform:translateX(-50%);font-size:1.4rem;background:var(--cream);padding:0 10px}
.ll-regen-btn{display:inline-block;margin:8px auto;padding:9px 22px;border-radius:30px;border:2px solid rgba(193,18,31,0.15);background:#fff;color:var(--crimson);font-size:.84rem;font-weight:600;cursor:pointer;transition:all .2s;font-family:'DM Sans',sans-serif}
.ll-regen-btn:hover{background:var(--crimson);color:#fff;border-color:transparent}
.share-ll{background:#c1121f !important;color:#fff !important}

/* ===== Breakup Calculator ===== */
.bu-form-grid{display:grid;grid-template-columns:1fr 1fr;gap:18px 24px;max-width:900px;margin:0 auto 24px}
.bu-field{display:flex;flex-direction:column;gap:6px}
.bu-field.full-width{grid-column:1/-1}
.bu-field label{font-family:'DM Sans',sans-serif;font-size:.88rem;font-weight:700;color:var(--dark);letter-spacing:.02em}
.bu-field label span{color:var(--crimson)}
.bu-field input,.bu-field select{padding:14px 16px;border:2px solid rgba(193,18,31,0.12);border-radius:12px;background:#fff;font-size:.92rem;color:var(--dark);font-family:'DM Sans',sans-serif;transition:border-color .2s;appearance:none;-webkit-appearance:none;-moz-appearance:none;outline:none}
.bu-field select{background:#fff url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%23666' stroke-width='1.5' fill='none'/%3E%3C/svg%3E") no-repeat right 16px center;padding-right:40px;cursor:pointer}
.bu-field input:focus,.bu-field select:focus{border-color:var(--crimson)}
.bu-field select.answered{border-color:var(--rose);background-color:rgba(255,107,129,0.03)}
.bu-radar{margin:18px auto 6px;text-align:left;max-width:420px}
.bu-radar-title{font-size:.72rem;letter-spacing:.12em;text-transform:uppercase;color:var(--muted);margin-bottom:10px;text-align:center}
.bu-radar-row{display:grid;grid-template-columns:110px 1fr;align-items:center;gap:10px;margin-bottom:9px;font-size:.82rem;color:var(--dark)}
.bu-radar-row .meter-bar{height:9px;margin:0}
.bu-radar-row .meter-fill{background:linear-gradient(90deg,#ef4444,#f97316)}
.bu-badge{display:inline-block;margin:12px auto 4px;padding:8px 24px;border-radius:30px;font-size:.86rem;font-weight:700;letter-spacing:.04em}
.share-bu{background:#ef4444 !important;color:#fff !important}
@media(max-width:600px){.bu-form-grid{grid-template-columns:1fr;gap:14px}}

/* ===== Love Story Generator ===== */
.ls-genre-grid{display:flex;flex-wrap:wrap;gap:10px;justify-content:center;margin:12px 0 18px}
.ls-genre-btn{padding:10px 20px;border-radius:30px;border:2px solid rgba(193,18,31,0.15);background:rgba(255,255,255,0.80);color:var(--dark);font-size:.88rem;font-weight:600;cursor:pointer;transition:all .2s;font-family:'DM Sans',sans-serif}
.ls-genre-btn:hover,.ls-genre-btn.active{background:linear-gradient(135deg,var(--crimson),var(--rose));color:#fff;border-color:transparent;box-shadow:0 3px 12px rgba(193,18,31,0.20);transform:translateY(-1px)}
.ls-story-box{background:linear-gradient(145deg,#fffbf5,#fff8f0);border:1.5px solid rgba(193,18,31,0.10);border-radius:20px;padding:28px 24px;margin:18px 0;font-family:'Playfair Display',serif;font-size:clamp(.9rem,2.5vw,1.02rem);color:var(--dark);line-height:1.95;white-space:pre-wrap;position:relative}
.ls-story-box::before{content:'📖';position:absolute;top:-14px;left:50%;transform:translateX(-50%);font-size:1.4rem;background:var(--cream);padding:0 10px}
.ls-story-title{font-family:'Playfair Display',serif;font-size:clamp(1.1rem,3vw,1.4rem);color:var(--crimson);text-align:center;margin-bottom:14px;font-weight:700}
.ls-regen-btn{display:inline-block;margin:8px auto;padding:9px 22px;border-radius:30px;border:2px solid rgba(193,18,31,0.15);background:#fff;color:var(--crimson);font-size:.84rem;font-weight:600;cursor:pointer;transition:all .2s;font-family:'DM Sans',sans-serif}
.ls-regen-btn:hover{background:var(--crimson);color:#fff;border-color:transparent}
.share-ls{background:#c1121f !important;color:#fff !important}

/* ===== Dahej Calculator ===== */
.dc-radar{margin:18px auto 6px;text-align:left;max-width:420px}
.dc-radar-title{font-size:.72rem;letter-spacing:.12em;text-transform:uppercase;color:var(--muted);margin-bottom:10px;text-align:center}
.dc-radar-row{display:grid;grid-template-columns:100px 1fr;align-items:center;gap:10px;margin-bottom:9px;font-size:.82rem;color:var(--dark)}
.dc-radar-row .meter-bar{height:9px;margin:0}
.dc-radar-row .meter-fill{background:linear-gradient(90deg,#d97706,#fbbf24)}
.dc-lucky-row{display:flex;flex-wrap:wrap;gap:14px 22px;justify-content:center;margin:14px 0 4px;font-size:.88rem;color:var(--muted)}
.dc-lucky-row strong{color:var(--dark);font-weight:500}
.dc-badge{display:inline-block;margin:12px auto 4px;padding:8px 24px;border-radius:30px;font-size:.86rem;font-weight:700;letter-spacing:.04em}
.share-dc{background:#d97706 !important;color:#fff !important}
.dc-form-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px 24px;max-width:640px;margin:0 auto 20px}
.dc-field{display:flex;flex-direction:column;gap:4px}
.dc-field label{font-size:.82rem;font-weight:600;color:var(--dark);letter-spacing:.02em}
.dc-field select{width:100%;padding:11px 14px;border:2px solid rgba(0,0,0,.08);border-radius:12px;font-size:.92rem;font-family:inherit;color:var(--dark);background:#fff;appearance:none;-webkit-appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='7'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%23999' stroke-width='1.5' fill='none'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 14px center;cursor:pointer;transition:border-color .2s,box-shadow .2s}
.dc-field select:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px rgba(225,29,72,.12)}
.dc-field select.answered{border-color:#d97706;background-color:rgba(217,119,6,.04)}
.dc-value{font-size:clamp(1.8rem,5vw,2.8rem);font-weight:900;background:linear-gradient(135deg,#d97706,#f59e0b);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.dc-disclaimer{margin:18px auto 0;padding:14px 20px;border-radius:12px;background:rgba(217,119,6,.06);border:1px solid rgba(217,119,6,.15);max-width:600px;font-size:.8rem;color:var(--muted);text-align:center;line-height:1.6}
@media(max-width:600px){.dc-form-grid{grid-template-columns:1fr}}

/* ===== Tools ===== */
.tools-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:24px;max-width:1200px;margin:0 auto;padding:0 5%}
.tool-card{background:var(--card-bg);border:1.5px solid rgba(193,18,31,0.08);border-radius:22px;padding:32px 28px;transition:all .3s;position:relative;overflow:hidden;text-decoration:none;display:block}
.tool-card::before{content:'';position:absolute;top:0;left:0;right:0;height:4px;background:linear-gradient(90deg,var(--crimson),var(--rose),var(--gold));opacity:0;transition:opacity .3s}
.tool-card:hover{transform:translateY(-6px);box-shadow:0 16px 40px rgba(193,18,31,0.12);border-color:rgba(193,18,31,0.15)}
.tool-card:hover::before{opacity:1}
.tool-card-icon{font-size:2.4rem;margin-bottom:14px;display:block}
.tool-card-title{font-family:'Playfair Display',serif;font-size:1.25rem;color:var(--dark);margin-bottom:8px;font-weight:700}
.tool-card-desc{font-size:.9rem;color:var(--muted);line-height:1.7;margin-bottom:16px}
.tool-card-tag{display:inline-block;padding:5px 14px;border-radius:20px;font-size:.72rem;font-weight:600;letter-spacing:.5px;text-transform:uppercase}
.tag-calculator{background:rgba(193,18,31,0.08);color:var(--crimson)}
.tag-generator{background:rgba(124,58,237,0.08);color:#7c3aed}
.tag-quiz{background:rgba(234,179,8,0.12);color:#b45309}
.tag-counter{background:rgba(14,165,233,0.08);color:#0284c7}
.tools-count{text-align:center;margin:0 auto 40px;font-size:.88rem;color:var(--muted);letter-spacing:.5px}
.tools-count strong{color:var(--crimson);font-weight:700;font-size:1rem}
.tools-filter{display:flex;flex-wrap:wrap;gap:10px;justify-content:center;margin:0 auto 36px;max-width:700px}
.tools-filter-btn{padding:9px 22px;border-radius:30px;border:2px solid rgba(193,18,31,0.12);background:rgba(255,255,255,0.8);color:var(--dark);font-size:.85rem;font-weight:600;cursor:pointer;transition:all .2s;font-family:'DM Sans',sans-serif}
.tools-filter-btn:hover,.tools-filter-btn.active{background:linear-gradient(135deg,var(--crimson),var(--rose));color:#fff;border-color:transparent;box-shadow:0 3px 12px rgba(193,18,31,0.18)}
@media(max-width:480px){
  .tools-grid{grid-template-columns:1fr;padding:0 4%}
  .tool-card{padding:24px 20px}
}
