/* ============================================================
   Phone A Mummy UK - Consolidated Stylesheet
   Source: pam-uk-nursery.html (canonical), plus all page mockups
   ============================================================ */

/* ============================================================
   1. CSS Custom Properties
   ============================================================ */
:root {
  --wisteria: #8B6BB0;
  --wisteria-dk: #6B4B90;
  --wisteria-lt: #C0A8D8;
  --wisteria-pale: #EDE4F5;
  --petal: #E8B0C0;
  --petal-dk: #D08898;
  --petal-lt: #F8D8E0;
  --sky: #B8D0E8;
  --leaf: #7CAA80;
  --cream: #FEFBF5;
  --warm: #F8F4EC;
  --text: #2C2038;
  --text-mid: #5C5068;
  --text-lt: #A098A8;
  --white: #FFF;
}

/* ============================================================
   2. Reset & Base Typography
   ============================================================ */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

body { font-family: 'Outfit', sans-serif; color: var(--text); background: var(--cream); line-height: 1.7; }
h1, h2, h3 { font-family: 'Sorts Mill Goudy', serif; line-height: 1.3; }
a { color: var(--wisteria); }

/* ============================================================
   3. UK Banner
   ============================================================ */
.uk-banner { background: linear-gradient(135deg, var(--wisteria-dk), var(--wisteria)); color: var(--white); text-align: center; padding: 10px 20px; font-size: 13px; font-weight: 500; letter-spacing: 0.5px; }
.uk-banner .flag { margin: 0 6px; font-size: 15px; }

/* ============================================================
   4. Sticky Nav + Dropdown
   ============================================================ */
.nav-wrap { padding: 16px 48px; position: sticky; top: 0; z-index: 100; background: rgba(254,251,245,0.95); backdrop-filter: blur(12px); box-shadow: 0 4px 12px rgba(44,32,56,0.12), 0 2px 4px rgba(0,0,0,0.06); }
.nav-inner { display: flex; align-items: center; justify-content: space-between; max-width: 1200px; margin: 0 auto; }
.nav-brand { font-family: 'Sorts Mill Goudy', serif; font-size: 24px; color: var(--wisteria-dk); text-decoration: none; }
.nav-brand em { color: var(--petal-dk); font-style: italic; }
.nav-links { display: flex; gap: 28px; align-items: center; }
.nav-links > a { text-decoration: none; color: var(--text-mid); font-weight: 500; font-size: 15px; transition: color 0.2s; }
.nav-links > a:hover { color: var(--wisteria); }
.nav-links > a.active { color: var(--wisteria); font-weight: 600; }
.nav-cta { background: linear-gradient(135deg, var(--wisteria), var(--petal-dk)); color: var(--white); padding: 10px 24px; border-radius: 999px; font-weight: 600; font-size: 14px; text-decoration: none; transition: all 0.2s; }
.nav-cta:hover { transform: translateY(-2px); box-shadow: 0 6px 20px rgba(139,107,176,0.3); }

/* Nav Dropdown */
.nav-dropdown { position: relative; }
.nav-dropdown > a { text-decoration: none; color: var(--text-mid); font-weight: 500; font-size: 15px; transition: color 0.2s; cursor: pointer; }
.nav-dropdown > a:hover { color: var(--wisteria); }
.nav-dropdown > a.active { color: var(--wisteria); font-weight: 600; }
.dropdown-menu { display: none; position: absolute; top: calc(100% + 8px); left: -12px; background: var(--white); border-radius: 12px; box-shadow: 0 4px 20px rgba(44,32,56,0.14); padding: 8px 0; min-width: 170px; z-index: 200; }
.dropdown-menu a { display: block; padding: 9px 20px; font-size: 14px; color: var(--text-mid); text-decoration: none; font-weight: 500; transition: all 0.15s; }
.dropdown-menu a:hover { background: var(--wisteria-pale); color: var(--wisteria-dk); }
.nav-dropdown:hover .dropdown-menu { display: block; }

/* ============================================================
   5. Page Headers (shared .page-header + variants)
   ============================================================ */
/* Standard page header (how-to-call, faqs canonical version) */
.page-header { background-color: #2A1845; background-image: linear-gradient(135deg, #1E0F35 0%, #2A1845 30%, #3D2860 60%, #4A2E6E 100%); padding: 64px 48px 60px; text-align: center; position: relative; overflow: hidden; }
.page-header::before { content: ''; position: absolute; top: -100px; right: -100px; width: 400px; height: 400px; background: radial-gradient(circle, rgba(255,255,255,0.06) 0%, transparent 70%); }
.page-header::after { content: ''; position: absolute; bottom: -80px; left: -80px; width: 300px; height: 300px; background: radial-gradient(circle, rgba(208,136,152,0.1) 0%, transparent 70%); }
.page-header h1 { font-size: 48px; color: var(--white); margin-bottom: 12px; position: relative; z-index: 1; }
.page-header h1 .accent { color: var(--wisteria-lt); }
.page-header p { font-size: 18px; color: rgba(255,255,255,0.75); max-width: 560px; margin: 0 auto; position: relative; z-index: 1; }
.page-header .badge { display: inline-block; background: rgba(255,255,255,0.12); color: var(--wisteria-lt); padding: 8px 20px; border-radius: 999px; font-size: 13px; font-weight: 600; margin-bottom: 20px; position: relative; z-index: 1; }

/* Page Hero (blog archive) */
.page-hero { background: linear-gradient(135deg, #3D2260 0%, var(--wisteria-dk) 40%, var(--wisteria) 70%, var(--petal-dk) 100%); padding: 80px 48px 70px; text-align: center; position: relative; overflow: hidden; }
.page-hero::before { content: ''; position: absolute; top: -100px; right: -100px; width: 400px; height: 400px; background: radial-gradient(circle, rgba(255,255,255,0.06) 0%, transparent 70%); }
.page-hero::after { content: ''; position: absolute; bottom: -80px; left: -80px; width: 300px; height: 300px; background: radial-gradient(circle, rgba(255,255,255,0.04) 0%, transparent 70%); }
.page-hero h1 { font-size: 52px; color: var(--white); margin-bottom: 12px; position: relative; z-index: 1; }
.page-hero p { font-size: 19px; color: rgba(255,255,255,0.8); position: relative; z-index: 1; max-width: 500px; margin: 0 auto; }

/* Decorative wisteria petals in hero */
.hero-petal { position: absolute; opacity: 0.12; z-index: 0; }
.hero-petal-1 { top: 20px; left: 8%; font-size: 60px; transform: rotate(-15deg); }
.hero-petal-2 { bottom: 15px; right: 10%; font-size: 48px; transform: rotate(20deg); }
.hero-petal-3 { top: 50%; left: 3%; font-size: 36px; transform: rotate(-30deg); }
.hero-petal-4 { top: 30%; right: 5%; font-size: 44px; transform: rotate(10deg); }

/* ============================================================
   6. Hero (homepage-specific)
   ============================================================ */
.hero-bg { background: var(--cream); }
.hero { padding: 44px 48px 48px; max-width: 1200px; margin: 0 auto; text-align: center; }
.hero-badge { display: inline-block; background: var(--wisteria-pale); color: var(--wisteria-dk); padding: 8px 20px; border-radius: 999px; font-size: 13px; font-weight: 600; margin-bottom: 16px; }
.hero h1 { font-size: 54px; color: var(--text); margin-bottom: 14px; }
.hero h1 .accent { color: var(--wisteria); }
.hero h1 .petal { color: var(--petal-dk); }
.hero > p { font-size: 20px; color: var(--text-mid); max-width: 620px; margin: 0 auto 24px; }
.hero-actions { display: flex; gap: 16px; justify-content: center; flex-wrap: wrap; }

/* ============================================================
   7. Notebook Paper Girls Section (homepage)
   ============================================================ */
.garden-strip { padding: 20px 24px 24px; position: relative; overflow: hidden; background: #FFFEF8; background-image: repeating-linear-gradient(transparent, transparent 23px, #D6E4F0 23px, #D6E4F0 24px); box-shadow: inset 0 2px 8px rgba(0,0,0,0.06), 0 6px 20px rgba(0,0,0,0.1), 0 2px 6px rgba(0,0,0,0.06); }
.garden-strip::before { content: ''; position: absolute; top: 0; left: 40px; width: 2px; height: 100%; background: #F0B0B0; opacity: 0.4; }
.garden-strip::after { content: ''; position: absolute; top: 0; left: 42px; width: 2px; height: 100%; background: #F0B0B0; opacity: 0.25; }

/* Crayon doodles layer */
.garden-doodles { position: absolute; top: 0; left: 0; right: 0; bottom: 0; pointer-events: none; overflow: hidden; z-index: 0; }
.garden-doodles svg { width: 100%; height: 100%; }
.garden-title { text-align: center; margin-bottom: 10px; position: relative; z-index: 1; }
.garden-title .crayon-love { font-family: 'Comic Sans MS', 'Marker Felt', cursive; font-size: 42px; font-weight: bold; color: #E06878; transform: rotate(-2deg); display: block; margin-bottom: -2px; letter-spacing: 2px; filter: url(#crayon); text-shadow: 1px 1px 0 rgba(224,104,120,0.15); }
.garden-title .crayon-love span { color: #60A0D0; text-shadow: 1px 1px 0 rgba(96,160,208,0.15); }
.garden-title h2 { font-size: 28px; margin-bottom: 2px; color: var(--text); }
.garden-title p { font-size: 14px; color: var(--text-mid); }
.garden-cards { display: grid; grid-template-columns: repeat(4, 1fr); gap: 20px; max-width: 1100px; margin: 0 auto; position: relative; z-index: 1; }

.see-all { text-align: center; margin-top: 28px; position: relative; z-index: 1; }
.see-all a { display: inline-flex; align-items: center; gap: 8px; font-size: 15px; font-weight: 600; color: var(--wisteria-dk); text-decoration: none; padding: 10px 24px; border-radius: 999px; border: 1px solid var(--wisteria-lt); transition: all 0.2s; }
.see-all a:hover { background: var(--wisteria-pale); }

/* ============================================================
   8. Girl Cards (.g-card - shared component)
   ============================================================ */
/* Homepage card style (canonical - with 3D shadow for notebook context) */
.g-card { background: var(--white); border-radius: 14px; overflow: hidden; text-decoration: none; color: inherit; display: flex; flex-direction: column; transition: transform 0.25s, box-shadow 0.25s; box-shadow: 0 2px 4px rgba(0,0,0,0.08), 0 6px 16px rgba(0,0,0,0.1), 0 12px 28px rgba(0,0,0,0.06), 0 1px 0 0 rgba(0,0,0,0.03); }
.g-card:hover { transform: translateY(-8px); box-shadow: 0 8px 20px rgba(0,0,0,0.12), 0 18px 40px rgba(0,0,0,0.14), 0 24px 56px rgba(0,0,0,0.06), 0 1px 0 0 rgba(0,0,0,0.03); }
.g-card:hover .photo { transform: scale(1.04); }

/* Photo */
.g-card .photo-wrap { overflow: hidden; height: 280px; position: relative; border-radius: 14px 14px 0 0; }
.g-card .photo { width: 100%; height: 100%; object-fit: cover; object-position: center 15%; display: block; transition: transform 0.5s; }

/* Online status pill (homepage variant) */
.g-card .status { position: absolute; top: 12px; left: 12px; display: inline-flex; align-items: center; gap: 5px; background: rgba(255,255,255,0.95); backdrop-filter: blur(4px); padding: 4px 10px 4px 7px; border-radius: 999px; font-size: 11px; font-weight: 600; color: #16a34a; z-index: 1; }
.g-card .status .dot { width: 7px; height: 7px; background: #22c55e; border-radius: 50%; flex-shrink: 0; }

/* Online chip (archive variant) */
.g-card .online { position: absolute; top: 10px; right: 10px; display: inline-flex; align-items: center; gap: 5px; background: rgba(255,255,255,0.9); backdrop-filter: blur(6px); padding: 3px 9px; border-radius: 4px; font-size: 11px; font-weight: 700; letter-spacing: 0.5px; color: #16a34a; z-index: 2; }
.g-card .online .dot { width: 7px; height: 7px; background: #16a34a; border-radius: 50%; flex-shrink: 0; }

/* Card Info (homepage variant) */
.g-card .info { padding: 12px 16px 14px; flex: 1; display: flex; flex-direction: column; }
.g-card .info h3 { font-size: 19px; margin-bottom: 2px; }
.g-card .info .role { font-size: 13px; color: var(--wisteria); font-weight: 500; margin-bottom: 6px; }
.g-card .info .desc { font-size: 13.5px; color: var(--text-mid); line-height: 1.55; flex: 1; }
.g-card .info .meta { display: flex; align-items: center; justify-content: space-between; margin-top: 10px; padding-top: 8px; border-top: 1px solid rgba(0,0,0,0.05); }
.g-card .info .meta .specs { font-size: 12px; color: var(--text-lt); }
.g-card .info .meta .link { font-size: 13px; font-weight: 600; color: var(--wisteria-dk); }

/* Card Body (archive variant) */
.g-card .card-body { padding: 16px; flex: 1; display: flex; flex-direction: column; }
.g-card .card-body::before { content: ''; position: absolute; top: -30px; left: 0; right: 0; height: 30px; background: linear-gradient(to top, white, transparent); pointer-events: none; }
.g-card h3 { font-size: 18px; margin-bottom: 2px; }
.g-card .role { font-size: 11px; color: var(--wisteria); font-weight: 600; text-transform: uppercase; letter-spacing: 1px; margin-bottom: 6px; }
.g-card .tagline { font-size: 13px; color: var(--text-mid); line-height: 1.5; margin-bottom: 12px; flex: 1; }

/* Specialty tags (archive) */
.g-card .tags { display: flex; flex-wrap: wrap; gap: 4px; margin-bottom: 0; }
.g-card .tag { font-size: 10px; font-weight: 600; padding: 3px 8px; border-radius: 4px; background: rgba(139,107,176,0.08); color: var(--wisteria-dk); letter-spacing: 0.3px; }

/* Card CTA button (profile more-mummies variant) */
.g-card .card-cta { display: inline-flex; align-items: center; gap: 6px; font-size: 12px; font-weight: 600; color: var(--white); background: linear-gradient(135deg, var(--wisteria), var(--petal-dk)); text-decoration: none; padding: 6px 16px; border-radius: 999px; transition: all 0.2s; box-shadow: 0 2px 0 1px rgba(107,75,144,0.3), 0 4px 8px rgba(44,32,56,0.2); position: relative; z-index: 3; }
.g-card .card-cta:hover { box-shadow: 0 2px 0 1px rgba(107,75,144,0.3), 0 6px 16px rgba(139,107,176,0.5); transform: translateY(-2px); }

/* Card ::after gloss (profile more-mummies variant) */
.g-card::after { display: none; }

/* ============================================================
   9. Girls Grid & Filter Bar (archive page)
   ============================================================ */
/* Filter Tabs (mummys archive) */
.filter-bar { background: var(--warm); padding: 20px 48px; border-bottom: 1px solid rgba(139,107,176,0.08); }
.filter-inner { max-width: 1200px; margin: 0 auto; display: flex; gap: 12px; justify-content: center; flex-wrap: wrap; }
.filter-btn { padding: 8px 20px; border-radius: 999px; border: 2px solid var(--wisteria-lt); background: transparent; color: var(--text-mid); font-weight: 600; font-size: 13px; cursor: pointer; transition: all 0.2s; font-family: 'Outfit', sans-serif; }
.filter-btn:hover, .filter-btn.active { background: var(--wisteria); color: var(--white); border-color: var(--wisteria); }

/* Blog filter bar variant */
.filter-bar.blog-filter { padding: 28px 48px; background: var(--white); border-bottom: 1px solid var(--wisteria-pale); }
.filter-pill { padding: 8px 22px; border-radius: 999px; font-size: 14px; font-weight: 500; text-decoration: none; color: var(--text-mid); background: var(--warm); border: 1px solid transparent; transition: all 0.2s; cursor: pointer; }
.filter-pill:hover { color: var(--wisteria-dk); background: var(--wisteria-pale); }
.filter-pill.active { color: var(--white); background: linear-gradient(135deg, var(--wisteria), var(--petal-dk)); border-color: transparent; }

/* Girls Grid (archive) */
.girls-section { padding: 48px; max-width: 1200px; margin: 0 auto; }
.girls-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 24px; }

/* ============================================================
   10. Profile Page (single-mummy.php styles)
   ============================================================ */
/* Profile Header */
.profile-header { background: linear-gradient(135deg, var(--wisteria-dk) 0%, #5A3D7A 100%); padding: 48px 48px 52px; text-align: center; }
.profile-header h1 { font-size: 44px; color: var(--white); margin-bottom: 8px; }
.profile-header .role-tag { display: inline-block; background: rgba(255,255,255,0.15); color: var(--wisteria-lt); padding: 6px 20px; border-radius: 999px; font-size: 14px; font-weight: 600; letter-spacing: 1px; text-transform: uppercase; }

/* Profile Content */
.profile-wrap { max-width: 1100px; margin: -32px auto 0; padding: 0 48px 60px; position: relative; z-index: 2; }
.profile-grid { display: grid; grid-template-columns: 400px 1fr; gap: 40px; align-items: start; }
.profile-photo { border-radius: 20px; overflow: hidden; box-shadow: 0 8px 32px rgba(44,32,56,0.2); }
.profile-photo img { width: 100%; height: auto; display: block; }

.profile-details { padding-top: 40px; }
.profile-details h2 { font-size: 32px; margin-bottom: 16px; color: var(--wisteria-dk); }

/* Measurements Box */
.measurements { background: var(--wisteria-pale); border-radius: 16px; padding: 24px 28px; margin-bottom: 28px; backdrop-filter: blur(8px); }
.measurements h3 { font-size: 18px; color: var(--wisteria-dk); margin-bottom: 14px; }
.meas-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 10px 24px; }
.meas-item { display: flex; justify-content: space-between; font-size: 15px; padding: 6px 0; border-bottom: 1px solid rgba(139,107,176,0.12); }
.meas-item .label { color: var(--text-mid); font-weight: 500; }
.meas-item .value { color: var(--text); font-weight: 600; }

/* Specialties Tags (profile page) */
.specialties { margin-bottom: 28px; }
.specialties h3 { font-size: 18px; color: var(--wisteria-dk); margin-bottom: 12px; }
.tag-list { display: flex; flex-wrap: wrap; gap: 8px; }
.tag { display: inline-block; background: var(--white); border: 1.5px solid var(--wisteria-lt); color: var(--wisteria-dk); padding: 6px 16px; border-radius: 999px; font-size: 13px; font-weight: 600; transition: all 0.2s; }
.tag:hover { background: var(--wisteria-pale); border-color: var(--wisteria); }

/* Bio (full width below grid) */
.bio { margin-top: 40px; padding-top: 36px; border-top: 2px solid var(--wisteria-pale); }
.bio h3 { font-size: 24px; color: var(--wisteria-dk); margin-bottom: 16px; }
.bio p { font-size: 16px; color: var(--text-mid); margin-bottom: 16px; line-height: 1.8; }

/* Photo Gallery */
.mummy-gallery { margin-top: 48px; padding-top: 40px; border-top: 2px solid var(--wisteria-pale); }
.mummy-gallery h2 { font-size: 28px; color: var(--wisteria-dk); margin-bottom: 24px; text-align: center; }
.gallery-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 20px; }
.gallery-item { border-radius: 16px; overflow: hidden; box-shadow: 0 4px 20px rgba(44,32,56,0.15); transition: transform 0.3s, box-shadow 0.3s; }
.gallery-item:hover { transform: translateY(-4px); box-shadow: 0 8px 32px rgba(44,32,56,0.25); }
.gallery-item img { width: 100%; height: 320px; object-fit: cover; object-position: center 20%; display: block; }

/* Contact Section */
.contact-section { margin-top: 48px; padding: 40px; background: var(--wisteria-pale); border-radius: 20px; text-align: center; }
.contact-section h2 { font-size: 26px; color: var(--wisteria-dk); margin-bottom: 8px; }
.contact-section > p { font-size: 16px; color: var(--text-mid); margin-bottom: 24px; }
.contact-section form { max-width: 500px; margin: 0 auto; text-align: left; }
.contact-section form input,
.contact-section form textarea { width: 100%; box-sizing: border-box; padding: 12px 16px; border: 1.5px solid rgba(139,107,176,0.3); border-radius: 10px; font-size: 15px; font-family: inherit; margin-bottom: 14px; transition: border-color 0.2s; }
.contact-section form input:focus,
.contact-section form textarea:focus { outline: none; border-color: var(--wisteria); box-shadow: 0 0 0 3px rgba(139,107,176,0.15); }
.contact-section form button,
.contact-section form input[type="submit"] { display: block; width: 100%; background: linear-gradient(135deg, var(--wisteria), var(--petal-dk)); color: var(--white); border: none; padding: 14px 24px; border-radius: 999px; font-size: 16px; font-weight: 700; cursor: pointer; transition: all 0.2s; }
.contact-section form button:hover,
.contact-section form input[type="submit"]:hover { transform: translateY(-2px); box-shadow: 0 6px 20px rgba(139,107,176,0.35); }

/* Ring CTA Wrap */
.ring-cta-wrap { text-align: center; margin-top: 36px; margin-bottom: 12px; }

/* Ring CTA */
.ring-cta { display: inline-flex; align-items: center; gap: 10px; background: linear-gradient(135deg, var(--wisteria), var(--petal-dk)); color: var(--white); padding: 16px 36px; border-radius: 999px; font-weight: 700; font-size: 18px; text-decoration: none; transition: all 0.2s; box-shadow: 0 4px 16px rgba(139,107,176,0.3); }
.ring-cta:hover { transform: translateY(-3px); box-shadow: 0 8px 28px rgba(139,107,176,0.4); color: var(--white); }

/* More Mummies Section */
.more-section { background: linear-gradient(180deg, #5A3D7A 0%, #6B4B90 50%, #5A3D7A 100%); padding: 48px 48px 56px; }
.more-section .section-title { text-align: center; margin-bottom: 32px; }
.more-section .section-title h2 { font-size: 32px; color: var(--white); margin-bottom: 8px; }
.more-section .section-title p { font-size: 16px; color: rgba(255,255,255,0.7); }
.more-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 16px; max-width: 1100px; margin: 0 auto; }

/* Profile more-mummies card overrides (3D toy-box shadow) */
.more-section .g-card { background: var(--white); border-radius: 16px; overflow: hidden; box-shadow: 0 2px 0 2px rgba(90,61,122,0.2), 0 6px 0 3px rgba(44,32,56,0.1), 0 12px 24px rgba(44,32,56,0.3), 0 24px 48px rgba(107,75,144,0.15); text-align: center; transition: all 0.3s; cursor: pointer; position: relative; text-decoration: none; display: block; color: var(--text); }
.more-section .g-card:hover { transform: translateY(-8px) scale(1.04); box-shadow: 0 2px 0 2px rgba(90,61,122,0.2), 0 6px 0 3px rgba(44,32,56,0.1), 0 18px 36px rgba(44,32,56,0.4), 0 32px 60px rgba(107,75,144,0.2); }
.more-section .g-card:hover .photo { transform: scale(1.05); }
.more-section .g-card .photo { width: 100%; height: 280px; object-fit: cover; object-position: center 15%; display: block; transition: transform 0.4s; }
.more-section .g-card .card-body { padding: 14px 16px 16px; position: relative; }
.more-section .g-card h3 { font-size: 18px; margin-bottom: 2px; }
.more-section .g-card .role { font-size: 11px; color: var(--wisteria); font-weight: 600; text-transform: uppercase; letter-spacing: 1px; margin-bottom: 6px; }

/* ============================================================
   11. Steps Section (3-step with SVG orbs)
   ============================================================ */
.steps-section { padding: 80px 48px 40px; max-width: 1200px; margin: 0 auto; }
.steps-title { text-align: center; margin-bottom: 56px; }
.steps-title h2 { font-size: 38px; margin-bottom: 12px; }
.steps-title p { font-size: 17px; color: var(--text-mid); }
.steps-wrapper { position: relative; }
.steps-connector { position: absolute; top: 110px; left: 50%; transform: translateX(-50%); width: 70%; height: 4px; z-index: 0; }
.steps-connector svg { width: 100%; height: 40px; overflow: visible; }
.steps-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 40px; position: relative; z-index: 1; }
.step-card { text-align: center; position: relative; }
.step-illust { width: 200px; height: 200px; border-radius: 50%; margin: 0 auto 24px; display: flex; align-items: center; justify-content: center; position: relative; border: 4px solid rgba(255,255,255,0.8); box-shadow: 0 2px 0 2px rgba(139,107,176,0.2), 0 6px 0 3px rgba(44,32,56,0.08), 0 12px 24px rgba(44,32,56,0.2), 0 24px 48px rgba(139,107,176,0.1), inset 0 -8px 20px rgba(44,32,56,0.12), inset 0 8px 16px rgba(255,255,255,0.35); overflow: hidden; transition: all 0.3s; }
.step-illust::before { content: ''; position: absolute; inset: -4px; border-radius: 50%; background: linear-gradient(145deg, rgba(255,255,255,0.5) 0%, transparent 40%, transparent 60%, rgba(44,32,56,0.1) 100%); z-index: 4; pointer-events: none; }
.step-illust::after { content: ''; position: absolute; top: 6px; left: 12%; width: 76%; height: 40%; background: linear-gradient(180deg, rgba(255,255,255,0.45) 0%, rgba(255,255,255,0.08) 50%, rgba(255,255,255,0) 100%); border-radius: 50%; pointer-events: none; z-index: 5; }
.step-illust:hover { box-shadow: 0 2px 0 2px rgba(139,107,176,0.2), 0 6px 0 3px rgba(44,32,56,0.08), 0 16px 32px rgba(44,32,56,0.3), 0 30px 60px rgba(139,107,176,0.14), inset 0 -8px 20px rgba(44,32,56,0.12), inset 0 8px 16px rgba(255,255,255,0.35); transform: translateY(-5px) scale(1.03); }
.step-card .step-num { position: absolute; top: 0; right: calc(50% - 130px); width: 48px; height: 48px; border-radius: 50%; background: linear-gradient(135deg, var(--wisteria), var(--petal)); color: var(--white); font-family: 'Sorts Mill Goudy', serif; font-size: 22px; display: flex; align-items: center; justify-content: center; font-weight: 700; box-shadow: 0 4px 16px rgba(139,107,176,0.3); z-index: 2; }
.step-card h3 { font-size: 22px; margin-bottom: 8px; color: var(--wisteria-dk); }
.step-card p { font-size: 15px; color: var(--text-mid); line-height: 1.7; max-width: 300px; margin: 0 auto; }

/* Step SVG illustrations */
.step-illust svg { width: 100%; height: 100%; }
.step-illust.step-choose { background: linear-gradient(135deg, #ede4f5, #f0d0e0); }
.step-illust.step-dial { background: linear-gradient(135deg, #e4d8f0, #ede4f5); }
.step-illust.step-enjoy { background: linear-gradient(135deg, #f0d0e0, #ede4f5); }

/* ============================================================
   12. Phone Bar
   ============================================================ */
.phone-bar { background: linear-gradient(135deg, #4888B8, #60A0D0); padding: 36px 48px; text-align: center; }
.phone-bar-inner { max-width: 800px; margin: 0 auto; }
.phone-bar .num { font-family: 'Sorts Mill Goudy', serif; font-size: 44px; color: var(--white); letter-spacing: 3px; margin-bottom: 8px; }
.phone-bar .note { color: rgba(255,255,255,0.7); font-size: 15px; }
.phone-bar .note strong { color: var(--white); }

/* ============================================================
   13. Services Grid
   ============================================================ */
.section { padding: 80px 48px; max-width: 1200px; margin: 0 auto; }
.section-title { text-align: center; margin-bottom: 40px; }
.section-title h2 { font-size: 36px; margin-bottom: 10px; }
.section-title p { font-size: 17px; color: var(--text-mid); }
.svc-list { display: grid; grid-template-columns: 1fr 1fr; gap: 20px; }
.svc-box { display: flex; background: var(--white); border-radius: 16px; overflow: hidden; box-shadow: 0 1px 3px rgba(0,0,0,0.04); transition: box-shadow 0.2s; }
.svc-box:hover { box-shadow: 0 4px 16px rgba(139,107,176,0.1); }
.svc-box .svc-img { width: 160px; min-height: 140px; object-fit: cover; flex-shrink: 0; }
.svc-box .svc-text { padding: 20px; }
.svc-box .svc-text h3 { font-size: 18px; margin-bottom: 6px; }
.svc-box .svc-text p { font-size: 14px; color: var(--text-mid); }

/* ============================================================
   14. Testimonial
   ============================================================ */
.test-bg { background: linear-gradient(135deg, var(--wisteria-pale), var(--petal-lt)); padding: 60px 48px; text-align: center; }
.test-inner { max-width: 700px; margin: 0 auto; }
.test-inner blockquote { font-family: 'Sorts Mill Goudy', serif; font-size: 22px; font-style: italic; color: var(--text); line-height: 1.6; margin-bottom: 16px; }
.test-inner cite { font-size: 14px; color: var(--text-mid); font-style: normal; }

/* About page testimonial variant */
.test-inner blockquote.about-quote { font-size: 24px; color: var(--wisteria-dk); }
.test-inner cite.about-cite { font-weight: 500; }

/* ============================================================
   15. Blog Cards
   ============================================================ */
/* Homepage blog */
.blog-bg { padding: 80px 48px; max-width: 1200px; margin: 0 auto; }
.blog-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 24px; }
.blog-card { background: var(--white); border-radius: 16px; overflow: hidden; box-shadow: 0 1px 3px rgba(0,0,0,0.04); transition: all 0.2s; }
.blog-card:hover { transform: translateY(-4px); box-shadow: 0 6px 20px rgba(139,107,176,0.1); }
.blog-card .blog-img { height: 180px; overflow: hidden; }
.blog-card .blog-img svg { width: 100%; height: 100%; display: block; transition: transform 0.4s; }
.blog-card:hover .blog-img svg { transform: scale(1.05); }
.blog-content { padding: 18px; }
.blog-content .cat { font-size: 11px; font-weight: 700; color: var(--wisteria); text-transform: uppercase; letter-spacing: 1px; margin-bottom: 6px; }
.blog-content h3 { font-size: 17px; margin: 8px 0 6px; color: var(--text); transition: color 0.2s; }
.blog-card:hover .blog-content h3 { color: var(--wisteria-dk); }
.blog-content p { font-size: 14px; color: var(--text-mid); line-height: 1.6; }
.blog-content .date { font-size: 12px; color: var(--text-lt); margin-top: 10px; }

/* Blog archive extras */
.blog-bg.archive { background: var(--warm); padding: 60px 48px 80px; }
.blog-bg.archive .blog-grid { gap: 28px; max-width: 1200px; margin: 0 auto; }
.blog-bg.archive .blog-card { border: 1px solid rgba(139,107,176,0.06); }
.blog-bg.archive .blog-card:hover { transform: translateY(-6px); box-shadow: 0 12px 36px rgba(139,107,176,0.12); }
.blog-bg.archive .blog-card .blog-img { height: 200px; position: relative; }
.blog-bg.archive .blog-content { padding: 24px; }
.blog-content .meta { display: flex; justify-content: space-between; align-items: center; margin-top: 16px; padding-top: 12px; border-top: 1px solid var(--wisteria-pale); }
.blog-content .author { font-size: 12px; color: var(--petal-dk); font-weight: 500; }

/* ============================================================
   16. Pricing (tiers, deals, specials, upsell)
   ============================================================ */
/* Pricing Tiers */
.pricing-section { padding: 60px 48px 40px; max-width: 1200px; margin: 0 auto; }
.pricing-intro { text-align: center; margin-bottom: 48px; }
.pricing-intro h2 { font-size: 36px; margin-bottom: 12px; }
.pricing-intro p { font-size: 17px; color: var(--text-mid); max-width: 600px; margin: 0 auto; }

.pricing-tiers { display: grid; grid-template-columns: repeat(3, 1fr); gap: 24px; margin-bottom: 60px; }

.tier-card { background: var(--white); border-radius: 20px; overflow: hidden; border: 1px solid var(--wisteria-pale); transition: all 0.3s; }
.tier-card:hover { border-color: var(--petal); box-shadow: 0 8px 32px rgba(139,107,176,0.12); transform: translateY(-4px); }
.tier-card.featured { border: 2px solid var(--wisteria); box-shadow: 0 4px 24px rgba(139,107,176,0.12); }
.tier-card.featured:hover { box-shadow: 0 8px 32px rgba(139,107,176,0.18); }

.tier-header { padding: 28px 24px 20px; text-align: center; }
.tier-header .tier-badge { display: inline-block; background: var(--wisteria-pale); color: var(--wisteria-dk); padding: 4px 14px; border-radius: 999px; font-size: 11px; font-weight: 700; text-transform: uppercase; letter-spacing: 1.5px; margin-bottom: 12px; }
.tier-card.featured .tier-badge { background: linear-gradient(135deg, var(--wisteria), var(--petal-dk)); color: var(--white); }
.tier-header h3 { font-size: 24px; margin-bottom: 8px; }
.tier-header .rate { font-size: 36px; font-family: 'Sorts Mill Goudy', serif; color: var(--wisteria-dk); }
.tier-header .rate small { font-size: 16px; color: var(--text-mid); font-family: 'Outfit', sans-serif; }

.tier-body { padding: 0 24px 28px; }
.tier-table { width: 100%; border-collapse: collapse; }
.tier-table th { font-size: 11px; text-transform: uppercase; letter-spacing: 1px; color: var(--text-lt); padding: 8px 0; border-bottom: 2px solid var(--wisteria-pale); text-align: left; }
.tier-table th:last-child { text-align: right; }
.tier-table td { padding: 7px 0; font-size: 14px; border-bottom: 1px solid rgba(139,107,176,0.06); }
.tier-table td:last-child { text-align: right; font-weight: 600; color: var(--wisteria-dk); }
.tier-table tr:last-child td { border-bottom: none; }
.tier-table tr:hover td { background: rgba(139,107,176,0.03); }

.tier-cta { display: block; text-align: center; margin: 20px 24px 24px; padding: 14px; background: linear-gradient(135deg, var(--wisteria), var(--petal-dk)); color: var(--white); border-radius: 999px; text-decoration: none; font-weight: 600; font-size: 15px; transition: all 0.2s; }
.tier-cta:hover { transform: translateY(-2px); box-shadow: 0 6px 20px rgba(139,107,176,0.3); }

/* Deals Section */
.deals-section { padding: 60px 48px; background: linear-gradient(135deg, var(--wisteria-pale), var(--petal-lt)); }
.deals-inner { max-width: 1200px; margin: 0 auto; }
.deals-title { text-align: center; margin-bottom: 40px; }
.deals-title h2 { font-size: 36px; margin-bottom: 8px; }
.deals-title p { font-size: 17px; color: var(--text-mid); }

.deals-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 24px; margin-bottom: 40px; }

.deal-card { background: var(--white); border-radius: 16px; padding: 28px 24px; text-align: center; border: 1px solid rgba(139,107,176,0.1); transition: all 0.3s; }
.deal-card:hover { transform: translateY(-4px); box-shadow: 0 8px 28px rgba(139,107,176,0.12); }
.deal-icon { font-size: 36px; margin-bottom: 12px; }
.deal-card h3 { font-size: 20px; margin-bottom: 8px; color: var(--wisteria-dk); }
.deal-card .deal-detail { font-size: 15px; color: var(--text-mid); line-height: 1.6; }
.deal-card .deal-price { font-family: 'Sorts Mill Goudy', serif; font-size: 28px; color: var(--petal-dk); margin: 12px 0 4px; }
.deal-card .deal-code { display: inline-block; background: var(--wisteria-pale); color: var(--wisteria-dk); padding: 4px 16px; border-radius: 999px; font-size: 13px; font-weight: 700; letter-spacing: 1px; margin-top: 8px; }

/* Upsell Table */
.upsell-section { padding: 0 48px 60px; background: linear-gradient(135deg, var(--wisteria-pale), var(--petal-lt)); }
.upsell-inner { max-width: 800px; margin: 0 auto; background: var(--white); border-radius: 20px; padding: 36px; border: 1px solid rgba(139,107,176,0.1); }
.upsell-inner h3 { font-size: 24px; text-align: center; margin-bottom: 6px; }
.upsell-inner .upsell-sub { text-align: center; font-size: 15px; color: var(--text-mid); margin-bottom: 24px; }
.upsell-inner .upsell-sub strong { color: var(--wisteria-dk); }
.upsell-table { width: 100%; border-collapse: collapse; }
.upsell-table th { font-size: 12px; text-transform: uppercase; letter-spacing: 1px; color: var(--text-lt); padding: 10px 12px; border-bottom: 2px solid var(--wisteria-pale); text-align: left; }
.upsell-table th:last-child { text-align: right; }
.upsell-table td { padding: 10px 12px; font-size: 15px; border-bottom: 1px solid rgba(139,107,176,0.06); }
.upsell-table td:last-child { text-align: right; font-weight: 600; color: var(--petal-dk); }
.upsell-table tr:last-child td { border-bottom: none; }
.upsell-table tr:hover td { background: rgba(139,107,176,0.03); }
.upsell-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 0; }
.upsell-grid .upsell-col:first-child { border-right: 1px solid var(--wisteria-pale); padding-right: 24px; }
.upsell-grid .upsell-col:last-child { padding-left: 24px; }

/* Special Rates */
.specials-section { padding: 60px 48px; max-width: 1200px; margin: 0 auto; }
.specials-title { text-align: center; margin-bottom: 40px; }
.specials-title h2 { font-size: 36px; margin-bottom: 8px; }
.specials-title p { font-size: 17px; color: var(--text-mid); }

.specials-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 20px; margin-bottom: 40px; }

.special-card { background: var(--white); border-radius: 16px; padding: 28px 24px; text-align: center; border: 2px solid var(--wisteria-pale); transition: all 0.3s; position: relative; overflow: hidden; }
.special-card::before { content: ''; position: absolute; top: 0; left: 0; right: 0; height: 4px; background: linear-gradient(135deg, var(--wisteria), var(--petal-dk)); }
.special-card:hover { border-color: var(--wisteria-lt); transform: translateY(-4px); box-shadow: 0 8px 28px rgba(139,107,176,0.1); }
.special-card h3 { font-size: 18px; margin-bottom: 8px; }
.special-card .special-price { font-family: 'Sorts Mill Goudy', serif; font-size: 32px; color: var(--wisteria-dk); margin: 8px 0; }
.special-card p { font-size: 14px; color: var(--text-mid); }
.special-card .tag { display: inline-block; background: linear-gradient(135deg, var(--wisteria), var(--petal-dk)); color: var(--white); padding: 4px 14px; border-radius: 999px; font-size: 11px; font-weight: 700; text-transform: uppercase; letter-spacing: 1px; margin-bottom: 12px; }

/* Custom Stories */
.stories-section { padding: 0 48px 60px; max-width: 1200px; margin: 0 auto; }
.stories-card { background: linear-gradient(135deg, #3A2555, var(--wisteria-dk)); border-radius: 20px; padding: 48px; display: flex; align-items: center; gap: 48px; color: var(--white); position: relative; overflow: hidden; }
.stories-card::before { content: ''; position: absolute; top: -60px; right: -60px; width: 200px; height: 200px; background: radial-gradient(circle, rgba(255,255,255,0.06) 0%, transparent 70%); }
.stories-card .stories-icon { font-size: 64px; flex-shrink: 0; }
.stories-card h3 { font-size: 28px; margin-bottom: 8px; }
.stories-card p { font-size: 16px; color: rgba(255,255,255,0.8); line-height: 1.7; margin-bottom: 16px; }
.stories-card .stories-price { font-family: 'Sorts Mill Goudy', serif; font-size: 36px; color: var(--petal-lt); }
.stories-card .stories-price small { font-size: 16px; font-family: 'Outfit', sans-serif; color: rgba(255,255,255,0.6); }

/* Billing Note */
.billing-note { padding: 40px 48px; text-align: center; background: var(--warm); }
.billing-inner { max-width: 600px; margin: 0 auto; background: var(--white); border-radius: 16px; padding: 28px 32px; border: 1px solid var(--wisteria-pale); display: flex; align-items: center; gap: 16px; }
.billing-inner .billing-icon { font-size: 32px; flex-shrink: 0; }
.billing-inner p { font-size: 15px; color: var(--text-mid); text-align: left; }
.billing-inner p strong { color: var(--text); }

/* ============================================================
   17. FAQ Accordion
   ============================================================ */
.faq-section { padding: 80px 48px; max-width: 900px; margin: 0 auto; }
.faq-title { text-align: center; margin-bottom: 48px; }
.faq-title h2 { font-size: 36px; margin-bottom: 12px; }
.faq-title p { font-size: 17px; color: var(--text-mid); }

/* How-to-call mini FAQ (non-accordion) */
.faq-list { display: flex; flex-direction: column; gap: 12px; }
.faq-item { background: var(--white); border-radius: 16px; border: 1px solid var(--wisteria-pale); overflow: hidden; transition: all 0.3s; }
.faq-item:hover { border-color: var(--petal); box-shadow: 0 6px 24px rgba(139,107,176,0.08); }
.faq-item h3 { font-size: 19px; margin-bottom: 8px; color: var(--wisteria-dk); display: flex; align-items: center; gap: 12px; }
.faq-item h3 .faq-icon { width: 32px; height: 32px; border-radius: 50%; background: var(--wisteria-pale); color: var(--wisteria); display: flex; align-items: center; justify-content: center; font-size: 16px; flex-shrink: 0; }
.faq-item p { font-size: 15px; color: var(--text-mid); padding-left: 44px; }

/* Accordion FAQ (faqs page) */
.faq-q { display: flex; align-items: center; gap: 14px; padding: 22px 28px; cursor: pointer; user-select: none; }
.faq-q .faq-icon { width: 36px; height: 36px; border-radius: 50%; background: var(--wisteria-pale); color: var(--wisteria); display: flex; align-items: center; justify-content: center; font-size: 17px; flex-shrink: 0; }
.faq-q h3 { font-size: 18px; color: var(--wisteria-dk); flex: 1; margin: 0; }
.faq-q .arrow { width: 24px; height: 24px; display: flex; align-items: center; justify-content: center; color: var(--wisteria-lt); transition: transform 0.3s; font-size: 18px; flex-shrink: 0; }
.faq-item.open .faq-q .arrow { transform: rotate(180deg); color: var(--wisteria); }
.faq-a { max-height: 0; overflow: hidden; transition: max-height 0.35s ease; }
.faq-a-inner { padding: 0 28px 22px 78px; font-size: 15px; color: var(--text-mid); line-height: 1.7; }
.faq-item.open .faq-a { max-height: 300px; }

/* ============================================================
   18. About Page
   ============================================================ */
/* Content Sections */
.about-section { padding: 80px 48px; max-width: 900px; margin: 0 auto; }
.about-section h2 { font-size: 34px; color: var(--wisteria-dk); margin-bottom: 20px; }
.about-section p { font-size: 17px; color: var(--text-mid); margin-bottom: 18px; line-height: 1.8; }
.about-section p:last-child { margin-bottom: 0; }

/* Alternate bg sections */
.about-warm { background: var(--warm); }

/* Who We Are icon accent */
.who-intro { display: flex; gap: 40px; align-items: flex-start; }
.who-icon { flex-shrink: 0; width: 120px; height: 120px; border-radius: 50%; background: linear-gradient(135deg, var(--wisteria-pale), var(--petal-lt)); display: flex; align-items: center; justify-content: center; box-shadow: 0 4px 20px rgba(139,107,176,0.15); }
.who-text { flex: 1; }

/* Offer Grid */
.offer-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 20px; margin-top: 32px; }
.offer-card { background: var(--white); border-radius: 16px; padding: 28px 24px; border: 1px solid var(--wisteria-pale); transition: all 0.3s; text-align: center; }
.offer-card:hover { border-color: var(--petal); box-shadow: 0 6px 24px rgba(139,107,176,0.1); transform: translateY(-4px); }
.offer-card .offer-icon { font-size: 32px; margin-bottom: 12px; display: block; }
.offer-card h3 { font-size: 18px; margin-bottom: 8px; color: var(--wisteria-dk); }
.offer-card p { font-size: 14px; color: var(--text-mid); line-height: 1.6; }

/* Why Choose Us */
.why-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 24px; margin-top: 32px; }
.why-item { display: flex; gap: 16px; align-items: flex-start; background: var(--white); border-radius: 14px; padding: 24px; border: 1px solid var(--wisteria-pale); }
.why-check { flex-shrink: 0; width: 40px; height: 40px; border-radius: 50%; background: linear-gradient(135deg, var(--wisteria), var(--petal-dk)); display: flex; align-items: center; justify-content: center; }
.why-check svg { width: 20px; height: 20px; }
.why-item h3 { font-size: 16px; margin-bottom: 4px; color: var(--text); }
.why-item p { font-size: 14px; color: var(--text-mid); margin-bottom: 0; }

/* ============================================================
   19. CTA Banner
   ============================================================ */
.cta-banner { background: linear-gradient(135deg, var(--wisteria-dk) 0%, var(--petal-dk) 100%); padding: 60px 48px; text-align: center; position: relative; overflow: hidden; }
.cta-banner::before { content: ''; position: absolute; top: -80px; right: -80px; width: 300px; height: 300px; background: radial-gradient(circle, rgba(255,255,255,0.08) 0%, transparent 70%); }
.cta-banner::after { content: ''; position: absolute; bottom: -60px; left: -60px; width: 250px; height: 250px; background: radial-gradient(circle, rgba(255,255,255,0.06) 0%, transparent 70%); }
.cta-banner h2 { font-size: 36px; color: var(--white); margin-bottom: 12px; position: relative; z-index: 1; }
.cta-banner p { font-size: 18px; color: rgba(255,255,255,0.85); margin-bottom: 28px; position: relative; z-index: 1; }
.cta-banner .btn-white { display: inline-flex; align-items: center; gap: 8px; background: var(--white); color: var(--wisteria-dk); padding: 16px 36px; border-radius: 999px; font-weight: 700; font-size: 17px; text-decoration: none; transition: all 0.2s; position: relative; z-index: 1; }
.cta-banner .btn-white:hover { transform: translateY(-2px); box-shadow: 0 8px 28px rgba(0,0,0,0.15); }

/* ============================================================
   20. Footer
   ============================================================ */
footer { background: #231832; color: var(--wisteria-lt); padding: 48px; }
.ft-grid { max-width: 1200px; margin: 0 auto; display: grid; grid-template-columns: 2fr 1fr 1fr 1fr; gap: 40px; }
.ft-brand h3 { font-family: 'Sorts Mill Goudy', serif; font-size: 22px; color: var(--white); margin-bottom: 12px; }
.ft-brand p { font-size: 14px; line-height: 1.6; }
footer h4 { font-size: 12px; color: var(--petal-lt); text-transform: uppercase; letter-spacing: 1px; margin-bottom: 14px; }
footer a { color: var(--wisteria-lt); text-decoration: none; font-size: 14px; display: block; margin-bottom: 8px; }
footer a:hover { color: var(--white); }
.ft-bottom { text-align: center; margin-top: 36px; padding-top: 24px; border-top: 1px solid rgba(255,255,255,0.06); font-size: 13px; color: var(--text-lt); max-width: 1200px; margin-left: auto; margin-right: auto; }

/* ============================================================
   21. Buttons
   ============================================================ */
.btn-grad { background: linear-gradient(135deg, var(--wisteria), var(--petal-dk)); color: var(--white); padding: 16px 36px; border-radius: 999px; font-weight: 600; font-size: 17px; text-decoration: none; transition: all 0.2s; display: inline-flex; align-items: center; gap: 8px; }
.btn-grad:hover { transform: translateY(-2px); box-shadow: 0 8px 28px rgba(139,107,176,0.3); }
.btn-soft { background: var(--white); color: var(--wisteria-dk); padding: 16px 36px; border-radius: 999px; font-weight: 600; font-size: 17px; text-decoration: none; border: 2px solid var(--wisteria-lt); transition: all 0.2s; }
.btn-soft:hover { background: var(--wisteria-pale); }

/* ============================================================
   22. International Calling Block
   ============================================================ */
.intl-note { background: var(--warm); padding: 48px; text-align: center; }
.intl-note-inner { max-width: 700px; margin: 0 auto; background: var(--white); border-radius: 16px; padding: 36px 40px; border: 1px solid var(--wisteria-pale); box-shadow: 0 2px 12px rgba(139,107,176,0.06); }
.intl-note-inner h3 { font-size: 24px; margin-bottom: 10px; color: var(--wisteria-dk); }
.intl-note-inner p { font-size: 16px; color: var(--text-mid); }
.intl-note-inner .intl-num { font-family: 'Sorts Mill Goudy', serif; font-size: 22px; color: var(--wisteria); font-weight: 700; margin-top: 8px; letter-spacing: 1px; }
.intl-select-wrap { margin-top: 20px; }
.intl-select-wrap label { font-size: 14px; font-weight: 600; color: var(--text-mid); display: block; margin-bottom: 8px; }
.intl-select-wrap select { appearance: none; background: var(--wisteria-pale); border: 2px solid var(--wisteria-lt); border-radius: 999px; padding: 12px 40px 12px 20px; font-family: 'Outfit', sans-serif; font-size: 15px; color: var(--wisteria-dk); font-weight: 500; cursor: pointer; background-image: 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='%236B4B90' stroke-width='2' fill='none' stroke-linecap='round'/%3E%3C/svg%3E"); background-repeat: no-repeat; background-position: right 16px center; min-width: 260px; transition: all 0.2s; }
.intl-select-wrap select:hover { border-color: var(--wisteria); }
.intl-select-wrap select:focus { outline: none; border-color: var(--wisteria); box-shadow: 0 0 0 3px rgba(139,107,176,0.15); }
.intl-result { margin-top: 16px; padding: 16px 24px; background: linear-gradient(135deg, var(--wisteria-pale), var(--petal-lt)); border-radius: 12px; display: none; }
.intl-result.show { display: block; }
.intl-result .dial-label { font-size: 13px; color: var(--text-mid); margin-bottom: 4px; }
.intl-result .dial-number { font-family: 'Sorts Mill Goudy', serif; font-size: 26px; color: var(--wisteria-dk); font-weight: 700; letter-spacing: 1.5px; }

/* ============================================================
   23. Responsive 968px
   ============================================================ */
@media (max-width: 968px) {
  .nav-links { display: none; }
  .nav-wrap { padding: 14px 24px; }

  /* Hero */
  .hero h1 { font-size: 38px; }
  .hero { padding: 40px 24px 60px; }

  /* Garden / notebook paper */
  .garden-cards { grid-template-columns: repeat(2, 1fr); gap: 20px; }
  .garden-strip { padding: 40px 24px; }

  /* Steps */
  .steps-grid { grid-template-columns: 1fr; gap: 48px; max-width: 400px; margin: 0 auto; }
  .steps-connector { display: none; }
  .steps-section { padding: 60px 24px 20px; }

  /* Services */
  .svc-list { grid-template-columns: 1fr; }
  .section { padding: 60px 24px; }

  /* Blog */
  .blog-grid { grid-template-columns: 1fr; }
  .blog-bg.archive .blog-grid { grid-template-columns: repeat(2, 1fr); gap: 20px; }
  .blog-bg.archive { padding: 40px 24px 60px; }

  /* Page headers */
  .page-header { padding: 48px 24px 44px; }
  .page-header h1 { font-size: 34px; }
  .page-hero h1 { font-size: 36px; }
  .page-hero { padding: 60px 24px 50px; }

  /* Phone bar */
  .phone-bar .num { font-size: 32px; }

  /* Footer */
  .ft-grid { grid-template-columns: 1fr 1fr; gap: 30px; }

  /* Mummys archive */
  .girls-grid { grid-template-columns: repeat(2, 1fr); }
  .girls-section { padding: 32px 24px; }

  /* Profile page */
  .profile-grid { grid-template-columns: 1fr; max-width: 500px; margin: 0 auto; }
  .profile-wrap { padding: 0 24px 40px; }
  .profile-header { padding: 36px 24px 40px; }
  .profile-header h1 { font-size: 34px; }
  .more-grid { grid-template-columns: repeat(2, 1fr); gap: 16px; }
  .more-section { padding: 36px 24px 44px; }
  .meas-grid { grid-template-columns: 1fr; }
  .gallery-grid { grid-template-columns: repeat(2, 1fr); gap: 16px; }
  .gallery-item img { height: 260px; }
  .mummy-gallery { margin-top: 36px; padding-top: 32px; }
  .contact-section { padding: 28px 24px; margin-top: 36px; }

  /* Pricing */
  .pricing-tiers { grid-template-columns: 1fr; max-width: 500px; margin-left: auto; margin-right: auto; }
  .deals-grid { grid-template-columns: 1fr; max-width: 400px; margin-left: auto; margin-right: auto; }
  .specials-grid { grid-template-columns: 1fr; max-width: 400px; margin-left: auto; margin-right: auto; }
  .stories-card { flex-direction: column; text-align: center; gap: 24px; padding: 36px 24px; }
  .pricing-section { padding: 40px 24px; }
  .deals-section { padding: 40px 24px; }
  .upsell-section { padding: 0 24px 40px; }
  .specials-section { padding: 40px 24px; }
  .stories-section { padding: 0 24px 40px; }
  .billing-note { padding: 30px 24px; }

  /* FAQ */
  .faq-section { padding: 60px 24px; }

  /* About */
  .about-section { padding: 60px 24px; }
  .offer-grid { grid-template-columns: repeat(2, 1fr); }
  .why-grid { grid-template-columns: 1fr; }
  .who-intro { flex-direction: column; align-items: center; text-align: center; }

  /* International */
  .intl-note { padding: 40px 24px; }

  /* Filter bar */
  .filter-bar { padding: 20px 24px; }
}

/* ============================================================
   24. Responsive 640px
   ============================================================ */
@media (max-width: 640px) {
  /* Hero */
  .hero h1 { font-size: 30px; }
  .hero > p { font-size: 17px; }
  .hero-actions { flex-direction: column; align-items: center; }

  /* Garden / notebook paper */
  .garden-cards { grid-template-columns: 1fr; max-width: 340px; margin: 0 auto; }

  /* Footer */
  .ft-grid { grid-template-columns: 1fr; }

  /* Phone bar */
  .phone-bar .num { font-size: 26px; letter-spacing: 1px; }

  /* UK Banner */
  .uk-banner { font-size: 11px; padding: 8px 16px; }

  /* Steps */
  .steps-title h2 { font-size: 28px; }

  /* CTA */
  .cta-banner h2 { font-size: 28px; }

  /* Services */
  .svc-box { flex-direction: column; }
  .svc-box .svc-img { width: 100%; min-height: 180px; }

  /* Page headers */
  .page-header h1 { font-size: 28px; }
  .page-header p { font-size: 16px; }
  .page-hero h1 { font-size: 28px; }
  .page-hero p { font-size: 16px; }

  /* Mummys archive */
  .girls-grid { grid-template-columns: 1fr; max-width: 320px; margin: 0 auto; }
  .filter-inner { gap: 8px; }
  .filter-btn { padding: 6px 14px; font-size: 12px; }

  /* Profile page */
  .profile-header h1 { font-size: 28px; }
  .more-grid { grid-template-columns: 1fr; max-width: 320px; margin: 0 auto; }
  .gallery-grid { grid-template-columns: 1fr; }
  .gallery-item img { height: 300px; }
  .mummy-gallery h2 { font-size: 24px; }
  .contact-section h2 { font-size: 22px; }

  /* Pricing */
  .upsell-grid { grid-template-columns: 1fr; }
  .upsell-grid .upsell-col:first-child { border-right: none; padding-right: 0; border-bottom: 1px solid var(--wisteria-pale); padding-bottom: 8px; margin-bottom: 8px; }
  .upsell-grid .upsell-col:last-child { padding-left: 0; }
  .billing-inner { flex-direction: column; text-align: center; }
  .billing-inner p { text-align: center; }

  /* FAQ */
  .faq-q { padding: 18px 20px; }
  .faq-q h3 { font-size: 16px; }
  .faq-a-inner { padding: 0 20px 18px 20px; }
  .faq-item p { padding-left: 0; }
  .faq-item h3 { font-size: 17px; }

  /* About */
  .about-section h2 { font-size: 28px; }
  .offer-grid { grid-template-columns: 1fr; }

  /* Blog archive */
  .blog-grid { grid-template-columns: 1fr; max-width: 480px; margin: 0 auto; }
  .blog-bg.archive .blog-grid { grid-template-columns: 1fr; max-width: 480px; margin: 0 auto; }
  .filter-pill { padding: 6px 16px; font-size: 13px; }

  /* International */
  .intl-note-inner { padding: 24px 20px; }
}
