/* ======================================================================
   TravelTradeInsights.com — Travel Industry Growth Partner
   Premium Corporate Design System
   Palette: Midnight Navy + Antique Gold + Emerald Pine + Ivory
   ====================================================================== */

:root{
  --navy-900:#0a1a2f;
  --navy-800:#0f2440;
  --navy-700:#15355c;
  --navy-600:#1d4673;
  --gold-600:#b8893a;
  --gold-500:#c9a050;
  --gold-400:#d8b97a;
  --gold-100:#f4e8cc;
  --emerald-700:#1f4e44;
  --emerald-500:#2d7263;
  --ivory:#faf8f3;
  --cream:#f4efe4;
  --paper:#ffffff;
  --ink:#1a1a1a;
  --ink-soft:#3a3a3a;
  --muted:#6b6b6b;
  --line:#e6dfd1;
  --line-strong:#cdbfa0;
  --shadow-sm:0 1px 2px rgba(10,26,47,.06), 0 1px 3px rgba(10,26,47,.04);
  --shadow:0 6px 24px rgba(10,26,47,.08), 0 2px 8px rgba(10,26,47,.05);
  --shadow-lg:0 24px 60px rgba(10,26,47,.14), 0 8px 24px rgba(10,26,47,.08);
  --radius-sm:6px;
  --radius:12px;
  --radius-lg:18px;
  --radius-xl:28px;
  --maxw:1480px;
  --gutter:clamp(20px, 4vw, 56px);
  --t-fast:.18s cubic-bezier(.2,.7,.2,1);
  --t:.28s cubic-bezier(.2,.7,.2,1);
}

*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  margin:0;
  font-family:'Inter','Segoe UI',system-ui,-apple-system,sans-serif;
  font-size:16.5px;
  line-height:1.7;
  color:var(--ink);
  background:var(--ivory);
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
img,svg,video{max-width:100%;height:auto;display:block}
a{color:var(--navy-700);text-decoration:none;transition:color var(--t-fast)}
a:hover{color:var(--gold-600)}
button{font-family:inherit;cursor:pointer;border:none;background:none}

/* ---------- TYPOGRAPHY ---------- */
h1,h2,h3,h4,h5{
  font-family:'Fraunces','Playfair Display',Georgia,serif;
  font-weight:500;
  line-height:1.15;
  letter-spacing:-.015em;
  color:var(--navy-900);
  margin:0 0 .5em;
}
h1{font-size:clamp(2.2rem, 4.8vw, 3.9rem);font-weight:500;letter-spacing:-.02em}
h2{font-size:clamp(1.7rem, 3.4vw, 2.6rem);font-weight:500}
h3{font-size:clamp(1.3rem, 2.2vw, 1.6rem);font-weight:600}
h4{font-size:1.15rem;font-weight:600;font-family:'Inter',sans-serif;color:var(--navy-800)}
p{margin:0 0 1rem;color:var(--ink-soft)}
.lead{font-size:1.18rem;line-height:1.65;color:var(--ink-soft)}
.eyebrow{
  display:inline-block;
  font-family:'Inter',sans-serif;
  font-size:.78rem;
  font-weight:600;
  letter-spacing:.18em;
  text-transform:uppercase;
  color:var(--gold-600);
  margin-bottom:1rem;
}
.eyebrow::before{
  content:"";
  display:inline-block;
  width:28px;
  height:1px;
  background:var(--gold-500);
  vertical-align:middle;
  margin-right:12px;
}
strong{color:var(--navy-900);font-weight:600}
blockquote{
  margin:2rem 0;
  padding:1.5rem 2rem;
  border-left:3px solid var(--gold-500);
  background:var(--cream);
  font-style:italic;
  color:var(--navy-800);
  border-radius:0 var(--radius) var(--radius) 0;
}

/* ---------- LAYOUT ---------- */
.wrap{width:min(100% - var(--gutter)*2, var(--maxw));margin-inline:auto}
.wrap-wide{width:min(100% - var(--gutter), 1680px);margin-inline:auto;padding:0 clamp(12px,2vw,24px)}
.section{padding:clamp(60px, 8vw, 110px) 0}
.section-tight{padding:clamp(40px, 5vw, 70px) 0}
.section-alt{background:var(--cream)}
.section-dark{background:var(--navy-900);color:#e9e3d4}
.section-dark h1,.section-dark h2,.section-dark h3,.section-dark h4{color:#fff}
.section-dark p{color:#c8c1b0}
.section-dark .eyebrow{color:var(--gold-400)}
.section-dark .eyebrow::before{background:var(--gold-400)}
.section-cream{background:linear-gradient(180deg, var(--ivory) 0%, var(--cream) 100%)}

.grid{display:grid;gap:clamp(18px,2.4vw,32px)}
.g-2{grid-template-columns:repeat(2, minmax(0,1fr))}
.g-3{grid-template-columns:repeat(3, minmax(0,1fr))}
.g-4{grid-template-columns:repeat(4, minmax(0,1fr))}
.g-12-7{grid-template-columns:1.2fr .7fr}
.g-7-12{grid-template-columns:.7fr 1.2fr}
@media (max-width: 960px){
  .g-2,.g-3,.g-4,.g-12-7,.g-7-12{grid-template-columns:1fr}
}

/* ---------- BUTTONS ---------- */
.btn{
  display:inline-flex;
  align-items:center;
  gap:.55rem;
  padding:.95rem 1.6rem;
  border-radius:999px;
  font-weight:600;
  font-size:.95rem;
  letter-spacing:.005em;
  transition:transform var(--t-fast), box-shadow var(--t), background var(--t), color var(--t);
  white-space:nowrap;
  border:1px solid transparent;
}
.btn-primary{
  background:var(--navy-900);
  color:#fff;
  box-shadow:0 6px 18px rgba(10,26,47,.18);
}
.btn-primary:hover{background:var(--navy-700);color:#fff;transform:translateY(-1px);box-shadow:0 10px 26px rgba(10,26,47,.24)}
.btn-gold{
  background:var(--gold-500);
  color:var(--navy-900);
  box-shadow:0 6px 18px rgba(184,137,58,.28);
}
.btn-gold:hover{background:var(--gold-600);color:#fff;transform:translateY(-1px)}
.btn-ghost{background:transparent;color:var(--navy-900);border-color:var(--navy-900)}
.btn-ghost:hover{background:var(--navy-900);color:#fff}
.btn-ghost-light{background:transparent;color:#fff;border-color:rgba(255,255,255,.4)}
.btn-ghost-light:hover{background:#fff;color:var(--navy-900)}
.btn-sm{padding:.65rem 1.15rem;font-size:.85rem}
.btn .arrow{transition:transform var(--t)}
.btn:hover .arrow{transform:translateX(3px)}

/* ---------- TOP BAR ---------- */
.topbar{
  background:var(--navy-900);
  color:#d8d2c2;
  font-size:.82rem;
  padding:.55rem 0;
}
.topbar-inner{display:flex;justify-content:space-between;align-items:center;gap:1.5rem;flex-wrap:wrap}
.topbar a{color:#e9e3d4}
.topbar a:hover{color:var(--gold-400)}
.topbar .meta{display:flex;gap:1.4rem;flex-wrap:wrap}
.topbar .meta span{display:inline-flex;gap:.45rem;align-items:center}
@media (max-width:780px){
  .topbar .meta{display:none}
}

/* ---------- HEADER / NAVIGATION ---------- */
.site-header{
  position:sticky;
  top:0;
  z-index:90;
  background:rgba(250,248,243,.92);
  backdrop-filter:saturate(160%) blur(14px);
  -webkit-backdrop-filter:saturate(160%) blur(14px);
  border-bottom:1px solid var(--line);
}
.nav{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:2rem;
  padding:1rem 0;
}
.brand{display:flex;align-items:center;gap:.7rem;color:var(--navy-900);font-weight:700}
.brand-mark{
  width:38px;height:38px;
  border-radius:8px;
  background:linear-gradient(135deg, var(--navy-900), var(--navy-700));
  display:grid;place-items:center;
  color:var(--gold-400);
  font-weight:800;
  font-family:'Fraunces',serif;
  font-size:1.2rem;
  letter-spacing:-.02em;
  box-shadow:inset 0 0 0 1px rgba(212,184,122,.28);
}
.brand-name{display:flex;flex-direction:column;line-height:1.05}
.brand-name .b1{font-size:1.02rem;font-family:'Fraunces',serif;color:var(--navy-900);letter-spacing:-.01em}
.brand-name .b2{font-size:.66rem;letter-spacing:.16em;text-transform:uppercase;color:var(--gold-600);font-weight:600}

.nav-links{display:flex;align-items:center;gap:1.6rem;list-style:none;padding:0;margin:0}
.nav-links > li{position:relative}
.nav-links a{font-size:.92rem;color:var(--navy-800);font-weight:500;padding:.4rem 0;position:relative}
.nav-links a:hover{color:var(--gold-600)}
.nav-links a.dropdown-trigger::after{
  content:"";
  display:inline-block;
  width:6px;height:6px;
  border-right:1.5px solid currentColor;
  border-bottom:1.5px solid currentColor;
  transform:rotate(45deg);
  margin-left:.4rem;margin-bottom:3px;
}
.dropdown{
  position:absolute;
  top:calc(100% + 10px);
  left:-1rem;
  min-width:260px;
  background:#fff;
  border:1px solid var(--line);
  border-radius:var(--radius);
  box-shadow:var(--shadow);
  padding:.7rem;
  opacity:0;
  pointer-events:none;
  transform:translateY(6px);
  transition:opacity var(--t), transform var(--t);
}
.dropdown.mega{min-width:540px;padding:1.4rem;display:grid;grid-template-columns:1fr 1fr;gap:.5rem 1.6rem}
.dropdown.mega .mega-col h5{font-family:'Inter',sans-serif;font-size:.7rem;letter-spacing:.16em;text-transform:uppercase;color:var(--gold-600);margin:.6rem 0 .4rem}
.dropdown a{
  display:block;
  padding:.55rem .7rem;
  border-radius:8px;
  font-size:.9rem;
  color:var(--navy-800);
}
.dropdown a:hover{background:var(--cream);color:var(--navy-900)}
.nav-links > li:hover > .dropdown,
.nav-links > li:focus-within > .dropdown{opacity:1;pointer-events:auto;transform:translateY(0)}

.nav-cta{display:flex;align-items:center;gap:.8rem}
.menu-toggle{display:none;width:44px;height:44px;border-radius:10px;border:1px solid var(--line);background:#fff;align-items:center;justify-content:center}
.menu-toggle span{display:block;width:20px;height:2px;background:var(--navy-900);position:relative}
.menu-toggle span::before,.menu-toggle span::after{content:"";position:absolute;left:0;width:100%;height:2px;background:inherit}
.menu-toggle span::before{top:-6px}
.menu-toggle span::after{top:6px}

@media (max-width:1100px){
  .nav-links{display:none}
  .menu-toggle{display:inline-flex}
  .nav-cta .btn:not(.menu-toggle):not(.btn-primary){display:none}
}
.mobile-nav{
  position:fixed;
  inset:0;
  background:#0a1a2feb;
  backdrop-filter:blur(8px);
  z-index:120;
  padding:80px 24px 24px;
  overflow-y:auto;
  transform:translateX(100%);
  transition:transform .35s cubic-bezier(.2,.7,.2,1);
}
.mobile-nav.open{transform:translateX(0)}
.mobile-nav .close{position:absolute;top:20px;right:20px;color:#fff;font-size:1.6rem;width:44px;height:44px;border:1px solid rgba(255,255,255,.2);border-radius:10px;display:grid;place-items:center}
.mobile-nav ul{list-style:none;padding:0;margin:0 0 1.4rem}
.mobile-nav h5{color:var(--gold-400);font-family:'Inter',sans-serif;font-size:.72rem;letter-spacing:.16em;text-transform:uppercase;margin:1.4rem 0 .4rem}
.mobile-nav a{display:block;padding:.8rem .2rem;color:#e9e3d4;border-bottom:1px solid rgba(255,255,255,.06)}
.mobile-nav a:hover{color:var(--gold-400)}

/* ---------- HERO ---------- */
.hero{
  position:relative;
  padding:clamp(60px,9vw,130px) 0 clamp(80px,10vw,140px);
  background:
    radial-gradient(900px 480px at 92% 6%, rgba(184,137,58,.10), transparent 60%),
    radial-gradient(700px 480px at -6% 80%, rgba(31,78,68,.07), transparent 60%),
    linear-gradient(180deg, var(--ivory), var(--cream));
  overflow:hidden;
}
.hero-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(32px,5vw,80px);align-items:center}
@media (max-width:980px){.hero-grid{grid-template-columns:1fr}}
.hero h1{margin-bottom:1.1rem}
.hero h1 em{
  font-style:normal;
  background:linear-gradient(90deg, var(--gold-600), var(--gold-400));
  -webkit-background-clip:text;
  background-clip:text;
  color:transparent;
}
.hero .lead{font-size:1.22rem;max-width:60ch;margin-bottom:1.8rem;color:var(--ink-soft)}
.hero-actions{display:flex;gap:.9rem;flex-wrap:wrap;margin-bottom:2.5rem}
.hero-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:1.4rem;border-top:1px solid var(--line);padding-top:1.6rem;max-width:560px}
.hero-stats .stat strong{display:block;font-family:'Fraunces',serif;font-size:1.9rem;color:var(--navy-900);letter-spacing:-.02em}
.hero-stats .stat span{font-size:.82rem;color:var(--muted);letter-spacing:.02em}

.hero-card{
  background:#fff;
  border:1px solid var(--line);
  border-radius:var(--radius-xl);
  padding:clamp(22px,3vw,36px);
  box-shadow:var(--shadow-lg);
  position:relative;
}
.hero-card::before{
  content:"";
  position:absolute;
  inset:-1px;
  border-radius:inherit;
  background:linear-gradient(135deg, rgba(184,137,58,.4), transparent 50%);
  z-index:-1;
  filter:blur(20px);
  opacity:.5;
}
.hero-card h3{margin-bottom:.4rem}
.hero-card .meta{font-size:.85rem;color:var(--muted);margin-bottom:1.2rem}
.hero-card .checklist{list-style:none;padding:0;margin:0 0 1.2rem;display:grid;gap:.6rem}
.hero-card .checklist li{padding-left:1.8rem;position:relative;font-size:.94rem;color:var(--ink-soft)}
.hero-card .checklist li::before{
  content:"✓";
  position:absolute;
  left:0;top:0;
  width:22px;height:22px;
  border-radius:50%;
  background:var(--emerald-500);
  color:#fff;
  font-size:.72rem;
  display:grid;place-items:center;
}

/* ---------- BREADCRUMB ---------- */
.breadcrumb{
  padding:1.2rem 0 .2rem;
  font-size:.84rem;
  color:var(--muted);
  background:var(--ivory);
}
.breadcrumb ol{list-style:none;padding:0;margin:0;display:flex;flex-wrap:wrap;gap:.5rem;align-items:center}
.breadcrumb li{display:flex;align-items:center;gap:.5rem}
.breadcrumb li:not(:last-child)::after{content:"›";color:var(--gold-500);margin-left:.5rem}
.breadcrumb a{color:var(--navy-700)}
.breadcrumb [aria-current="page"]{color:var(--ink)}

/* ---------- CARDS ---------- */
.card{
  background:#fff;
  border:1px solid var(--line);
  border-radius:var(--radius-lg);
  padding:clamp(22px,2.4vw,32px);
  transition:transform var(--t), box-shadow var(--t), border-color var(--t);
  height:100%;
  display:flex;
  flex-direction:column;
}
.card:hover{transform:translateY(-3px);box-shadow:var(--shadow);border-color:var(--line-strong)}
.card .ico{
  width:48px;height:48px;
  border-radius:12px;
  background:linear-gradient(135deg, var(--cream), #fff);
  border:1px solid var(--line);
  color:var(--gold-600);
  display:grid;place-items:center;
  margin-bottom:1.2rem;
  font-size:1.2rem;
}
.card h3{margin-bottom:.5rem;font-size:1.25rem}
.card p{font-size:.95rem;margin-bottom:1rem}
.card .more{
  margin-top:auto;
  font-size:.86rem;
  font-weight:600;
  color:var(--navy-800);
  display:inline-flex;
  align-items:center;
  gap:.4rem;
}
.card .more::after{content:"→";transition:transform var(--t)}
.card:hover .more::after{transform:translateX(4px)}
.card.dark{background:var(--navy-800);color:#e9e3d4;border-color:transparent}
.card.dark h3{color:#fff}
.card.dark p{color:#c8c1b0}
.card.dark .ico{background:linear-gradient(135deg, rgba(184,137,58,.25), rgba(184,137,58,.08));border-color:rgba(184,137,58,.3);color:var(--gold-400)}

/* ---------- SECTION HEAD ---------- */
.section-head{max-width:780px;margin:0 auto 3rem;text-align:center}
.section-head.left{margin-inline:0;text-align:left}
.section-head h2{margin-bottom:.6rem}
.section-head p{font-size:1.1rem;color:var(--ink-soft)}

/* ---------- FEATURE LIST ---------- */
.feature-list{display:grid;gap:1.1rem;list-style:none;padding:0;margin:1.4rem 0}
.feature-list li{display:flex;gap:1rem;align-items:flex-start}
.feature-list .num{
  flex:0 0 36px;
  height:36px;
  border-radius:50%;
  background:var(--navy-900);
  color:var(--gold-400);
  display:grid;place-items:center;
  font-family:'Fraunces',serif;
  font-weight:600;
  font-size:.95rem;
}
.feature-list h4{margin:0 0 .25rem}
.feature-list p{margin:0;font-size:.95rem}

/* ---------- TABLE ---------- */
.table-wrap{overflow-x:auto;border:1px solid var(--line);border-radius:var(--radius);background:#fff;margin:1.8rem 0}
table.data{width:100%;border-collapse:collapse;min-width:640px;font-size:.94rem}
table.data th,table.data td{padding:.95rem 1.1rem;text-align:left;border-bottom:1px solid var(--line)}
table.data thead th{background:var(--cream);font-family:'Inter',sans-serif;font-weight:600;color:var(--navy-900);font-size:.84rem;letter-spacing:.04em;text-transform:uppercase}
table.data tbody tr:last-child td{border-bottom:none}
table.data tbody tr:hover{background:rgba(244,232,204,.3)}
table.data .yes{color:var(--emerald-500);font-weight:600}
table.data .no{color:#9c2c2c;font-weight:600}

/* ---------- FAQ ---------- */
.faq{display:grid;gap:.8rem}
.faq details{
  background:#fff;
  border:1px solid var(--line);
  border-radius:var(--radius);
  padding:0;
  transition:border-color var(--t), box-shadow var(--t);
}
.faq details[open]{border-color:var(--line-strong);box-shadow:var(--shadow-sm)}
.faq summary{
  list-style:none;
  cursor:pointer;
  padding:1.15rem 1.4rem;
  font-weight:600;
  font-size:1.02rem;
  color:var(--navy-900);
  display:flex;
  justify-content:space-between;
  gap:1rem;
  align-items:center;
}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{
  content:"+";
  font-family:'Fraunces',serif;
  font-size:1.5rem;
  font-weight:300;
  color:var(--gold-600);
  transition:transform var(--t);
  flex:0 0 auto;
}
.faq details[open] summary::after{transform:rotate(45deg)}
.faq .answer{padding:0 1.4rem 1.4rem;color:var(--ink-soft);font-size:.96rem;line-height:1.7}

/* ---------- LOGO ROW ---------- */
.logo-row{display:flex;justify-content:center;align-items:center;flex-wrap:wrap;gap:clamp(28px,4vw,64px);opacity:.78}
.logo-row .lg{
  font-family:'Fraunces',serif;
  font-size:1.1rem;
  letter-spacing:.04em;
  color:var(--navy-800);
  font-weight:500;
  white-space:nowrap;
}
.logo-row .lg .dot{display:inline-block;width:6px;height:6px;border-radius:50%;background:var(--gold-500);margin:0 .5rem;vertical-align:middle}

/* ---------- TESTIMONIAL ---------- */
.testimonial{
  background:#fff;
  border:1px solid var(--line);
  border-radius:var(--radius-lg);
  padding:clamp(24px,3vw,40px);
  position:relative;
}
.testimonial::before{
  content:"\201C";
  position:absolute;
  top:14px;left:24px;
  font-family:'Fraunces',serif;
  font-size:5rem;
  color:var(--gold-500);
  line-height:1;
  opacity:.4;
}
.testimonial blockquote{
  margin:0 0 1.4rem;
  padding:0;
  border:none;
  background:transparent;
  font-style:normal;
  font-size:1.12rem;
  line-height:1.6;
  color:var(--navy-800);
  font-family:'Fraunces',serif;
  font-weight:400;
}
.testimonial .who{display:flex;align-items:center;gap:.85rem}
.testimonial .avatar{
  width:48px;height:48px;border-radius:50%;
  background:linear-gradient(135deg, var(--navy-900), var(--navy-700));
  color:var(--gold-400);
  display:grid;place-items:center;
  font-weight:700;
}
.testimonial .who strong{display:block;color:var(--navy-900);font-size:.95rem;font-weight:600}
.testimonial .who span{font-size:.82rem;color:var(--muted)}

/* ---------- CTA BLOCK ---------- */
.cta-block{
  background:
    radial-gradient(700px 320px at 88% 12%, rgba(184,137,58,.25), transparent 60%),
    linear-gradient(135deg, var(--navy-900), var(--navy-700));
  color:#fff;
  border-radius:var(--radius-xl);
  padding:clamp(36px,5vw,72px);
  display:grid;
  grid-template-columns:1.4fr .9fr;
  gap:2rem;
  align-items:center;
}
.cta-block h2{color:#fff;margin-bottom:.8rem}
.cta-block p{color:#d8d2c2;margin-bottom:1.4rem;font-size:1.05rem}
.cta-block .actions{display:flex;gap:.8rem;flex-wrap:wrap}
@media (max-width:880px){.cta-block{grid-template-columns:1fr}}

/* ---------- STICKY FLOATING CTAs ---------- */
.float-actions{
  position:fixed;
  right:18px;
  bottom:18px;
  z-index:80;
  display:flex;
  flex-direction:column;
  gap:.6rem;
}
.float-btn{
  width:54px;height:54px;
  border-radius:50%;
  display:grid;place-items:center;
  box-shadow:0 10px 26px rgba(10,26,47,.25);
  color:#fff;
  font-size:1.4rem;
  transition:transform var(--t), box-shadow var(--t);
  border:none;
}
.float-btn:hover{transform:translateY(-2px) scale(1.04);color:#fff}
.float-btn.whatsapp{background:#25d366}
.float-btn.call{background:var(--navy-900)}
.float-btn.scroll-top{background:var(--gold-600);width:46px;height:46px;font-size:1rem}
.sticky-cta-bar{
  position:fixed;
  left:50%;
  transform:translateX(-50%);
  bottom:18px;
  z-index:75;
  background:var(--navy-900);
  color:#fff;
  padding:.7rem .85rem .7rem 1.4rem;
  border-radius:999px;
  box-shadow:0 18px 40px rgba(10,26,47,.32);
  display:none;
  align-items:center;
  gap:1rem;
  font-size:.9rem;
}
.sticky-cta-bar .btn{padding:.55rem 1rem;font-size:.85rem}
@media (min-width:880px){
  .sticky-cta-bar.show{display:flex}
}

/* ---------- FORMS ---------- */
.form{display:grid;gap:1rem}
.form .row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
@media (max-width:680px){.form .row{grid-template-columns:1fr}}
.form label{display:block;font-size:.84rem;font-weight:600;color:var(--navy-800);margin-bottom:.35rem}
.form input,.form select,.form textarea{
  width:100%;
  padding:.85rem 1rem;
  border:1px solid var(--line-strong);
  border-radius:10px;
  background:#fff;
  font-family:inherit;
  font-size:.95rem;
  color:var(--ink);
  transition:border-color var(--t), box-shadow var(--t);
}
.form input:focus,.form select:focus,.form textarea:focus{
  outline:none;
  border-color:var(--gold-500);
  box-shadow:0 0 0 4px rgba(201,160,80,.18);
}
.form textarea{min-height:130px;resize:vertical}
.form .hint{font-size:.78rem;color:var(--muted)}
.form .consent{display:flex;gap:.6rem;align-items:flex-start;font-size:.84rem;color:var(--ink-soft)}
.form .consent input{width:auto;margin-top:.25rem}

/* ---------- NEWSLETTER STRIP ---------- */
.newsletter{
  background:var(--cream);
  border:1px solid var(--line);
  border-radius:var(--radius-lg);
  padding:clamp(26px,3vw,40px);
  display:grid;
  grid-template-columns:1.1fr 1fr;
  gap:2rem;
  align-items:center;
}
.newsletter form{display:flex;gap:.6rem;flex-wrap:wrap}
.newsletter input{flex:1;min-width:220px;padding:.85rem 1rem;border-radius:999px;border:1px solid var(--line-strong);background:#fff}
@media (max-width:760px){.newsletter{grid-template-columns:1fr}}

/* ---------- TIMELINE ---------- */
.timeline{display:grid;gap:.5rem;position:relative;padding-left:30px}
.timeline::before{content:"";position:absolute;left:11px;top:8px;bottom:8px;width:2px;background:linear-gradient(180deg, var(--gold-500), var(--gold-100))}
.timeline-step{position:relative;padding:.3rem 0 1.4rem 0}
.timeline-step::before{
  content:"";
  position:absolute;
  left:-30px;top:6px;
  width:24px;height:24px;
  border-radius:50%;
  background:#fff;
  border:2px solid var(--gold-500);
  box-shadow:0 0 0 4px var(--ivory);
}
.timeline-step h4{margin-bottom:.2rem;color:var(--navy-900)}
.timeline-step p{margin:0;font-size:.94rem}

/* ---------- STAT GRID ---------- */
.stat-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1.4rem}
@media (max-width:960px){.stat-grid{grid-template-columns:repeat(2,1fr)}}
.stat-card{
  background:#fff;
  border:1px solid var(--line);
  border-radius:var(--radius);
  padding:1.6rem 1.4rem;
  text-align:left;
}
.stat-card .num{font-family:'Fraunces',serif;font-size:2.4rem;color:var(--navy-900);line-height:1;letter-spacing:-.02em}
.stat-card .num .unit{font-size:1.2rem;color:var(--gold-600);margin-left:.1rem}
.stat-card .lbl{margin-top:.4rem;font-size:.86rem;color:var(--muted);line-height:1.4}

/* ---------- PILL TAGS ---------- */
.pill{
  display:inline-flex;
  align-items:center;
  padding:.3rem .7rem;
  border-radius:999px;
  background:var(--cream);
  border:1px solid var(--line);
  color:var(--navy-800);
  font-size:.78rem;
  font-weight:600;
  letter-spacing:.02em;
}
.pill.gold{background:rgba(201,160,80,.14);border-color:rgba(201,160,80,.28);color:var(--gold-600)}
.pill.dark{background:rgba(255,255,255,.07);border-color:rgba(255,255,255,.16);color:#e9e3d4}
.pill-row{display:flex;flex-wrap:wrap;gap:.5rem;margin:.4rem 0 1rem}

/* ---------- FOOTER ---------- */
.site-footer{
  background:var(--navy-900);
  color:#bcb6a3;
  padding:clamp(48px,6vw,80px) 0 24px;
  margin-top:clamp(40px,5vw,80px);
}
.footer-grid{display:grid;grid-template-columns:1.4fr repeat(4,1fr);gap:2rem}
@media (max-width:1000px){.footer-grid{grid-template-columns:1fr 1fr}}
@media (max-width:600px){.footer-grid{grid-template-columns:1fr 1fr;gap:1.4rem}}
.footer-grid h5{
  color:#fff;
  font-family:'Inter',sans-serif;
  font-size:.78rem;
  letter-spacing:.18em;
  text-transform:uppercase;
  margin:0 0 1rem;
}
.footer-grid ul{list-style:none;padding:0;margin:0;display:grid;gap:.55rem}
.footer-grid a{color:#bcb6a3;font-size:.92rem}
.footer-grid a:hover{color:var(--gold-400)}
.footer-bio p{color:#bcb6a3;font-size:.94rem;max-width:34ch}
.footer-bottom{border-top:1px solid rgba(255,255,255,.08);margin-top:2.4rem;padding-top:1.6rem;display:flex;justify-content:space-between;flex-wrap:wrap;gap:1rem;font-size:.82rem;color:#9b957f}
.footer-bottom a{color:#bcb6a3}

/* ---------- UTILITY ---------- */
.mt-0{margin-top:0}.mt-1{margin-top:.5rem}.mt-2{margin-top:1rem}.mt-3{margin-top:1.5rem}.mt-4{margin-top:2.4rem}
.mb-0{margin-bottom:0}.mb-2{margin-bottom:1rem}.mb-4{margin-bottom:2.4rem}
.text-center{text-align:center}
.text-muted{color:var(--muted)}
.gold{color:var(--gold-600)}
.hide-sm{display:initial}
@media (max-width:760px){.hide-sm{display:none}}
.no-shrink{flex-shrink:0}

/* ---------- ARTICLE PROSE ---------- */
.prose h2{margin-top:2.4rem}
.prose h3{margin-top:1.8rem}
.prose ul,.prose ol{padding-left:1.3rem;margin-bottom:1.3rem;color:var(--ink-soft)}
.prose ul li,.prose ol li{margin-bottom:.5rem}
.prose img,.prose figure{margin:2rem 0;border-radius:var(--radius)}
.prose figcaption{font-size:.85rem;color:var(--muted);margin-top:.5rem;text-align:center}

/* ---------- CALLOUT BOX ---------- */
.callout{
  background:linear-gradient(135deg, var(--cream), #fff);
  border:1px solid var(--line);
  border-left:4px solid var(--gold-500);
  border-radius:var(--radius);
  padding:1.4rem 1.6rem;
  margin:1.8rem 0;
}
.callout strong{display:block;color:var(--navy-900);margin-bottom:.3rem;font-family:'Fraunces',serif;font-size:1.05rem;font-weight:500}
.callout p{margin:0;font-size:.95rem}

/* ---------- COMPARISON BLOCK ---------- */
.compare-grid{display:grid;grid-template-columns:1fr 1fr;gap:1.6rem}
@media (max-width:760px){.compare-grid{grid-template-columns:1fr}}
.compare-col{background:#fff;border:1px solid var(--line);border-radius:var(--radius-lg);padding:1.8rem}
.compare-col.a{border-top:3px solid var(--gold-500)}
.compare-col.b{border-top:3px solid var(--emerald-500)}
.compare-col h3{margin-bottom:1rem}
.compare-col ul{list-style:none;padding:0;margin:0}
.compare-col li{padding:.55rem 0;border-bottom:1px dashed var(--line);font-size:.95rem;color:var(--ink-soft);display:flex;align-items:flex-start;gap:.6rem}
.compare-col li::before{content:"●";color:var(--gold-500);font-size:.6rem;margin-top:.55rem}
.compare-col li:last-child{border-bottom:none}

/* ---------- SECTION ANCHOR ---------- */
.anchor-target{scroll-margin-top:100px}

/* ---------- ARTICLE META BAR ---------- */
.article-meta{
  display:flex;
  align-items:center;
  gap:1.4rem;
  flex-wrap:wrap;
  font-size:.85rem;
  color:var(--muted);
  border-top:1px solid var(--line);
  border-bottom:1px solid var(--line);
  padding:1rem 0;
  margin:1.4rem 0 2rem;
}
.article-meta span{display:inline-flex;gap:.4rem;align-items:center}
.article-meta strong{color:var(--navy-900);font-weight:600}

/* ---------- PROCESS STEPS ---------- */
.process{display:grid;grid-template-columns:repeat(4,1fr);gap:1.4rem;counter-reset:step}
@media (max-width:980px){.process{grid-template-columns:repeat(2,1fr)}}
@media (max-width:560px){.process{grid-template-columns:1fr}}
.process-step{
  background:#fff;
  border:1px solid var(--line);
  border-radius:var(--radius-lg);
  padding:1.6rem 1.4rem 1.4rem;
  position:relative;
  counter-increment:step;
}
.process-step::before{
  content:"0" counter(step);
  position:absolute;
  top:1rem;right:1.2rem;
  font-family:'Fraunces',serif;
  font-size:2.2rem;
  color:var(--gold-400);
  line-height:1;
  letter-spacing:-.04em;
}
.process-step h4{margin:1.4rem 0 .3rem;font-family:'Fraunces',serif;font-size:1.18rem;font-weight:500;color:var(--navy-900)}
.process-step p{margin:0;font-size:.92rem}

/* ---------- TOC ---------- */
.toc{
  background:var(--cream);
  border:1px solid var(--line);
  border-radius:var(--radius);
  padding:1.4rem 1.6rem;
  margin:1.4rem 0 2rem;
}
.toc h4{margin:0 0 .8rem;font-family:'Inter',sans-serif;font-size:.78rem;letter-spacing:.16em;text-transform:uppercase;color:var(--gold-600)}
.toc ol{list-style:decimal;padding-left:1.4rem;margin:0;color:var(--ink-soft)}
.toc li{padding:.25rem 0;font-size:.94rem}
.toc a{color:var(--navy-700)}

/* ---------- RESPONSIVE PADDING ---------- */
@media (max-width:520px){
  body{font-size:15.5px}
  .hero-stats{grid-template-columns:1fr;gap:.8rem}
  .hero-stats .stat strong{font-size:1.5rem}
  .float-actions{right:12px;bottom:12px}
  .float-btn{width:48px;height:48px;font-size:1.2rem}
}

/* ---------- SCROLL ANIMATION ---------- */
.reveal{opacity:0;transform:translateY(14px);transition:opacity .8s ease, transform .8s cubic-bezier(.2,.7,.2,1)}
.reveal.in{opacity:1;transform:none}

/* ===========================================================
   BUNDLE CTA (matches Limited-Time Bundle inspiration card)
   Used in 3 variations: A=Growth Bundle, B=Sprint, C=Diagnostic
   =========================================================== */
.bundle-cta{
  position:relative;
  background:
    radial-gradient(800px 360px at 92% 0%, rgba(184,137,58,.16), transparent 60%),
    linear-gradient(160deg, #0a1a2f 0%, #102943 60%, #0a1a2f 100%);
  color:#e9e3d4;
  border-radius:var(--radius-xl);
  padding:clamp(28px, 4vw, 56px);
  overflow:hidden;
  box-shadow:0 30px 80px rgba(10,26,47,.30);
}
.bundle-cta::before{
  content:"";
  position:absolute;inset:0;
  background-image:
    linear-gradient(rgba(212,184,122,.05) 1px, transparent 1px),
    linear-gradient(90deg, rgba(212,184,122,.05) 1px, transparent 1px);
  background-size:48px 48px;
  pointer-events:none;
  mask-image:radial-gradient(ellipse at center, #000 0%, transparent 75%);
  -webkit-mask-image:radial-gradient(ellipse at center, #000 0%, transparent 75%);
}
.bundle-cta > *{position:relative;z-index:1}

.bundle-pill{
  display:inline-flex;
  align-items:center;
  gap:.5rem;
  padding:.55rem 1.1rem;
  background:linear-gradient(135deg, var(--gold-500), var(--gold-400));
  color:var(--navy-900);
  font-family:'Inter',sans-serif;
  font-weight:700;
  font-size:.78rem;
  letter-spacing:.16em;
  text-transform:uppercase;
  border-radius:8px;
  box-shadow:0 8px 22px rgba(184,137,58,.32);
  margin-bottom:1.6rem;
}
.bundle-heading{
  font-family:'Fraunces',serif;
  font-size:clamp(1.8rem, 3.5vw, 2.7rem);
  font-weight:500;
  line-height:1.1;
  letter-spacing:-.02em;
  color:#fff;
  margin:0 0 .8rem;
}
.bundle-heading em{
  font-style:italic;
  background:linear-gradient(90deg, var(--gold-400), var(--gold-500));
  -webkit-background-clip:text;
  background-clip:text;
  color:transparent;
}
.bundle-sub{
  color:#bcb6a3;
  font-size:1.02rem;
  line-height:1.6;
  max-width:62ch;
  margin:0 0 1.6rem;
}
.bundle-price{
  display:flex;
  align-items:baseline;
  gap:.6rem;
  padding:1.2rem 0;
  border-top:1px solid rgba(212,184,122,.18);
  border-bottom:1px solid rgba(212,184,122,.18);
  margin-bottom:1.6rem;
}
.bundle-price-from{
  font-family:'Inter',sans-serif;
  font-size:.78rem;
  letter-spacing:.18em;
  text-transform:uppercase;
  color:#8d8773;
  margin-right:.4rem;
}
.bundle-price-num{
  font-family:'Fraunces',serif;
  font-size:3rem;
  line-height:1;
  color:var(--gold-400);
  font-weight:500;
  letter-spacing:-.02em;
}
.bundle-price-unit{
  color:#bcb6a3;
  font-size:1.1rem;
}
.bundle-tiles{
  display:grid;
  grid-template-columns:repeat(2, minmax(0,1fr));
  gap:.7rem;
  margin-bottom:1.6rem;
}
@media (max-width:640px){.bundle-tiles{grid-template-columns:1fr}}
.bundle-tile{
  display:flex;
  align-items:center;
  gap:.8rem;
  padding:.7rem 1rem;
  background:rgba(255,255,255,.04);
  border:1px solid rgba(212,184,122,.12);
  border-radius:12px;
  color:#fff;
  font-size:.94rem;
  font-weight:500;
  transition:background var(--t-fast), border-color var(--t-fast), transform var(--t-fast);
}
.bundle-tile:hover{background:rgba(255,255,255,.07);border-color:rgba(212,184,122,.32);transform:translateY(-1px)}
.bundle-tile-ico{
  flex:0 0 38px;
  height:38px;
  border-radius:9px;
  display:grid;
  place-items:center;
  font-size:1.05rem;
  font-weight:700;
  color:#fff;
  box-shadow:inset 0 0 0 1px rgba(255,255,255,.12), 0 4px 10px rgba(0,0,0,.18);
}
.bundle-tile-ico.t-web{background:linear-gradient(135deg,#d8b97a,#b8893a);color:#0a1a2f}
.bundle-tile-ico.t-seo{background:linear-gradient(135deg,#34d399,#0ea5e9 60%,#a855f7);color:#fff}
.bundle-tile-ico.t-content{background:linear-gradient(135deg,#e9c46a,#d4a017);color:#0a1a2f}
.bundle-tile-ico.t-ig{background:linear-gradient(135deg,#f58529,#dd2a7b 50%,#8134af 90%);color:#fff}
.bundle-tile-ico.t-igads{background:linear-gradient(135deg,#f58529,#dd2a7b 50%,#8134af 90%);color:#fff}
.bundle-tile-ico.t-fb{background:#1877f2;color:#fff}
.bundle-tile-ico.t-g{background:#fff;color:#0a1a2f}
.bundle-tile-ico.t-yt{background:#ff0000;color:#fff}
.bundle-tile-ico.t-li{background:#0a66c2;color:#fff}
.bundle-tile-ico.t-stack{background:linear-gradient(135deg,#1d4673,#15355c);color:#d8b97a}
.bundle-tile-ico.t-ai{background:linear-gradient(135deg,#2d7263,#1f4e44);color:#d8b97a}
.bundle-tile-ico.t-crm{background:linear-gradient(135deg,#b8893a,#7a5e2d);color:#fff}
.bundle-tile-ico.t-analytics{background:linear-gradient(135deg,#0ea5e9,#1d4673);color:#fff}
.bundle-tile-ico.t-funnel{background:linear-gradient(135deg,#d8b97a,#b8893a);color:#0a1a2f}
.bundle-tile-ico.t-wa{background:#25d366;color:#fff}
.bundle-tile-ico.t-shield{background:linear-gradient(135deg,#2d7263,#0a1a2f);color:#d8b97a}

.bundle-actions{display:grid;gap:.7rem;margin-bottom:1.4rem}
.bundle-btn-primary{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:.6rem;
  padding:1.15rem 1.6rem;
  background:linear-gradient(135deg, var(--gold-500), var(--gold-600));
  color:var(--navy-900);
  border-radius:14px;
  font-weight:700;
  font-size:1.02rem;
  letter-spacing:.005em;
  border:none;
  cursor:pointer;
  transition:transform var(--t-fast), box-shadow var(--t-fast), filter var(--t-fast);
  box-shadow:0 14px 32px rgba(184,137,58,.36);
}
.bundle-btn-primary:hover{transform:translateY(-2px);box-shadow:0 18px 40px rgba(184,137,58,.44);color:var(--navy-900);filter:brightness(1.04)}
.bundle-btn-secondary{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:.6rem;
  padding:1rem 1.4rem;
  background:rgba(255,255,255,.04);
  color:#fff;
  border:1px solid rgba(255,255,255,.18);
  border-radius:14px;
  font-weight:600;
  font-size:.96rem;
  transition:background var(--t-fast), border-color var(--t-fast);
}
.bundle-btn-secondary:hover{background:rgba(37,211,102,.12);border-color:#25d366;color:#fff}
.bundle-trust{
  list-style:none;
  padding:1.2rem 0 0;
  margin:0;
  border-top:1px solid rgba(212,184,122,.14);
  display:flex;
  flex-wrap:wrap;
  gap:1.4rem;
  font-size:.85rem;
  color:#bcb6a3;
}
.bundle-trust li{display:inline-flex;align-items:center;gap:.45rem}
.bundle-trust li::before{content:"✓";color:var(--gold-400);font-weight:700}

/* ===========================================================
   AI-GENERATED IMAGE FIGURES
   Used to give every page contextual editorial imagery
   =========================================================== */
.ai-figure{
  position:relative;
  margin:0;
  border-radius:var(--radius-lg);
  overflow:hidden;
  background:var(--cream);
  border:1px solid var(--line);
  box-shadow:var(--shadow);
  transition:transform var(--t), box-shadow var(--t);
}
.ai-figure:hover{transform:translateY(-3px);box-shadow:var(--shadow-lg)}
.ai-figure img{
  width:100%;
  height:100%;
  object-fit:cover;
  aspect-ratio:4/3;
  display:block;
  background:linear-gradient(135deg, #1d4673, #0a1a2f);
  color:transparent;
  font-size:0;
}
.ai-figure figcaption{
  position:absolute;
  left:0;right:0;bottom:0;
  padding:1.2rem 1.2rem 1rem;
  background:linear-gradient(180deg, transparent, rgba(10,26,47,.88) 60%);
  color:#fff;
  font-size:.85rem;
  font-weight:500;
  letter-spacing:.01em;
}
.ai-figure figcaption .tag{
  display:inline-block;
  font-family:'Inter',sans-serif;
  font-size:.66rem;
  font-weight:700;
  letter-spacing:.18em;
  text-transform:uppercase;
  color:var(--gold-400);
  margin-bottom:.3rem;
}
.ai-figure.wide{grid-column:span 2}
@media (max-width:760px){.ai-figure.wide{grid-column:auto}}

.ai-gallery{
  display:grid;
  grid-template-columns:repeat(3, minmax(0,1fr));
  gap:clamp(14px,1.6vw,22px);
}
@media (max-width:900px){.ai-gallery{grid-template-columns:1fr 1fr}}
@media (max-width:560px){.ai-gallery{grid-template-columns:1fr}}

.ai-hero-banner{
  position:relative;
  border-radius:var(--radius-xl);
  overflow:hidden;
  margin:1rem 0 0;
  box-shadow:var(--shadow-lg);
  aspect-ratio:21/9;
}
.ai-hero-banner img{width:100%;height:100%;object-fit:cover;display:block}
.ai-hero-banner::after{
  content:"";
  position:absolute;inset:0;
  background:linear-gradient(180deg, transparent 40%, rgba(10,26,47,.55));
}
.ai-hero-banner .tag{
  position:absolute;
  left:24px;bottom:20px;
  z-index:2;
  color:#fff;
  font-family:'Inter',sans-serif;
  font-size:.78rem;
  font-weight:600;
  letter-spacing:.16em;
  text-transform:uppercase;
  padding:.5rem .9rem;
  background:rgba(10,26,47,.55);
  backdrop-filter:blur(6px);
  border-radius:8px;
  border:1px solid rgba(212,184,122,.22);
}

/* ===========================================================
   CTA BAR — compact horizontal lead-capture bar
   Repeated 2x per page (top + mid); pairs with .bundle-cta (bottom)
   =========================================================== */
.cta-bar{
  position:relative;
  margin:0;
  background:
    radial-gradient(700px 220px at 92% 0%, rgba(184,137,58,.22), transparent 60%),
    linear-gradient(125deg, #0a1a2f 0%, #102943 55%, #0a1a2f 100%);
  color:#e9e3d4;
  border:1px solid rgba(212,184,122,.18);
  border-radius:var(--radius-xl);
  padding:clamp(22px,2.6vw,34px);
  overflow:hidden;
  box-shadow:0 24px 56px rgba(10,26,47,.22);
}
.cta-bar::before{
  content:"";
  position:absolute;inset:0;
  background-image:
    linear-gradient(rgba(212,184,122,.05) 1px, transparent 1px),
    linear-gradient(90deg, rgba(212,184,122,.05) 1px, transparent 1px);
  background-size:36px 36px;
  pointer-events:none;
  mask-image:radial-gradient(ellipse at center, #000 0%, transparent 80%);
  -webkit-mask-image:radial-gradient(ellipse at center, #000 0%, transparent 80%);
}
.cta-bar > *{position:relative;z-index:1}

.cta-bar-top{
  display:flex;
  align-items:center;
  gap:1.2rem;
  flex-wrap:wrap;
  margin-bottom:1.1rem;
}
.cta-bar-pill{
  display:inline-flex;
  align-items:center;
  gap:.4rem;
  padding:.45rem .9rem;
  background:linear-gradient(135deg, var(--gold-500), var(--gold-400));
  color:var(--navy-900);
  border-radius:8px;
  font-family:'Inter',sans-serif;
  font-weight:700;
  font-size:.72rem;
  letter-spacing:.18em;
  text-transform:uppercase;
  box-shadow:0 6px 18px rgba(184,137,58,.32);
}
.cta-bar-heading{
  font-family:'Fraunces',serif;
  font-size:clamp(1.35rem,2.4vw,1.95rem);
  color:#fff;
  margin:0;
  font-weight:500;
  letter-spacing:-.015em;
  line-height:1.15;
  flex:1 1 auto;
  min-width:240px;
}
.cta-bar-heading em{
  font-style:italic;
  background:linear-gradient(90deg, var(--gold-400), var(--gold-500));
  -webkit-background-clip:text;
  background-clip:text;
  color:transparent;
}
.cta-bar-sub{
  margin:.2rem 0 0;
  color:#bcb6a3;
  font-size:.92rem;
  flex-basis:100%;
}

.cta-bar-services{
  display:grid;
  grid-template-columns:repeat(7, minmax(0,1fr));
  gap:.55rem;
  margin-bottom:1.2rem;
}
@media (max-width:1200px){.cta-bar-services{grid-template-columns:repeat(4, minmax(0,1fr))}}
@media (max-width:760px){.cta-bar-services{grid-template-columns:repeat(2, minmax(0,1fr))}}
@media (max-width:420px){.cta-bar-services{grid-template-columns:1fr 1fr}}

.cta-bar-chip{
  display:flex;
  align-items:center;
  gap:.55rem;
  padding:.55rem .7rem;
  background:rgba(255,255,255,.04);
  border:1px solid rgba(212,184,122,.14);
  border-radius:10px;
  font-size:.84rem;
  color:#fff;
  font-weight:500;
  transition:background var(--t-fast), border-color var(--t-fast), transform var(--t-fast);
}
.cta-bar-chip:hover{background:rgba(255,255,255,.07);border-color:rgba(212,184,122,.32);transform:translateY(-1px)}
.cta-bar-chip-ico{
  flex:0 0 30px;
  height:30px;
  border-radius:7px;
  display:grid;place-items:center;
  font-size:.85rem;font-weight:700;
  box-shadow:inset 0 0 0 1px rgba(255,255,255,.1), 0 3px 8px rgba(0,0,0,.18);
}
.cta-bar-chip-ico.c-web{background:linear-gradient(135deg,#d8b97a,#b8893a);color:#0a1a2f}
.cta-bar-chip-ico.c-design{background:linear-gradient(135deg,#e9c46a,#d4a017);color:#0a1a2f}
.cta-bar-chip-ico.c-seo{background:linear-gradient(135deg,#34d399,#0ea5e9 60%,#a855f7);color:#fff}
.cta-bar-chip-ico.c-aeo{background:linear-gradient(135deg,#2d7263,#1f4e44);color:#d8b97a}
.cta-bar-chip-ico.c-social{background:linear-gradient(135deg,#f58529,#dd2a7b 50%,#8134af 90%);color:#fff}
.cta-bar-chip-ico.c-content{background:linear-gradient(135deg,#b8893a,#7a5e2d);color:#fff}
.cta-bar-chip-ico.c-ads{background:#fff;color:#0a1a2f}
.cta-bar-chip-name{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}

.cta-bar-actions{
  display:flex;
  flex-wrap:wrap;
  gap:.6rem;
  align-items:center;
  padding-top:.4rem;
  border-top:1px dashed rgba(212,184,122,.18);
}
.cta-bar-price{
  display:flex;
  align-items:baseline;
  gap:.35rem;
  margin-right:.6rem;
}
.cta-bar-price-from{
  font-family:'Inter',sans-serif;
  font-size:.68rem;
  letter-spacing:.18em;
  text-transform:uppercase;
  color:#8d8773;
}
.cta-bar-price-num{
  font-family:'Fraunces',serif;
  font-size:1.7rem;
  color:var(--gold-400);
  font-weight:500;
  line-height:1;
  letter-spacing:-.02em;
}
.cta-bar-price-unit{
  color:#bcb6a3;
  font-size:.85rem;
}
.cta-bar-btn-primary{
  display:inline-flex;align-items:center;gap:.5rem;
  padding:.85rem 1.3rem;
  background:linear-gradient(135deg, var(--gold-500), var(--gold-600));
  color:var(--navy-900);
  border-radius:12px;
  font-weight:700;
  font-size:.92rem;
  box-shadow:0 12px 24px rgba(184,137,58,.32);
  transition:transform var(--t-fast), filter var(--t-fast);
}
.cta-bar-btn-primary:hover{transform:translateY(-1px);filter:brightness(1.05);color:var(--navy-900)}
.cta-bar-btn-secondary{
  display:inline-flex;align-items:center;gap:.45rem;
  padding:.75rem 1.1rem;
  background:rgba(37,211,102,.08);
  color:#fff;
  border:1px solid rgba(37,211,102,.4);
  border-radius:12px;
  font-weight:600;
  font-size:.86rem;
  transition:background var(--t-fast);
}
.cta-bar-btn-secondary:hover{background:rgba(37,211,102,.18);color:#fff}

.cta-bar-trust{
  list-style:none;
  margin:1rem 0 0;
  padding:.9rem 0 0;
  border-top:1px solid rgba(212,184,122,.12);
  display:flex;
  flex-wrap:wrap;
  gap:1.2rem;
  font-size:.78rem;
  color:#bcb6a3;
}
.cta-bar-trust li{display:inline-flex;align-items:center;gap:.4rem}
.cta-bar-trust li::before{content:"✓";color:var(--gold-400);font-weight:700}

/* Section wrapper that pairs CTA bar with proper page padding */
.cta-bar-wrap{padding:clamp(20px,3vw,40px) 0}

/* ===========================================================
   UNIFIED ENQUIRY FORM
   One form, used everywhere on the site
   =========================================================== */
.enquiry-form{
  display:grid;
  gap:1rem;
}
.enquiry-form .row{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:1rem;
}
@media (max-width:600px){.enquiry-form .row{grid-template-columns:1fr}}
.enquiry-form label{
  display:block;
  font-size:.84rem;
  font-weight:600;
  color:var(--navy-800);
  margin-bottom:.4rem;
}
.enquiry-form input[type="text"],
.enquiry-form input[type="email"],
.enquiry-form input[type="tel"]{
  width:100%;
  padding:.9rem 1rem;
  border:1px solid var(--line-strong);
  border-radius:10px;
  background:#fff;
  font-family:inherit;
  font-size:.96rem;
  color:var(--ink);
  transition:border-color var(--t-fast), box-shadow var(--t-fast);
}
.enquiry-form input:focus{
  outline:none;
  border-color:var(--gold-500);
  box-shadow:0 0 0 4px rgba(201,160,80,.18);
}
.services-grid{
  display:grid;
  grid-template-columns:repeat(2, minmax(0,1fr));
  gap:.6rem;
  margin-top:.2rem;
}
@media (max-width:480px){.services-grid{grid-template-columns:1fr}}
.services-grid label.svc{
  display:flex;
  align-items:flex-start;
  gap:.6rem;
  padding:.7rem .9rem;
  border:1px solid var(--line);
  background:#fff;
  border-radius:10px;
  cursor:pointer;
  font-size:.9rem;
  font-weight:500;
  color:var(--ink);
  transition:border-color var(--t-fast), background var(--t-fast);
  margin-bottom:0;
}
.services-grid label.svc:hover{border-color:var(--gold-500);background:#fffaf0}
.services-grid label.svc input[type="checkbox"]{
  appearance:none;
  -webkit-appearance:none;
  width:18px;height:18px;
  flex:0 0 18px;
  border:1.5px solid var(--line-strong);
  border-radius:5px;
  background:#fff;
  margin-top:.05rem;
  cursor:pointer;
  position:relative;
  transition:border-color var(--t-fast), background var(--t-fast);
}
.services-grid label.svc input[type="checkbox"]:checked{
  background:var(--gold-500);
  border-color:var(--gold-600);
}
.services-grid label.svc input[type="checkbox"]:checked::after{
  content:"✓";
  position:absolute;
  inset:0;
  display:grid;
  place-items:center;
  color:#fff;
  font-size:.78rem;
  font-weight:800;
}
.services-grid label.svc:has(input:checked){
  border-color:var(--gold-500);
  background:#fffaf0;
}
.enquiry-form .submit-btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:.5rem;
  padding:1rem 1.6rem;
  background:linear-gradient(135deg, var(--gold-500), var(--gold-600));
  color:var(--navy-900);
  border:none;
  border-radius:12px;
  font-weight:700;
  font-size:1rem;
  cursor:pointer;
  box-shadow:0 12px 28px rgba(184,137,58,.28);
  transition:transform var(--t-fast), filter var(--t-fast);
}
.enquiry-form .submit-btn:hover{transform:translateY(-1px);filter:brightness(1.05)}
.enquiry-form .form-success{
  margin:0;
  padding:1rem 1.2rem;
  background:rgba(45,114,99,.08);
  border:1px solid rgba(45,114,99,.3);
  border-radius:10px;
  color:var(--emerald-700);
  font-weight:600;
  font-size:.94rem;
}
.enquiry-form .form-hint{
  margin:0;
  font-size:.78rem;
  color:var(--muted);
  text-align:center;
}
