/* =========================================================
   [BRAND NAME] — shared stylesheet
   Refined editorial SaaS aesthetic
   ========================================================= */

:root{
  --cream:#FBF7F0;
  --cream-2:#F4EEE3;
  --ink:#0E2A33;
  --ink-soft:#26414A;
  --teal:#0F766E;
  --teal-deep:#0B5C56;
  --teal-pale:#D6EDE9;
  --navy:#1B2A4E;
  --gold:#C89B3C;
  --rust:#B65A3C;
  --line:rgba(14,42,51,0.12);
  --shadow-sm: 0 1px 2px rgba(14,42,51,0.06), 0 2px 8px rgba(14,42,51,0.04);
  --shadow-md: 0 4px 12px rgba(14,42,51,0.08), 0 12px 32px rgba(14,42,51,0.06);
  --shadow-lg: 0 12px 32px rgba(14,42,51,0.10), 0 32px 64px rgba(14,42,51,0.08);
  --radius: 14px;
  --radius-lg: 22px;
  --serif:'Fraunces', Georgia, serif;
  --sans:'DM Sans', system-ui, sans-serif;
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  font-family:var(--sans);
  color:var(--ink);
  background:var(--cream);
  line-height:1.55;
  font-size:17px;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
.container{max-width:1180px;margin:0 auto;padding:0 24px}
.container-narrow{max-width:820px;margin:0 auto;padding:0 24px}
h1,h2,h3,h4{font-family:var(--serif);font-weight:500;letter-spacing:-0.015em;line-height:1.1;color:var(--ink)}
h1{font-size:clamp(2.4rem, 5.5vw, 4.2rem);font-weight:500;letter-spacing:-0.025em}
h2{font-size:clamp(2rem, 3.8vw, 3rem);letter-spacing:-0.02em}
h3{font-size:clamp(1.25rem, 2vw, 1.5rem)}
p{color:var(--ink-soft)}
.serif-italic{font-style:italic;font-family:var(--serif);font-weight:500}
.accent{color:var(--teal);font-style:italic;font-weight:500}

/* === NAV === */
.nav{
  position:sticky;top:0;z-index:50;
  backdrop-filter:blur(12px);
  background:rgba(251,247,240,0.82);
  border-bottom:1px solid transparent;
  transition:border-color .2s ease, background .2s ease;
}
.nav.scrolled{border-bottom-color:var(--line)}
.nav-inner{display:flex;align-items:center;justify-content:space-between;padding:18px 0}
.logo{display:flex;align-items:center;gap:10px;font-family:var(--serif);font-size:1.35rem;font-weight:600;color:var(--ink)}
.logo-mark{
  width:34px;height:34px;border-radius:10px;
  background:linear-gradient(135deg,var(--teal),var(--teal-deep));
  display:grid;place-items:center;color:var(--cream);
  box-shadow:var(--shadow-sm);
}
.nav-links{display:flex;gap:32px;align-items:center}
.nav-links a{font-size:.95rem;color:var(--ink-soft);font-weight:500;transition:color .2s;position:relative}
.nav-links a:hover{color:var(--teal)}
.nav-links a.active{color:var(--ink)}
.nav-links a.active:not(.nav-cta)::after{
  content:'';position:absolute;bottom:-6px;left:0;right:0;height:2px;background:var(--teal);border-radius:2px;
}
.nav-cta{padding:10px 18px;background:var(--ink);color:var(--cream)!important;border-radius:999px;font-size:.9rem;font-weight:600;transition:transform .15s, background .2s}
.nav-cta:hover{background:var(--teal);transform:translateY(-1px)}
.nav-cta.active::after{display:none}
.nav-toggle{display:none;background:none;border:none;cursor:pointer;padding:8px;color:var(--ink)}

/* Dropdown */
.has-dropdown{position:relative}
.dropdown-trigger{display:inline-flex;align-items:center;gap:6px;background:none;border:none;cursor:pointer;font:inherit;color:var(--ink-soft);font-weight:500;padding:0;transition:color .2s}
.dropdown-trigger:hover, .has-dropdown.open .dropdown-trigger{color:var(--teal)}
.has-dropdown.active .dropdown-trigger{color:var(--ink)}
.has-dropdown.active .dropdown-trigger::after{
  content:'';position:absolute;bottom:-6px;left:0;right:24px;height:2px;background:var(--teal);border-radius:2px;
}
.caret{transition:transform .2s ease;font-size:.75rem;line-height:1;margin-top:2px}
.has-dropdown.open .caret{transform:rotate(180deg)}

.dropdown-menu{
  position:absolute;top:calc(100% + 14px);left:50%;transform:translateX(-50%) translateY(-8px);
  background:var(--cream);border:1px solid var(--line);border-radius:16px;
  box-shadow:var(--shadow-lg);
  padding:10px;min-width:340px;
  opacity:0;pointer-events:none;
  transition:opacity .18s ease, transform .18s ease;
  z-index:60;
}
.has-dropdown.open .dropdown-menu{opacity:1;pointer-events:auto;transform:translateX(-50%) translateY(0)}
.dropdown-item{
  display:flex;align-items:flex-start;gap:14px;
  padding:12px 14px;border-radius:10px;
  transition:background .15s ease;
}
.dropdown-item:hover{background:var(--cream-2)}
.dropdown-item .di-icon{
  width:36px;height:36px;border-radius:10px;flex-shrink:0;
  background:var(--teal-pale);color:var(--teal-deep);
  display:grid;place-items:center;
}
.dropdown-item .di-text strong{display:block;font-size:.94rem;color:var(--ink);font-weight:600;font-family:var(--sans);margin-bottom:2px}
.dropdown-item .di-text span{display:block;font-size:.82rem;color:var(--ink-soft);line-height:1.4}

@media (max-width:780px){
  .has-dropdown{width:100%}
  .dropdown-trigger{width:100%;justify-content:space-between;padding:14px 0;color:var(--ink);font-size:1rem;font-weight:500;border-bottom:1px solid var(--line)}
  .has-dropdown.active .dropdown-trigger::after{display:none}
  .dropdown-menu{
    position:static;transform:none;opacity:1;pointer-events:auto;
    background:transparent;border:none;box-shadow:none;padding:0;min-width:0;
    display:none;
  }
  .has-dropdown.open .dropdown-menu{display:block;transform:none}
  .dropdown-item{padding:12px 0 12px 12px;border-bottom:1px solid var(--line)}
  .dropdown-item:last-child{border-bottom:none}
}
@media (max-width:780px){
  .nav-links{position:absolute;top:100%;left:0;right:0;background:var(--cream);flex-direction:column;gap:0;padding:8px 24px 24px;border-bottom:1px solid var(--line);box-shadow:var(--shadow-md);transform:translateY(-12px);opacity:0;pointer-events:none;transition:transform .2s,opacity .2s}
  .nav-links.open{transform:translateY(0);opacity:1;pointer-events:auto}
  .nav-links a{width:100%;padding:14px 0;border-bottom:1px solid var(--line)}
  .nav-links a:last-child{border-bottom:none;margin-top:8px}
  .nav-links a.active:not(.nav-cta)::after{display:none}
  .nav-toggle{display:block}
}

/* === BUTTONS === */
.btn{display:inline-flex;align-items:center;gap:10px;padding:15px 28px;border-radius:999px;font-weight:600;font-size:1rem;cursor:pointer;border:none;transition:all .2s ease;font-family:var(--sans)}
.btn-primary{background:var(--ink);color:var(--cream);box-shadow:var(--shadow-md)}
.btn-primary:hover{background:var(--teal);transform:translateY(-2px);box-shadow:var(--shadow-lg)}
.btn-ghost{background:transparent;color:var(--ink);border:1.5px solid var(--line)}
.btn-ghost:hover{border-color:var(--ink);background:rgba(14,42,51,0.04)}
.btn-arrow{transition:transform .2s}
.btn:hover .btn-arrow{transform:translateX(3px)}

/* === SECTION HEADER === */
.section-head{text-align:center;max-width:680px;margin:0 auto 64px}
.section-eyebrow{
  display:inline-block;font-size:.82rem;font-weight:600;
  color:var(--teal-deep);letter-spacing:.12em;text-transform:uppercase;
  margin-bottom:16px;
}
.section-head p{font-size:1.1rem;margin-top:16px;color:var(--ink-soft)}

/* === EYEBROW === */
.eyebrow{
  display:inline-flex;align-items:center;gap:8px;
  padding:6px 14px;border-radius:999px;
  background:var(--teal-pale);color:var(--teal-deep);
  font-size:.85rem;font-weight:600;letter-spacing:.01em;
  margin-bottom:24px;
}
.eyebrow-dot{width:6px;height:6px;border-radius:50%;background:var(--teal);box-shadow:0 0 0 4px rgba(15,118,110,0.18);animation:pulse 2s infinite}
@keyframes pulse{0%,100%{box-shadow:0 0 0 4px rgba(15,118,110,0.18)}50%{box-shadow:0 0 0 6px rgba(15,118,110,0.08)}}

/* =========================================================
   HOMEPAGE STYLES
   ========================================================= */

/* === HERO (homepage) === */
.hero{position:relative;padding:80px 0 100px;overflow:hidden}
.hero-bg{
  position:absolute;inset:0;z-index:0;
  background:
    radial-gradient(ellipse 60% 50% at 85% 20%, rgba(15,118,110,0.10), transparent 60%),
    radial-gradient(ellipse 50% 40% at 10% 80%, rgba(200,155,60,0.08), transparent 60%);
  pointer-events:none;
}
.paw-pattern{
  position:absolute;inset:0;z-index:0;opacity:.06;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='120' height='120' viewBox='0 0 120 120'><g fill='%230E2A33'><circle cx='30' cy='40' r='5'/><circle cx='45' cy='30' r='5'/><circle cx='60' cy='28' r='5'/><circle cx='75' cy='35' r='5'/><ellipse cx='52' cy='55' rx='14' ry='12'/></g></svg>");
  background-size:200px;
}
.hero-grid{position:relative;z-index:1;display:grid;grid-template-columns:1.15fr 1fr;gap:64px;align-items:center}
@media (max-width:960px){.hero-grid{grid-template-columns:1fr;gap:48px}}

.hero-sub{font-size:1.18rem;line-height:1.55;margin:24px 0 36px;max-width:540px;color:var(--ink-soft)}
.hero-ctas{display:flex;gap:14px;flex-wrap:wrap;align-items:center}
.hero-trust{display:flex;align-items:center;gap:14px;margin-top:36px;font-size:.9rem;color:var(--ink-soft)}
.hero-trust strong{color:var(--ink);font-weight:600}
.stars{color:var(--gold);letter-spacing:2px;font-size:1rem}

.hero-visual{position:relative;display:flex;justify-content:center;align-items:center;min-height:520px}
.phone{
  position:relative;width:280px;height:560px;
  background:var(--ink);border-radius:42px;padding:12px;
  box-shadow:var(--shadow-lg), 0 40px 80px -20px rgba(14,42,51,0.30);
  transform:rotate(-3deg);
  z-index:2;
}
.phone-screen{
  width:100%;height:100%;
  background:var(--cream);border-radius:32px;
  padding:24px 18px;overflow:hidden;position:relative;
}
.phone-notch{position:absolute;top:18px;left:50%;transform:translateX(-50%);width:90px;height:22px;background:var(--ink);border-radius:0 0 14px 14px;z-index:3}
.app-header{padding-top:22px;margin-bottom:18px}
.app-header h4{font-family:var(--serif);font-size:1rem;color:var(--ink)}
.app-header p{font-size:.7rem;color:var(--ink-soft)}
.app-card{
  background:white;border:1px solid var(--line);
  border-radius:14px;padding:12px 14px;margin-bottom:10px;
  font-size:.75rem;
}
.app-card.featured{background:var(--teal);color:var(--cream);border-color:var(--teal)}
.app-card.featured p{color:rgba(251,247,240,.85)}
.app-card-row{display:flex;align-items:center;justify-content:space-between;gap:10px}
.app-card-row strong{font-weight:600;font-size:.78rem}
.app-tag{font-size:.62rem;padding:3px 8px;border-radius:6px;background:var(--cream-2);color:var(--ink-soft);font-weight:600}
.app-card.featured .app-tag{background:rgba(251,247,240,.18);color:var(--cream)}
.app-card p{font-size:.7rem;color:var(--ink-soft);margin-top:4px}

.notif-card{
  position:absolute;top:60px;right:-30px;z-index:3;
  background:white;border-radius:14px;padding:14px 16px;
  box-shadow:var(--shadow-lg);
  display:flex;align-items:center;gap:12px;
  max-width:240px;
  animation:float 6s ease-in-out infinite;
}
.notif-card.review{top:auto;bottom:80px;right:auto;left:-20px;animation-delay:-3s}
@keyframes float{0%,100%{transform:translateY(0)}50%{transform:translateY(-8px)}}
.notif-icon{
  width:36px;height:36px;border-radius:10px;
  background:var(--teal-pale);color:var(--teal-deep);
  display:grid;place-items:center;flex-shrink:0;
}
.notif-card.review .notif-icon{background:rgba(200,155,60,.18);color:var(--gold)}
.notif-card p{font-size:.78rem;margin:0;line-height:1.35;color:var(--ink)}
.notif-card small{font-size:.68rem;color:var(--ink-soft);display:block;margin-top:2px}
@media (max-width:960px){
  .hero{padding-top:48px}
  .notif-card{right:-10px}
  .notif-card.review{left:-10px}
}
@media (max-width:480px){
  .phone{width:240px;height:480px;transform:rotate(-2deg)}
  .notif-card{display:none}
}

/* === PAIN POINTS === */
.pains{padding:100px 0;background:var(--cream-2);position:relative;overflow:hidden}
.pains::before{
  content:'';position:absolute;top:-1px;left:0;right:0;height:60px;
  background:linear-gradient(to bottom, var(--cream), transparent);
}
.pain-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:20px}
@media (max-width:760px){.pain-grid{grid-template-columns:1fr}}
.pain-card{
  background:var(--cream);border-radius:var(--radius-lg);
  padding:32px;border:1px solid var(--line);
  position:relative;overflow:hidden;
  transition:transform .25s ease, box-shadow .25s ease;
}
.pain-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-md)}
.pain-num{
  font-family:var(--serif);font-style:italic;
  font-size:3rem;font-weight:500;
  color:var(--teal);opacity:.4;
  line-height:1;margin-bottom:12px;
}
.pain-card h3{margin-bottom:10px;font-weight:600}
.pain-card p{font-size:.98rem}
.pain-tagline{
  text-align:center;margin-top:56px;
  font-family:var(--serif);font-style:italic;font-size:1.4rem;
  color:var(--ink);
}
.pain-tagline span{color:var(--teal);font-weight:600;font-style:normal}

/* === HOW IT WORKS === */
.how{padding:120px 0;position:relative}
.how-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:32px;position:relative}
@media (max-width:820px){.how-grid{grid-template-columns:1fr;gap:40px}}
.how-step{position:relative;text-align:left}
.how-step::before{
  content:'';position:absolute;top:28px;right:-32px;width:24px;height:1px;
  background:repeating-linear-gradient(to right, var(--line) 0 4px, transparent 4px 8px);
}
.how-step:last-child::before{display:none}
@media (max-width:820px){.how-step::before{display:none}}
.step-num{
  width:56px;height:56px;border-radius:16px;
  background:var(--ink);color:var(--cream);
  display:grid;place-items:center;
  font-family:var(--serif);font-size:1.4rem;font-weight:500;
  margin-bottom:24px;
  box-shadow:var(--shadow-sm);
}
.how-step:nth-child(2) .step-num{background:var(--teal)}
.how-step:nth-child(3) .step-num{background:var(--gold);color:var(--ink)}
.how-step h3{margin-bottom:12px;font-weight:600}

/* === FEATURES (homepage grid) === */
.features{padding:100px 0;background:var(--ink);color:var(--cream);position:relative;overflow:hidden}
.features::before{
  content:'';position:absolute;inset:0;
  background:radial-gradient(ellipse 70% 50% at 80% 0%, rgba(15,118,110,0.25), transparent 60%);
  pointer-events:none;
}
.features h2{color:var(--cream)}
.features .section-head p{color:rgba(251,247,240,0.75)}
.features .section-eyebrow{color:#5EAEA4}
.feature-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:2px;background:rgba(251,247,240,0.10);border-radius:var(--radius-lg);overflow:hidden;border:1px solid rgba(251,247,240,0.10);position:relative}
@media (max-width:820px){.feature-grid{grid-template-columns:repeat(2,1fr)}}
@media (max-width:520px){.feature-grid{grid-template-columns:1fr}}
.feature-card{
  background:var(--ink);padding:36px 28px;
  transition:background .25s ease;
}
.feature-card:hover{background:#13323D}
.feature-icon{
  width:44px;height:44px;border-radius:12px;
  background:rgba(15,118,110,0.18);color:#7CC8BE;
  display:grid;place-items:center;margin-bottom:20px;
}
.feature-card h4{font-family:var(--serif);font-size:1.15rem;color:var(--cream);font-weight:500;margin-bottom:8px}
.feature-card p{font-size:.94rem;color:rgba(251,247,240,0.70);line-height:1.5}

/* === ROI === */
.roi{padding:120px 0;position:relative;overflow:hidden}
.roi-card{
  max-width:880px;margin:0 auto;
  background:linear-gradient(135deg, var(--cream) 0%, var(--cream-2) 100%);
  border:1px solid var(--line);
  border-radius:var(--radius-lg);
  padding:56px 48px;text-align:center;
  box-shadow:var(--shadow-md);
  position:relative;overflow:hidden;
}
.roi-card::before{
  content:'';position:absolute;top:-50px;right:-50px;width:200px;height:200px;
  background:radial-gradient(circle,rgba(15,118,110,0.10),transparent 70%);
  border-radius:50%;
}
.roi-quote{
  font-family:var(--serif);font-size:clamp(1.4rem,2.5vw,1.9rem);
  line-height:1.4;color:var(--ink);font-weight:500;letter-spacing:-0.01em;
  margin-bottom:32px;position:relative;
}
.roi-quote .highlight{
  background:linear-gradient(180deg, transparent 60%, rgba(200,155,60,0.32) 60%);
  padding:0 4px;
}
.roi-maths{
  display:flex;align-items:center;justify-content:center;gap:20px;flex-wrap:wrap;
  margin:32px 0;
  font-family:var(--serif);
}
.roi-bit{text-align:center}
.roi-bit .num{font-size:2.2rem;font-weight:500;color:var(--teal);display:block;line-height:1}
.roi-bit .label{font-size:.78rem;color:var(--ink-soft);font-family:var(--sans);font-weight:500;letter-spacing:.04em;text-transform:uppercase;margin-top:6px;display:block}
.roi-plus{font-size:1.8rem;color:var(--ink-soft);font-family:var(--sans);font-weight:300}
.roi-equals{font-size:2.4rem;color:var(--ink-soft);font-family:var(--sans);font-weight:300}
.roi-bit.total .num{color:var(--rust)}
.roi-note{font-size:.95rem;color:var(--ink-soft);font-style:italic;font-family:var(--serif)}

/* === PRICING (homepage) === */
.pricing{padding:120px 0;background:var(--cream-2);position:relative}
.price-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:24px;max-width:920px;margin:0 auto}
@media (max-width:780px){.price-grid{grid-template-columns:1fr;max-width:480px}}
.price-card{
  background:var(--cream);border:1px solid var(--line);
  border-radius:var(--radius-lg);padding:40px 36px;
  position:relative;display:flex;flex-direction:column;
  transition:transform .25s ease, box-shadow .25s ease;
}
.price-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-md)}
.price-card.recommended{
  background:var(--ink);color:var(--cream);
  border-color:var(--ink);
  box-shadow:var(--shadow-lg);
}
.price-card.recommended h3,
.price-card.recommended .price-amount{color:var(--cream)}
.price-card.recommended p{color:rgba(251,247,240,0.75)}
.recommend-tag{
  position:absolute;top:-12px;left:50%;transform:translateX(-50%);
  background:var(--gold);color:var(--ink);
  padding:6px 16px;border-radius:999px;
  font-size:.78rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase;
}
.price-card h3{font-family:var(--serif);font-size:1.5rem;margin-bottom:8px;font-weight:600}
.price-tagline{font-size:.95rem;margin-bottom:24px}
.price-amount{
  font-family:var(--serif);font-size:3.4rem;font-weight:500;
  color:var(--ink);line-height:1;letter-spacing:-0.02em;
}
.price-amount .per{font-size:1rem;color:var(--ink-soft);font-family:var(--sans);font-weight:500}
.price-card.recommended .price-amount .per{color:rgba(251,247,240,0.7)}
.price-setup{font-size:.92rem;margin:10px 0 28px;color:var(--ink-soft)}
.price-card.recommended .price-setup{color:rgba(251,247,240,0.75)}
.feature-list{list-style:none;margin-bottom:32px;flex-grow:1}
.feature-list li{
  padding:10px 0;display:flex;align-items:flex-start;gap:12px;
  font-size:.96rem;color:var(--ink);
  border-bottom:1px solid var(--line);
}
.feature-list li:last-child{border-bottom:none}
.price-card.recommended .feature-list li{color:var(--cream);border-color:rgba(251,247,240,0.10)}
.check{
  width:20px;height:20px;border-radius:50%;flex-shrink:0;margin-top:2px;
  background:var(--teal-pale);color:var(--teal-deep);
  display:grid;place-items:center;font-size:.7rem;font-weight:700;
}
.price-card.recommended .check{background:rgba(124,200,190,0.18);color:#7CC8BE}
.price-btn{
  width:100%;text-align:center;display:block;
  padding:15px;border-radius:12px;
  background:var(--ink);color:var(--cream);
  font-weight:600;font-size:1rem;transition:all .2s;
}
.price-btn:hover{background:var(--teal)}
.price-card.recommended .price-btn{background:var(--gold);color:var(--ink)}
.price-card.recommended .price-btn:hover{background:var(--cream)}
.price-footnote{text-align:center;margin-top:32px;font-size:.9rem;color:var(--ink-soft)}

/* === FAQ === */
.faq{padding:120px 0}
.faq-grid{max-width:780px;margin:0 auto}
.faq-item{
  border-bottom:1px solid var(--line);
  padding:0;
}
.faq-question{
  width:100%;text-align:left;background:none;border:none;
  padding:24px 0;cursor:pointer;
  display:flex;justify-content:space-between;align-items:center;gap:24px;
  font-family:var(--serif);font-size:1.15rem;font-weight:500;color:var(--ink);
  transition:color .2s;
}
.faq-question:hover{color:var(--teal)}
.faq-toggle{
  flex-shrink:0;width:32px;height:32px;border-radius:50%;
  background:var(--cream-2);color:var(--ink);
  display:grid;place-items:center;
  font-size:1.2rem;font-weight:300;
  transition:transform .25s, background .25s;
}
.faq-item.open .faq-toggle{background:var(--teal);color:var(--cream);transform:rotate(45deg)}
.faq-answer{
  max-height:0;overflow:hidden;
  transition:max-height .35s ease, padding .25s ease;
}
.faq-item.open .faq-answer{max-height:400px;padding:0 0 24px}
.faq-answer p{font-size:1rem;line-height:1.6;color:var(--ink-soft);max-width:680px}

/* === FOOTER CTA === */
.footer-cta{
  padding:120px 0 80px;background:var(--ink);color:var(--cream);
  position:relative;overflow:hidden;
}
.footer-cta::before{
  content:'';position:absolute;inset:0;
  background:
    radial-gradient(ellipse 50% 40% at 20% 30%, rgba(15,118,110,0.30), transparent 60%),
    radial-gradient(ellipse 60% 50% at 90% 80%, rgba(200,155,60,0.12), transparent 60%);
  pointer-events:none;
}
.cta-inner{position:relative;z-index:1;text-align:center;max-width:680px;margin:0 auto}
.cta-inner h2{color:var(--cream);margin-bottom:20px}
.cta-inner .serif-italic{color:#7CC8BE}
.cta-inner p{font-size:1.15rem;color:rgba(251,247,240,0.80);margin-bottom:36px}
.cta-ctas{display:flex;gap:14px;justify-content:center;flex-wrap:wrap}
.cta-inner .btn-primary{background:var(--cream);color:var(--ink)}
.cta-inner .btn-primary:hover{background:var(--gold)}
.cta-inner .btn-ghost{color:var(--cream);border-color:rgba(251,247,240,0.30)}
.cta-inner .btn-ghost:hover{border-color:var(--cream);background:rgba(251,247,240,0.06)}

.footer-info{
  position:relative;z-index:1;
  margin-top:80px;padding-top:40px;border-top:1px solid rgba(251,247,240,0.12);
  display:flex;justify-content:space-between;align-items:center;gap:24px;flex-wrap:wrap;
  font-size:.9rem;color:rgba(251,247,240,0.65);
}
.footer-info a{color:rgba(251,247,240,0.85);transition:color .2s}
.footer-info a:hover{color:var(--cream)}
.footer-contact{display:flex;gap:24px;flex-wrap:wrap}

/* Reveal animation — only applied when JS is enabled. Content is visible
   by default as a safety fallback so the site never breaks if JS fails. */
.js .reveal{opacity:0;transform:translateY(20px);transition:opacity .7s ease, transform .7s ease}
.js .reveal.in{opacity:1;transform:translateY(0)}
@media (prefers-reduced-motion: reduce){
  .js .reveal{opacity:1;transform:none;transition:none}
}

/* =========================================================
   PAGE HERO (shared across sub-pages)
   ========================================================= */

.page-hero{
  padding:80px 0 60px;
  position:relative;overflow:hidden;
  text-align:center;
}
.page-hero::before{
  content:'';position:absolute;inset:0;
  background:
    radial-gradient(ellipse 60% 50% at 50% 0%, rgba(15,118,110,0.08), transparent 60%);
  pointer-events:none;
}
.page-hero .container{position:relative;z-index:1}
.page-hero h1{max-width:880px;margin:0 auto;font-size:clamp(2.2rem, 4.6vw, 3.6rem)}
.page-hero .lede{font-size:1.18rem;max-width:640px;margin:24px auto 0;color:var(--ink-soft)}
.page-hero-ctas{margin-top:36px;display:flex;gap:14px;justify-content:center;flex-wrap:wrap}

/* =========================================================
   ABOUT PAGE
   ========================================================= */

.about-story{padding:80px 0;position:relative}
.story-grid{display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:center;max-width:1080px;margin:0 auto}
@media (max-width:880px){.story-grid{grid-template-columns:1fr;gap:40px}}
.story-image{
  position:relative;border-radius:var(--radius-lg);overflow:hidden;
  background:linear-gradient(135deg, var(--teal) 0%, var(--teal-deep) 100%);
  aspect-ratio:4/5;
  display:grid;place-items:center;
  box-shadow:var(--shadow-lg);
}
.story-image::after{
  content:'';position:absolute;inset:0;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='120' height='120' viewBox='0 0 120 120'><g fill='%23FBF7F0' fill-opacity='0.10'><circle cx='30' cy='40' r='5'/><circle cx='45' cy='30' r='5'/><circle cx='60' cy='28' r='5'/><circle cx='75' cy='35' r='5'/><ellipse cx='52' cy='55' rx='14' ry='12'/></g></svg>");
  background-size:160px;
}
.story-image-inner{
  position:relative;z-index:1;color:var(--cream);text-align:center;padding:40px;
}
.story-image-inner .big-quote{
  font-family:var(--serif);font-style:italic;
  font-size:clamp(1.6rem, 3vw, 2.2rem);line-height:1.25;font-weight:500;
}
.story-image-inner .attribution{
  margin-top:24px;font-size:.85rem;letter-spacing:.08em;text-transform:uppercase;
  color:rgba(251,247,240,0.75);font-weight:600;
}
.story-text h2{margin-bottom:24px}
.story-text p{font-size:1.05rem;margin-bottom:18px;line-height:1.65}
.story-text p:last-child{margin-bottom:0}

/* Principles strip */
.principles{padding:100px 0;background:var(--cream-2)}
.principle-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
@media (max-width:820px){.principle-grid{grid-template-columns:1fr}}
.principle-card{
  background:var(--cream);border:1px solid var(--line);
  border-radius:var(--radius-lg);padding:36px 32px;
}
.principle-num{
  font-family:var(--serif);font-style:italic;
  font-size:1.05rem;color:var(--teal);font-weight:600;
  margin-bottom:14px;display:block;
}
.principle-card h3{margin-bottom:12px;font-weight:600;font-size:1.3rem}
.principle-card p{font-size:.98rem;line-height:1.6}

/* Numbers strip */
.numbers{padding:80px 0;background:var(--ink);color:var(--cream)}
.numbers-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:32px;text-align:center}
@media (max-width:720px){.numbers-grid{grid-template-columns:1fr;gap:40px}}
.number-item .big-num{
  font-family:var(--serif);font-size:clamp(3rem,6vw,4.5rem);
  color:var(--cream);font-weight:500;line-height:1;letter-spacing:-0.03em;
  display:block;
}
.number-item .big-num .symbol{color:#7CC8BE;font-style:italic}
.number-item .label{
  margin-top:14px;font-size:.95rem;color:rgba(251,247,240,0.75);
  max-width:240px;margin-left:auto;margin-right:auto;line-height:1.5;
}

/* =========================================================
   CONTACT PAGE
   ========================================================= */

.contact-section{padding:60px 0 100px}
.contact-grid{
  display:grid;grid-template-columns:1.1fr 1fr;gap:48px;
  max-width:1080px;margin:0 auto;align-items:start;
}
@media (max-width:880px){.contact-grid{grid-template-columns:1fr;gap:48px}}

.contact-form{
  background:var(--cream);border:1px solid var(--line);
  border-radius:var(--radius-lg);padding:40px;
  box-shadow:var(--shadow-md);
}
.contact-form h2{font-size:1.6rem;margin-bottom:8px;font-weight:600}
.contact-form > p{margin-bottom:28px;font-size:.98rem}

.form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:18px}
@media (max-width:520px){.form-row{grid-template-columns:1fr}}
.form-field{display:flex;flex-direction:column;margin-bottom:18px}
.form-field label{
  font-size:.85rem;font-weight:600;color:var(--ink);
  margin-bottom:6px;letter-spacing:.01em;
}
.form-field label .opt{color:var(--ink-soft);font-weight:400;font-size:.78rem}
.form-field input,
.form-field select,
.form-field textarea{
  padding:13px 16px;border-radius:10px;
  border:1.5px solid var(--line);
  background:var(--cream);
  font-family:var(--sans);font-size:1rem;color:var(--ink);
  transition:border-color .2s, background .2s;
  width:100%;
}
.form-field input:focus,
.form-field select:focus,
.form-field textarea:focus{
  outline:none;border-color:var(--teal);
  background:white;
}
.form-field textarea{resize:vertical;min-height:120px;font-family:var(--sans)}
.form-submit{margin-top:8px;width:100%;justify-content:center}
.form-success{
  background:var(--teal-pale);color:var(--teal-deep);
  border:1px solid rgba(15,118,110,0.20);
  padding:20px 24px;border-radius:14px;margin-top:20px;display:none;
}
.form-success.show{display:block}
.form-success strong{display:block;font-size:1.05rem;font-family:var(--serif);font-weight:600;margin-bottom:4px}

.contact-info h3{
  font-family:var(--serif);font-size:1.4rem;font-weight:600;
  margin-bottom:8px;
}
.contact-info p{margin-bottom:32px;font-size:.98rem}

.contact-methods{display:flex;flex-direction:column;gap:18px;margin-bottom:36px}
.contact-method{
  display:flex;align-items:flex-start;gap:16px;
  padding:18px;background:var(--cream-2);
  border-radius:14px;border:1px solid transparent;
  transition:border-color .2s, transform .2s;
}
.contact-method:hover{border-color:var(--line);transform:translateX(2px)}
.contact-method .ic{
  width:42px;height:42px;border-radius:11px;flex-shrink:0;
  background:var(--cream);color:var(--teal-deep);
  display:grid;place-items:center;border:1px solid var(--line);
}
.contact-method strong{font-size:.95rem;color:var(--ink);font-weight:600;display:block}
.contact-method a, .contact-method .meta{
  font-size:.92rem;color:var(--ink-soft);margin-top:2px;display:block;
}
.contact-method a:hover{color:var(--teal)}

.hours-card{
  background:var(--cream);border:1px solid var(--line);
  border-radius:14px;padding:20px 24px;
}
.hours-card h4{font-family:var(--serif);font-size:1.05rem;font-weight:600;margin-bottom:12px}
.hours-card .row{display:flex;justify-content:space-between;font-size:.93rem;padding:5px 0;color:var(--ink-soft)}
.hours-card .row span:last-child{color:var(--ink);font-weight:500}

/* =========================================================
   FEATURES PAGE
   ========================================================= */

.features-deep{padding:60px 0 80px}
.feature-block{
  display:grid;grid-template-columns:1fr 1fr;gap:64px;
  align-items:center;padding:80px 0;
  border-bottom:1px solid var(--line);
}
.feature-block:last-of-type{border-bottom:none}
.feature-block.reverse .feature-visual{order:-1}
@media (max-width:880px){
  .feature-block, .feature-block.reverse{grid-template-columns:1fr;gap:40px}
  .feature-block.reverse .feature-visual{order:0}
}
.feature-text .pill{
  display:inline-flex;align-items:center;gap:8px;
  padding:6px 14px;border-radius:999px;
  background:var(--teal-pale);color:var(--teal-deep);
  font-size:.78rem;font-weight:600;letter-spacing:.06em;text-transform:uppercase;
  margin-bottom:18px;
}
.feature-text h2{font-size:clamp(1.7rem,3vw,2.3rem);margin-bottom:20px}
.feature-text p{font-size:1.05rem;line-height:1.65;margin-bottom:16px}
.feature-text ul{list-style:none;margin-top:20px}
.feature-text ul li{
  padding:8px 0;display:flex;align-items:flex-start;gap:12px;
  font-size:.98rem;color:var(--ink);
}
.feature-text ul li .check{margin-top:4px}

/* Mock visuals */
.feature-visual{
  position:relative;border-radius:var(--radius-lg);
  padding:40px;min-height:380px;
  display:flex;align-items:center;justify-content:center;
  overflow:hidden;
  box-shadow:var(--shadow-md);
}
.visual-cream{background:linear-gradient(135deg, var(--cream-2) 0%, var(--cream) 100%)}
.visual-teal{background:linear-gradient(135deg, var(--teal) 0%, var(--teal-deep) 100%);color:var(--cream)}
.visual-ink{background:linear-gradient(135deg, var(--ink) 0%, #13323D 100%);color:var(--cream)}
.visual-gold{background:linear-gradient(135deg, #F4E2B5 0%, var(--cream-2) 100%)}

.mock-card{
  background:white;border-radius:14px;
  box-shadow:var(--shadow-lg);
  padding:22px 24px;width:100%;max-width:340px;
  position:relative;
}
.visual-teal .mock-card, .visual-ink .mock-card{color:var(--ink)}
.mock-card .mc-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px}
.mock-card .mc-head h5{font-family:var(--serif);font-size:1rem;font-weight:600;color:var(--ink)}
.mock-card .mc-head .pill-mini{font-size:.7rem;padding:3px 9px;border-radius:6px;background:var(--teal-pale);color:var(--teal-deep);font-weight:600}
.mock-card .mc-row{
  display:flex;align-items:center;justify-content:space-between;
  padding:10px 0;border-top:1px solid var(--line);font-size:.85rem;
}
.mock-card .mc-row:first-of-type{border-top:none}
.mock-card .mc-row strong{color:var(--ink);font-weight:600}
.mock-card .mc-row .meta{color:var(--ink-soft);font-size:.78rem}

.mock-sms{
  background:white;border-radius:18px;padding:18px;width:100%;max-width:320px;
  box-shadow:var(--shadow-lg);
}
.sms-bubble{
  background:var(--cream-2);border-radius:16px 16px 16px 4px;
  padding:12px 16px;font-size:.88rem;color:var(--ink);
  margin-bottom:10px;line-height:1.5;
}
.sms-bubble.out{
  background:var(--teal);color:var(--cream);
  border-radius:16px 16px 4px 16px;margin-left:auto;
  max-width:85%;
}
.sms-bubble:last-child{margin-bottom:0}
.sms-time{font-size:.7rem;color:var(--ink-soft);text-align:center;margin-bottom:12px;letter-spacing:.04em;text-transform:uppercase}

.mock-reviews{display:flex;flex-direction:column;gap:14px;width:100%;max-width:360px}
.review-card{
  background:white;border-radius:14px;padding:18px 20px;
  box-shadow:var(--shadow-md);
}
.review-stars{color:var(--gold);font-size:.9rem;letter-spacing:2px;margin-bottom:6px}
.review-card p{font-size:.88rem;color:var(--ink);line-height:1.5;margin-bottom:8px}
.review-author{font-size:.78rem;color:var(--ink-soft);font-weight:600}

.mock-dashboard{
  background:white;border-radius:14px;padding:24px;width:100%;max-width:380px;
  box-shadow:var(--shadow-lg);
}
.dash-stat-row{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:16px}
.dash-stat{background:var(--cream-2);border-radius:10px;padding:14px}
.dash-stat .v{font-family:var(--serif);font-size:1.6rem;font-weight:500;color:var(--ink);line-height:1}
.dash-stat .l{font-size:.72rem;color:var(--ink-soft);margin-top:4px;font-weight:500}
.dash-chart{
  height:90px;background:var(--cream-2);border-radius:10px;padding:14px 16px;
  position:relative;overflow:hidden;
}
.dash-bars{display:flex;align-items:flex-end;gap:6px;height:100%}
.dash-bar{flex:1;background:var(--teal);border-radius:3px 3px 0 0;opacity:.85}
.dash-bar:nth-child(odd){background:var(--teal-deep)}

/* Comparison table (features page CTA strip) */
.compare-strip{
  background:var(--cream-2);padding:80px 0;text-align:center;
  border-radius:0;
}
.compare-strip h2{margin-bottom:16px}
.compare-strip p{font-size:1.05rem;max-width:560px;margin:0 auto 32px}

/* =========================================================
   PRICING PAGE
   ========================================================= */

.pricing-deep{padding:60px 0 80px}
.price-toggle{
  display:flex;justify-content:center;margin-bottom:48px;
}
.toggle-pill{
  background:var(--cream-2);border:1px solid var(--line);border-radius:999px;
  padding:5px;display:inline-flex;gap:4px;
}
.toggle-pill button{
  background:none;border:none;padding:10px 22px;border-radius:999px;
  font-family:var(--sans);font-weight:600;font-size:.92rem;color:var(--ink-soft);
  cursor:pointer;transition:all .2s;
}
.toggle-pill button.on{background:var(--ink);color:var(--cream)}

.price-compare{padding:60px 0 80px;background:var(--cream-2)}
.compare-table{
  max-width:980px;margin:0 auto;
  background:var(--cream);border:1px solid var(--line);
  border-radius:var(--radius-lg);overflow:hidden;
  box-shadow:var(--shadow-sm);
}
.compare-row{
  display:grid;grid-template-columns:2fr 1fr 1fr;
  border-bottom:1px solid var(--line);
}
.compare-row:last-child{border-bottom:none}
.compare-row.header{
  background:var(--ink);color:var(--cream);
}
.compare-row.header > div{padding:24px;font-family:var(--serif);font-size:1.05rem;font-weight:600}
.compare-row.header .col-feature{color:rgba(251,247,240,0.75);font-size:.85rem;letter-spacing:.08em;text-transform:uppercase;font-family:var(--sans);font-weight:600}
.compare-row.header .col-growth{background:var(--teal);position:relative}
.compare-row.header .col-growth .tag{
  position:absolute;top:8px;right:12px;font-size:.65rem;
  background:var(--gold);color:var(--ink);padding:2px 8px;border-radius:999px;
  letter-spacing:.06em;text-transform:uppercase;font-weight:700;
}
.compare-row > div{padding:18px 24px;display:flex;align-items:center;font-size:.95rem}
.compare-row .col-feature{font-weight:500;color:var(--ink)}
.compare-row .col-essential, .compare-row .col-growth{justify-content:center;font-weight:600}
.compare-row .yes{color:var(--teal-deep)}
.compare-row .no{color:var(--ink-soft);opacity:.4}
.compare-row.section{background:var(--cream-2)}
.compare-row.section .col-feature{
  font-family:var(--serif);font-style:italic;font-weight:500;color:var(--ink);
  font-size:.92rem;letter-spacing:.02em;
}
.compare-row.section > div:not(.col-feature){background:var(--cream-2)}

@media (max-width:680px){
  .compare-row{grid-template-columns:1.6fr 1fr 1fr;font-size:.82rem}
  .compare-row > div{padding:14px 12px}
  .compare-row.header > div{padding:18px 12px;font-size:.92rem}
}

/* Add-ons / pricing extras */
.addons{padding:100px 0}
.addon-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;max-width:1080px;margin:0 auto}
@media (max-width:820px){.addon-grid{grid-template-columns:1fr}}
.addon-card{
  background:var(--cream);border:1px solid var(--line);
  border-radius:var(--radius-lg);padding:28px;
  transition:transform .25s, box-shadow .25s;
}
.addon-card:hover{transform:translateY(-3px);box-shadow:var(--shadow-md)}
.addon-card h4{font-family:var(--serif);font-size:1.15rem;font-weight:600;margin-bottom:8px}
.addon-card .price{
  font-family:var(--serif);font-size:1.6rem;font-weight:500;color:var(--teal);
  display:block;margin:8px 0 12px;
}
.addon-card p{font-size:.95rem;line-height:1.55}

/* =========================================================
   SINGLE FEATURE PAGES (punchy, one-screen)
   ========================================================= */

.feature-single{
  position:relative;overflow:hidden;
  padding:60px 0 80px;
  min-height:calc(100vh - 76px);
  display:flex;align-items:center;
}
.feature-single::before{
  content:'';position:absolute;inset:0;
  background:
    radial-gradient(ellipse 50% 40% at 90% 20%, rgba(15,118,110,0.10), transparent 60%),
    radial-gradient(ellipse 50% 40% at 10% 90%, rgba(200,155,60,0.06), transparent 60%);
  pointer-events:none;
}
.fs-grid{
  position:relative;z-index:1;
  display:grid;grid-template-columns:1.05fr 1fr;gap:64px;align-items:center;
  width:100%;
}
@media (max-width:960px){
  .fs-grid{grid-template-columns:1fr;gap:48px}
  .feature-single{min-height:0;padding-top:48px;padding-bottom:64px}
}
.fs-text .pill{
  display:inline-flex;align-items:center;gap:8px;
  padding:6px 14px;border-radius:999px;
  background:var(--teal-pale);color:var(--teal-deep);
  font-size:.78rem;font-weight:600;letter-spacing:.06em;text-transform:uppercase;
  margin-bottom:20px;
}
.fs-text h1{font-size:clamp(2rem,4.4vw,3.2rem);margin-bottom:20px}
.fs-text .lede{font-size:1.12rem;line-height:1.6;color:var(--ink-soft);margin-bottom:24px;max-width:540px}
.fs-text ul{list-style:none;margin:0 0 32px}
.fs-text ul li{
  padding:8px 0;display:flex;align-items:flex-start;gap:12px;
  font-size:.98rem;color:var(--ink);
}
.fs-text ul li .check{margin-top:3px}
.fs-ctas{display:flex;gap:12px;flex-wrap:wrap}

.fs-visual{
  position:relative;border-radius:var(--radius-lg);
  padding:48px;min-height:440px;
  display:flex;align-items:center;justify-content:center;
  overflow:hidden;
  box-shadow:var(--shadow-md);
}

/* Browser-frame mock for the Website page */
.mock-browser{
  background:white;border-radius:12px;
  box-shadow:var(--shadow-lg);
  width:100%;max-width:420px;
  overflow:hidden;
}
.mock-browser .bar{
  background:var(--cream-2);padding:10px 14px;
  display:flex;align-items:center;gap:6px;
  border-bottom:1px solid var(--line);
}
.mock-browser .bar .dot{width:10px;height:10px;border-radius:50%;background:var(--line)}
.mock-browser .bar .url{
  flex:1;background:white;border-radius:6px;
  padding:4px 10px;margin-left:10px;
  font-size:.7rem;color:var(--ink-soft);
}
.mock-browser .content{padding:0}
.mock-browser .hero-mock{
  background:linear-gradient(135deg, var(--teal) 0%, var(--teal-deep) 100%);
  padding:24px 22px;color:var(--cream);
}
.mock-browser .hero-mock h6{font-family:var(--serif);font-size:1.1rem;font-weight:600;line-height:1.2;margin-bottom:8px}
.mock-browser .hero-mock p{font-size:.78rem;color:rgba(251,247,240,0.85);margin-bottom:14px;line-height:1.5}
.mock-browser .hero-mock .btn-mock{
  display:inline-block;background:var(--cream);color:var(--ink);
  font-size:.72rem;font-weight:600;padding:8px 14px;border-radius:999px;
}
.mock-browser .body-mock{padding:18px 22px;background:white}
.mock-browser .row-mock{
  display:flex;align-items:center;justify-content:space-between;
  padding:10px 0;font-size:.78rem;color:var(--ink);
  border-bottom:1px solid var(--line);
}
.mock-browser .row-mock:last-child{border-bottom:none}
.mock-browser .row-mock .price-mock{color:var(--teal-deep);font-weight:600}

/* Big stars block for reviews page */
.mock-stars-big{
  background:white;border-radius:16px;padding:32px 28px;
  box-shadow:var(--shadow-lg);
  width:100%;max-width:340px;text-align:center;
}
.mock-stars-big .rating{
  font-family:var(--serif);font-size:4rem;font-weight:500;line-height:1;color:var(--ink);
}
.mock-stars-big .stars-big{color:var(--gold);font-size:1.6rem;letter-spacing:4px;margin:10px 0}
.mock-stars-big .meta{font-size:.85rem;color:var(--ink-soft);font-weight:500}
.mock-stars-big .trend{
  margin-top:18px;padding-top:18px;border-top:1px solid var(--line);
  display:flex;justify-content:space-between;align-items:center;font-size:.82rem;color:var(--ink);
}
.mock-stars-big .trend .up{color:var(--teal-deep);font-weight:600}

/* Phone with notif stack for SMS-style features */
.mock-phone-stack{
  position:relative;width:280px;
}
.mock-phone-stack .phone-frame{
  background:var(--ink);border-radius:36px;padding:10px;
  box-shadow:var(--shadow-lg);
}
.mock-phone-stack .phone-inner{
  background:var(--cream);border-radius:28px;
  padding:42px 16px 20px;min-height:420px;
}
.mock-phone-stack .pf-notch{
  position:absolute;top:18px;left:50%;transform:translateX(-50%);
  width:80px;height:20px;background:var(--ink);border-radius:0 0 12px 12px;z-index:2;
}

/* Calendar mini for booking page */
.mock-calendar{
  background:white;border-radius:16px;padding:20px;
  box-shadow:var(--shadow-lg);
  width:100%;max-width:320px;
}
.mock-cal-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:14px}
.mock-cal-head h6{font-family:var(--serif);font-size:1rem;font-weight:600}
.mock-cal-head .nav-arrows{display:flex;gap:4px}
.mock-cal-head .nav-arrows span{
  width:24px;height:24px;border-radius:6px;background:var(--cream-2);
  display:grid;place-items:center;font-size:.7rem;color:var(--ink-soft);
}
.mock-cal-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:4px}
.mock-cal-grid .day-label{font-size:.65rem;color:var(--ink-soft);text-align:center;padding:4px 0;font-weight:600}
.mock-cal-grid .day{
  font-size:.78rem;text-align:center;padding:8px 0;border-radius:6px;color:var(--ink);
}
.mock-cal-grid .day.muted{color:var(--ink-soft);opacity:.4}
.mock-cal-grid .day.booked{background:var(--cream-2);color:var(--ink-soft);text-decoration:line-through}
.mock-cal-grid .day.avail{background:var(--teal-pale);color:var(--teal-deep);font-weight:600}
.mock-cal-grid .day.selected{background:var(--teal);color:var(--cream);font-weight:600}
.mock-cal-foot{
  margin-top:14px;padding-top:14px;border-top:1px solid var(--line);
  font-size:.8rem;color:var(--ink);display:flex;justify-content:space-between;
}
.mock-cal-foot strong{color:var(--teal-deep);font-weight:600}

/* Missed call card */
.mock-missed{
  background:white;border-radius:18px;padding:22px;
  box-shadow:var(--shadow-lg);
  width:100%;max-width:320px;
}
.mock-missed .top{
  display:flex;align-items:center;gap:12px;
  padding-bottom:14px;margin-bottom:14px;border-bottom:1px solid var(--line);
}
.mock-missed .top .av{
  width:42px;height:42px;border-radius:50%;
  background:var(--cream-2);color:var(--ink-soft);
  display:grid;place-items:center;flex-shrink:0;
}
.mock-missed .top .info strong{display:block;font-size:.9rem;color:var(--ink);font-weight:600}
.mock-missed .top .info span{display:block;font-size:.75rem;color:var(--rust);font-weight:600;margin-top:2px}
.mock-missed .arrow-down{
  text-align:center;color:var(--ink-soft);font-size:.7rem;letter-spacing:.1em;
  margin:4px 0;text-transform:uppercase;font-weight:600;
}
.mock-missed .auto-sms{
  background:var(--teal);color:var(--cream);border-radius:14px 14px 4px 14px;
  padding:12px 14px;font-size:.85rem;line-height:1.45;margin-left:auto;max-width:90%;
}
.mock-missed .timestamp{
  text-align:right;font-size:.65rem;color:var(--ink-soft);
  margin-top:6px;font-weight:600;
}

.text-center{text-align:center}
.mt-32{margin-top:32px}
.mt-48{margin-top:48px}

/* =========================================================
   BOOK A DEMO PAGE
   ========================================================= */

.demo-section{padding:40px 0 100px;position:relative}
.demo-grid{
  display:grid;grid-template-columns:1fr 1.15fr;gap:48px;
  max-width:1100px;margin:0 auto;align-items:start;
}
@media (max-width:960px){.demo-grid{grid-template-columns:1fr;gap:40px}}

.demo-info h2{font-size:1.6rem;margin-bottom:20px;font-weight:600}

.expect-list{list-style:none;margin:0 0 36px}
.expect-list li{
  display:flex;align-items:flex-start;gap:16px;
  padding:14px 0;border-bottom:1px solid var(--line);
}
.expect-list li:last-child{border-bottom:none}
.expect-num{
  width:32px;height:32px;border-radius:9px;flex-shrink:0;
  background:var(--ink);color:var(--cream);
  display:grid;place-items:center;
  font-family:var(--serif);font-size:.95rem;font-weight:500;
}
.expect-list li:nth-child(2) .expect-num{background:var(--teal)}
.expect-list li:nth-child(3) .expect-num{background:var(--gold);color:var(--ink)}
.expect-list li:nth-child(4) .expect-num{background:var(--rust)}
.expect-text strong{display:block;font-size:1rem;color:var(--ink);font-weight:600;margin-bottom:2px}
.expect-text span{display:block;font-size:.92rem;color:var(--ink-soft);line-height:1.5}

.demo-testimonial{
  background:var(--cream-2);border:1px solid var(--line);
  border-radius:var(--radius-lg);padding:28px 32px;
  position:relative;
}
.demo-testimonial::before{
  content:'"';position:absolute;top:8px;left:20px;
  font-family:var(--serif);font-size:4rem;color:var(--teal);
  opacity:.25;line-height:1;font-style:italic;
}
.demo-testimonial blockquote{
  font-family:var(--serif);font-size:1.1rem;line-height:1.5;
  color:var(--ink);font-weight:500;margin:0 0 16px;
  font-style:italic;
}
.demo-testimonial .author{display:flex;align-items:center;gap:12px}
.demo-testimonial .author-av{
  width:40px;height:40px;border-radius:50%;flex-shrink:0;
  background:linear-gradient(135deg,var(--teal),var(--teal-deep));
  color:var(--cream);
  display:grid;place-items:center;
  font-family:var(--serif);font-weight:600;font-size:1rem;
}
.demo-testimonial .author-meta strong{display:block;font-size:.92rem;color:var(--ink);font-weight:600}
.demo-testimonial .author-meta span{display:block;font-size:.82rem;color:var(--ink-soft);margin-top:1px}

.calendar-card{
  background:var(--cream);border:1px solid var(--line);
  border-radius:var(--radius-lg);padding:0;
  box-shadow:var(--shadow-md);
  overflow:hidden;position:sticky;top:100px;
}
@media (max-width:960px){.calendar-card{position:static}}
.calendar-head{
  padding:24px 28px;border-bottom:1px solid var(--line);
  background:var(--cream-2);
}
.calendar-head h3{font-family:var(--serif);font-size:1.25rem;font-weight:600;margin-bottom:4px}
.calendar-head p{font-size:.92rem;color:var(--ink-soft);margin:0}
.calendar-head .duration{
  display:inline-flex;align-items:center;gap:6px;
  margin-top:10px;font-size:.82rem;color:var(--teal-deep);font-weight:600;
}

.calendar-iframe-wrap{
  position:relative;
  min-height:560px;
  background:var(--cream-2);
}
.calendar-iframe-wrap iframe{
  width:100%;min-height:560px;border:none;display:block;
}
.calendar-placeholder{
  position:absolute;inset:0;display:flex;flex-direction:column;
  align-items:center;justify-content:center;text-align:center;
  padding:40px 32px;
  background:
    repeating-linear-gradient(45deg, var(--cream) 0 10px, var(--cream-2) 10px 20px);
}
.calendar-placeholder .pl-icon{
  width:64px;height:64px;border-radius:18px;
  background:var(--cream);border:2px dashed var(--line);
  display:grid;place-items:center;margin-bottom:20px;color:var(--ink-soft);
}
.calendar-placeholder h4{
  font-family:var(--serif);font-size:1.2rem;font-weight:600;
  color:var(--ink);margin-bottom:8px;
}
.calendar-placeholder p{
  font-size:.92rem;color:var(--ink-soft);max-width:340px;line-height:1.55;margin:0;
}
.calendar-placeholder code{
  display:inline-block;margin-top:14px;
  font-family:ui-monospace,Menlo,monospace;font-size:.78rem;
  background:var(--cream);padding:6px 10px;border-radius:6px;
  color:var(--teal-deep);border:1px solid var(--line);
}

/* Alternative ways strip */
.demo-alt{
  background:var(--cream-2);padding:60px 0;text-align:center;
}
.demo-alt h3{font-size:1.5rem;margin-bottom:8px;font-weight:600}
.demo-alt p{font-size:1rem;margin-bottom:28px;color:var(--ink-soft);max-width:520px;margin-left:auto;margin-right:auto}
.demo-alt-ctas{display:flex;gap:14px;justify-content:center;flex-wrap:wrap}
