@import url('https://fonts.googleapis.com/css2?family=Playfair+Display:wght@400;600;700;800&family=Inter:wght@300;400;500;600;700&display=swap');

:root {
  --navy:       #0a1628;
  --navy-mid:   #0f2040;
  --navy-light: #162d52;
  --gold:       #c9a84c;
  --gold-light: #e2c078;
  --gold-pale:  #f5e9ca;
  --white:      #ffffff;
  --off-white:  #f4f6fa;
  --text-body:  #3d4f6b;
  --text-muted: #7a8fa6;
  --border:     #dce4ef;
  --shadow-sm:  0 2px 12px rgba(10,22,40,0.08);
  --shadow-md:  0 8px 32px rgba(10,22,40,0.12);
  --shadow-lg:  0 20px 60px rgba(10,22,40,0.16);
}

*, *::before, *::after { margin:0; padding:0; box-sizing:border-box; }
html { scroll-behavior:smooth; }
body { background:var(--white); color:var(--navy); font-family:'Inter',sans-serif; overflow-x:hidden; }

/* ── TOPBAR ── */
.topbar { background:var(--navy); padding:8px 60px; display:flex; justify-content:space-between; align-items:center; }
.topbar p { font-size:0.72rem; color:rgba(255,255,255,0.5); letter-spacing:0.3px; }
.topbar-right { display:flex; gap:24px; }
.topbar-right a { font-size:0.72rem; color:var(--gold); text-decoration:none; }
.topbar-right a:hover { color:var(--gold-light); }

/* ── NAV ── */
nav { position:sticky; top:0; z-index:1000; background:var(--white); border-bottom:1px solid var(--border); display:flex; align-items:center; justify-content:space-between; padding:0 60px; height:72px; box-shadow:var(--shadow-sm); }
.nav-logo { display:flex; align-items:center; gap:4px; text-decoration:none; }
.ez-logo { display:inline-flex; flex-direction:column; line-height:1; }
.ez-logo-name { display:flex; align-items:baseline; gap:4px; }
.ez-logo-ez { font-family:'Playfair Display',serif; font-weight:800; color:var(--navy); letter-spacing:-0.5px; line-height:1; }
.ez-logo-tax { font-family:'Playfair Display',serif; font-weight:400; color:var(--gold); letter-spacing:-0.5px; line-height:1; }
.ez-logo-rule { width:100%; height:1.5px; margin:4px 0 3px; background:linear-gradient(90deg,var(--gold) 0%,transparent 100%); border:none; display:block; }
.ez-logo-sub { font-family:'Inter',sans-serif; font-size:0.48rem; font-weight:600; color:var(--text-muted); letter-spacing:2px; text-transform:uppercase; white-space:nowrap; }
.ez-logo--nav .ez-logo-ez  { font-size:1.45rem; }
.ez-logo--nav .ez-logo-tax { font-size:1.45rem; }
.ez-logo--nav .ez-logo-sub { font-size:0.5rem; letter-spacing:1.8px; }
.ez-logo--lg .ez-logo-ez   { font-size:2.1rem; }
.ez-logo--lg .ez-logo-tax  { font-size:2.1rem; }
.ez-logo--lg .ez-logo-sub  { font-size:0.58rem; letter-spacing:2.5px; }
.ez-logo--dark .ez-logo-ez  { color:var(--white); }
.ez-logo--dark .ez-logo-sub { color:rgba(255,255,255,0.38); }
.nav-links { display:flex; gap:0; list-style:none; height:72px; }
.nav-links li { display:flex; align-items:center; }
.nav-links a { display:flex; align-items:center; height:72px; padding:0 18px; color:var(--text-body); text-decoration:none; font-size:0.88rem; font-weight:500; border-bottom:3px solid transparent; transition:all 0.2s; }
.nav-links a:hover, .nav-links a.active { color:var(--navy); border-bottom-color:var(--gold); }
.nav-actions { display:flex; gap:12px; align-items:center; }
.btn-ghost { background:transparent; border:1.5px solid var(--border); color:var(--navy); font-size:0.85rem; font-weight:600; padding:9px 22px; border-radius:4px; cursor:pointer; transition:all 0.2s; text-decoration:none; display:inline-block; }
.btn-ghost:hover { border-color:var(--navy); }
.btn-navy { background:var(--navy); color:var(--white); font-size:0.85rem; font-weight:600; padding:10px 24px; border-radius:4px; border:none; cursor:pointer; transition:all 0.2s; text-decoration:none; display:inline-block; }
.btn-navy:hover { background:var(--navy-mid); box-shadow:var(--shadow-md); }
.btn-gold { background:var(--gold); color:var(--navy); font-weight:700; font-size:0.9rem; padding:13px 30px; border-radius:3px; border:none; cursor:pointer; letter-spacing:0.2px; transition:all 0.2s; text-decoration:none; display:inline-block; }
.btn-gold:hover { background:var(--gold-light); box-shadow:0 6px 20px rgba(201,168,76,0.35); }
.btn-outline-white { background:transparent; color:var(--white); font-weight:600; font-size:0.9rem; padding:13px 30px; border-radius:3px; border:1.5px solid rgba(255,255,255,0.25); cursor:pointer; transition:all 0.2s; text-decoration:none; display:inline-block; }
.btn-outline-white:hover { border-color:rgba(255,255,255,0.6); }

/* ── PAGE HERO (inner pages) ── */
.page-hero { background:var(--navy); padding:72px 60px 64px; position:relative; overflow:hidden; }
.page-hero::before { content:''; position:absolute; top:-100px; right:-100px; width:400px; height:400px; border-radius:50%; background:rgba(201,168,76,0.04); pointer-events:none; }
.page-hero-inner { max-width:1200px; margin:0 auto; position:relative; z-index:1; }
.page-hero-label { font-size:0.72rem; font-weight:700; letter-spacing:2.5px; text-transform:uppercase; color:var(--gold); margin-bottom:12px; display:block; }
.page-hero h1 { font-family:'Playfair Display',serif; font-size:clamp(2rem,4vw,3rem); font-weight:800; color:var(--white); line-height:1.1; letter-spacing:-0.3px; margin-bottom:16px; }
.page-hero h1 em { color:var(--gold); font-style:normal; }
.page-hero p { color:rgba(255,255,255,0.6); font-size:1rem; line-height:1.75; max-width:560px; }
.breadcrumb { display:flex; align-items:center; gap:8px; margin-bottom:28px; }
.breadcrumb a { font-size:0.78rem; color:rgba(255,255,255,0.45); text-decoration:none; transition:color 0.2s; }
.breadcrumb a:hover { color:var(--gold); }
.breadcrumb span { font-size:0.78rem; color:rgba(255,255,255,0.25); }
.breadcrumb strong { font-size:0.78rem; color:var(--gold); }

/* ── SECTION SHARED ── */
.section-inner { max-width:1200px; margin:0 auto; padding:80px 60px; }
.section-label { font-size:0.72rem; font-weight:700; letter-spacing:2.5px; text-transform:uppercase; color:var(--gold); margin-bottom:12px; display:block; }
.section-title { font-family:'Playfair Display',serif; font-size:clamp(1.7rem,3vw,2.5rem); font-weight:700; color:var(--navy); line-height:1.2; letter-spacing:-0.3px; margin-bottom:14px; }
.section-sub { color:var(--text-muted); font-size:0.95rem; line-height:1.75; max-width:520px; }
.section-header { display:flex; justify-content:space-between; align-items:flex-end; margin-bottom:48px; flex-wrap:wrap; gap:24px; }
.divider { width:48px; height:3px; background:var(--gold); border-radius:2px; margin-top:16px; }

/* ── SERVICES CARDS ── */
.services-grid-3 { display:grid; grid-template-columns:repeat(3,1fr); gap:1px; background:var(--border); border:1px solid var(--border); border-radius:8px; overflow:hidden; box-shadow:var(--shadow-sm); }
.services-grid-2 { display:grid; grid-template-columns:repeat(2,1fr); gap:24px; }
.service-card { background:var(--white); padding:36px 32px; transition:all 0.25s; cursor:pointer; position:relative; }
.service-card::after { content:''; position:absolute; bottom:0; left:32px; right:32px; height:2px; background:var(--gold); transform:scaleX(0); transition:transform 0.3s; }
.service-card:hover { background:var(--off-white); }
.service-card:hover::after { transform:scaleX(1); }
.service-num { font-size:0.7rem; font-weight:700; color:var(--gold); letter-spacing:1.5px; margin-bottom:20px; }
.service-icon-wrap { width:48px; height:48px; border-radius:6px; background:var(--off-white); border:1px solid var(--border); display:flex; align-items:center; justify-content:center; font-size:1.3rem; margin-bottom:18px; transition:all 0.25s; }
.service-card:hover .service-icon-wrap { background:var(--navy); border-color:var(--navy); }
.service-card h3 { font-size:1rem; font-weight:700; color:var(--navy); margin-bottom:10px; }
.service-card p { font-size:0.84rem; color:var(--text-muted); line-height:1.7; }
.service-link { display:inline-flex; align-items:center; gap:6px; color:var(--gold); font-size:0.8rem; font-weight:700; margin-top:16px; text-decoration:none; letter-spacing:0.3px; text-transform:uppercase; }

/* ── WHY US ── */
.why-section { background:var(--navy); }
.why-section .section-title { color:var(--white); }
.why-section .section-label { color:var(--gold); }
.why-section .section-sub { color:rgba(255,255,255,0.55); }
.why-grid { display:grid; grid-template-columns:1fr 1fr; gap:64px; align-items:center; }
.metric-item { padding:20px 0; border-bottom:1px solid rgba(255,255,255,0.07); }
.metric-item:first-child { padding-top:0; }
.metric-top { display:flex; justify-content:space-between; align-items:center; margin-bottom:10px; }
.metric-name { font-size:0.85rem; color:rgba(255,255,255,0.6); }
.metric-value { font-family:'Playfair Display',serif; font-size:1.1rem; font-weight:700; color:var(--gold); }
.metric-track { height:4px; background:rgba(255,255,255,0.07); border-radius:2px; overflow:hidden; }
.metric-fill { height:100%; background:linear-gradient(90deg,var(--gold),var(--gold-light)); border-radius:2px; }
.why-features { display:flex; flex-direction:column; gap:28px; }
.why-feature { display:flex; gap:18px; }
.why-feature-icon { width:46px; height:46px; border-radius:6px; background:rgba(201,168,76,0.1); border:1px solid rgba(201,168,76,0.2); display:flex; align-items:center; justify-content:center; font-size:1.2rem; flex-shrink:0; }
.why-feature h4 { font-size:0.95rem; font-weight:700; color:var(--white); margin-bottom:6px; }
.why-feature p { font-size:0.83rem; color:rgba(255,255,255,0.5); line-height:1.7; }

/* ── TESTIMONIALS ── */
.testimonials-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:24px; }
.testimonial-card { background:var(--white); border:1px solid var(--border); border-radius:8px; padding:32px; box-shadow:var(--shadow-sm); transition:all 0.3s; }
.testimonial-card:hover { box-shadow:var(--shadow-md); transform:translateY(-3px); }
.quote-mark { font-family:'Playfair Display',serif; font-size:3rem; color:var(--gold); line-height:1; margin-bottom:12px; opacity:0.6; }
.testimonial-text { font-size:0.88rem; color:var(--text-body); line-height:1.8; margin-bottom:24px; }
.stars { color:var(--gold); font-size:0.78rem; letter-spacing:2px; margin-bottom:6px; }
.author-info { display:flex; align-items:center; gap:12px; padding-top:20px; border-top:1px solid var(--border); }
.avatar { width:40px; height:40px; border-radius:50%; background:var(--navy); display:flex; align-items:center; justify-content:center; font-size:0.9rem; font-weight:700; color:var(--white); flex-shrink:0; }
.author-name { font-size:0.88rem; font-weight:700; color:var(--navy); }
.author-role { font-size:0.75rem; color:var(--text-muted); }

/* ── CTA BANNER ── */
.cta-section { background:var(--navy); position:relative; overflow:hidden; }
.cta-section::before { content:''; position:absolute; top:-200px; right:-200px; width:500px; height:500px; border-radius:50%; background:rgba(201,168,76,0.04); pointer-events:none; }
.cta-inner { max-width:800px; margin:0 auto; padding:90px 60px; text-align:center; }
.cta-inner h2 { font-family:'Playfair Display',serif; font-size:clamp(1.9rem,3.5vw,2.9rem); font-weight:800; color:var(--white); letter-spacing:-0.3px; margin-bottom:16px; }
.cta-inner p { color:rgba(255,255,255,0.55); font-size:1rem; line-height:1.75; margin-bottom:36px; }
.cta-btns { display:flex; gap:12px; justify-content:center; flex-wrap:wrap; }

/* ── TEMPLATES / SHOP ── */
.templates-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:24px; }
.template-card { border:1px solid var(--border); border-radius:8px; overflow:hidden; transition:all 0.3s; box-shadow:var(--shadow-sm); }
.template-card:hover { transform:translateY(-4px); box-shadow:var(--shadow-lg); border-color:var(--gold); }
.template-preview { height:120px; display:flex; align-items:center; justify-content:center; font-size:2.2rem; position:relative; }
.tp-navy { background:var(--navy); }
.tp-navy2 { background:var(--navy-mid); }
.tp-navy3 { background:var(--navy-light); }
.template-tag { position:absolute; top:10px; right:10px; background:var(--gold); color:var(--navy); font-size:0.65rem; font-weight:800; padding:3px 8px; border-radius:2px; letter-spacing:0.8px; text-transform:uppercase; }
.template-body { padding:20px; }
.template-body h3 { font-size:0.92rem; font-weight:700; color:var(--navy); margin-bottom:6px; }
.template-body p { font-size:0.8rem; color:var(--text-muted); line-height:1.6; margin-bottom:16px; }
.template-footer-row { display:flex; align-items:center; justify-content:space-between; padding-top:14px; border-top:1px solid var(--border); }
.template-price { font-size:1rem; font-weight:800; color:var(--navy); }
.template-price s { font-size:0.78rem; color:var(--text-muted); font-weight:400; margin-right:4px; }
.btn-buy { background:transparent; border:1.5px solid var(--navy); color:var(--navy); font-size:0.76rem; font-weight:700; padding:7px 16px; border-radius:3px; cursor:pointer; transition:all 0.2s; }
.btn-buy:hover { background:var(--navy); color:var(--white); }

/* ── FORM STYLES ── */
.form-card { background:var(--white); border:1px solid var(--border); border-radius:8px; overflow:hidden; box-shadow:var(--shadow-md); }
.form-card-header { background:var(--navy); padding:24px 32px; }
.form-card-header h3 { font-family:'Playfair Display',serif; font-size:1.2rem; color:var(--white); }
.form-card-header p { font-size:0.8rem; color:rgba(255,255,255,0.5); margin-top:4px; }
.form-card-body { padding:32px; }
.form-group { margin-bottom:20px; }
.form-group label { display:block; font-size:0.72rem; font-weight:700; color:var(--navy); letter-spacing:1px; text-transform:uppercase; margin-bottom:8px; }
.form-group input, .form-group select, .form-group textarea {
  width:100%; background:var(--white); border:1.5px solid var(--border);
  border-radius:4px; padding:12px 14px; color:var(--navy); font-size:0.88rem;
  font-family:'Inter',sans-serif; outline:none; transition:border-color 0.2s;
}
.form-group textarea { resize:vertical; min-height:120px; }
.form-group input:focus, .form-group select:focus, .form-group textarea:focus { border-color:var(--navy); box-shadow:0 0 0 3px rgba(10,22,40,0.06); }
.form-row { display:grid; grid-template-columns:1fr 1fr; gap:16px; }
.check { width:20px; height:20px; border-radius:50%; background:var(--navy); display:flex; align-items:center; justify-content:center; flex-shrink:0; margin-top:1px; }

/* ── FOOTER ── */
footer { background:var(--navy-mid); border-top:1px solid rgba(255,255,255,0.06); padding:56px 60px 32px; }
.footer-grid { display:grid; grid-template-columns:2fr 1fr 1fr 1fr; gap:48px; margin-bottom:48px; }
.footer-brand p { color:rgba(255,255,255,0.4); font-size:0.82rem; line-height:1.75; margin-top:14px; max-width:260px; }
.footer-badge { display:inline-flex; align-items:center; gap:6px; background:rgba(201,168,76,0.1); border:1px solid rgba(201,168,76,0.2); border-radius:3px; padding:5px 12px; margin-top:16px; }
.footer-badge span { font-size:0.68rem; font-weight:700; letter-spacing:1px; text-transform:uppercase; color:var(--gold); }
.footer-col h4 { font-size:0.68rem; font-weight:700; letter-spacing:2px; text-transform:uppercase; color:rgba(255,255,255,0.35); margin-bottom:16px; }
.footer-col ul { list-style:none; display:flex; flex-direction:column; gap:10px; }
.footer-col ul li a { color:rgba(255,255,255,0.5); text-decoration:none; font-size:0.83rem; transition:color 0.2s; }
.footer-col ul li a:hover { color:var(--gold); }
.footer-bottom { border-top:1px solid rgba(255,255,255,0.07); padding-top:24px; display:flex; justify-content:space-between; align-items:center; flex-wrap:wrap; gap:12px; }
.footer-bottom p { font-size:0.77rem; color:rgba(255,255,255,0.3); }
.footer-socials { display:flex; gap:8px; }
.social-btn { width:32px; height:32px; border-radius:4px; background:rgba(255,255,255,0.05); border:1px solid rgba(255,255,255,0.1); display:flex; align-items:center; justify-content:center; font-size:0.8rem; cursor:pointer; transition:all 0.2s; text-decoration:none; color:rgba(255,255,255,0.4); font-weight:700; }
.social-btn:hover { border-color:var(--gold); color:var(--gold); }

/* ── CHAT WIDGET ── */
#chat-toggle { position:fixed; bottom:28px; right:28px; z-index:9999; background:var(--navy); color:var(--white); width:56px; height:56px; border-radius:50%; border:none; cursor:pointer; display:flex; align-items:center; justify-content:center; font-size:1.2rem; box-shadow:0 8px 24px rgba(10,22,40,0.35); transition:all 0.2s; }
#chat-toggle:hover { background:var(--navy-mid); transform:scale(1.05); }
#chat-window { position:fixed; bottom:96px; right:28px; z-index:9999; width:360px; background:var(--white); border:1px solid var(--border); border-radius:10px; overflow:hidden; box-shadow:var(--shadow-lg); transform:scale(0.95) translateY(10px); opacity:0; pointer-events:none; transition:all 0.25s ease; }
#chat-window.open { transform:scale(1) translateY(0); opacity:1; pointer-events:all; }
.chat-header { background:var(--navy); padding:16px 20px; display:flex; align-items:center; gap:12px; }
.chat-avatar { width:36px; height:36px; border-radius:50%; background:rgba(201,168,76,0.15); border:1px solid rgba(201,168,76,0.3); display:flex; align-items:center; justify-content:center; font-size:1rem; flex-shrink:0; }
.chat-header-info h4 { font-size:0.88rem; font-weight:700; color:var(--white); }
.online { display:flex; align-items:center; gap:5px; font-size:0.7rem; color:rgba(255,255,255,0.4); margin-top:2px; }
.online-dot { width:6px; height:6px; border-radius:50%; background:#4ade80; animation:pulse 2s infinite; }
.chat-messages { height:240px; overflow-y:auto; padding:16px; display:flex; flex-direction:column; gap:10px; background:var(--off-white); }
.msg { max-width:82%; padding:10px 14px; border-radius:8px; font-size:0.82rem; line-height:1.6; }
.msg.bot { background:var(--white); border:1px solid var(--border); align-self:flex-start; color:var(--navy); }
.msg.user { background:var(--navy); color:var(--white); align-self:flex-end; }
.chat-quick { display:flex; gap:7px; padding:10px 14px; flex-wrap:wrap; background:var(--white); border-top:1px solid var(--border); border-bottom:1px solid var(--border); }
.quick-btn { background:var(--off-white); border:1.5px solid var(--border); color:var(--navy); font-size:0.71rem; font-weight:600; padding:5px 10px; border-radius:3px; cursor:pointer; transition:all 0.2s; white-space:nowrap; }
.quick-btn:hover { border-color:var(--gold); color:var(--gold); }
.chat-input-row { padding:12px 14px; display:flex; gap:8px; background:var(--white); }
.chat-input-row input { flex:1; background:var(--off-white); border:1.5px solid var(--border); border-radius:4px; padding:9px 12px; color:var(--navy); font-size:0.82rem; font-family:'Inter',sans-serif; outline:none; }
.chat-send { width:34px; height:34px; border-radius:4px; background:var(--navy); border:none; cursor:pointer; color:var(--white); font-size:0.9rem; display:flex; align-items:center; justify-content:center; transition:background 0.2s; }

/* ── ANIMATIONS ── */
@keyframes pulse { 0%,100%{opacity:1}50%{opacity:0.3} }
.reveal { opacity:0; transform:translateY(24px); transition:opacity 0.55s ease, transform 0.55s ease; }
.reveal.visible { opacity:1; transform:translateY(0); }

/* ── RESPONSIVE ── */
@media(max-width:960px) {
  .topbar { display:none; }
  nav { padding:0 24px; }
  .nav-links { display:none; }
  .page-hero { padding:56px 24px 48px; }
  .section-inner { padding:56px 24px; }
  .services-grid-3, .templates-grid, .testimonials-grid { grid-template-columns:1fr; }
  .services-grid-2, .why-grid { grid-template-columns:1fr; }
  .footer-grid { grid-template-columns:1fr 1fr; }
  .form-row { grid-template-columns:1fr; }
}

/* ══════════════════════════════════════
   NEW PAGE COMPONENTS — About, Bookings, Shop, Contact
   ══════════════════════════════════════ */

/* ── SHARED LAYOUT HELPERS ── */
.container { max-width:1160px; margin:0 auto; padding:0 40px; }
.section { padding:80px 0; }
.section-light { background:var(--off-white); }
.section-navy { background:var(--navy); }
.section-header.centered { text-align:center; max-width:680px; margin:0 auto 52px; }
.section-intro { color:var(--text-muted); font-size:1rem; margin-top:12px; }
.grid-2-col { display:grid; grid-template-columns:1fr 1fr; gap:60px; align-items:start; }
.grid-2-col.align-center { align-items:center; }

/* topbar inner layout */
.topbar-inner { display:flex; justify-content:space-between; align-items:center; max-width:1160px; margin:0 auto; width:100%; }
.topbar-left  { display:flex; gap:24px; }
.topbar-left span, .topbar-right span { font-size:0.72rem; color:rgba(255,255,255,0.5); letter-spacing:0.3px; }

/* Nav system (used across all pages) */
.navbar { position:sticky; top:0; z-index:1000; background:var(--white); border-bottom:1px solid var(--border); box-shadow:var(--shadow-sm); transition:background 0.3s; }
.navbar.scrolled { background:rgba(255,255,255,0.97); backdrop-filter:blur(8px); }
.nav-inner { display:flex; align-items:center; justify-content:space-between; padding:0 60px; height:72px; max-width:1400px; margin:0 auto; }
.nav-logo { display:flex; align-items:baseline; gap:2px; text-decoration:none; flex-direction:column; line-height:1.1; }
.logo-ez  { font-family:'Playfair Display',serif; font-weight:800; font-size:1.4rem; color:var(--navy); letter-spacing:-0.5px; }
.logo-tax { font-family:'Playfair Display',serif; font-weight:400; font-size:1.4rem; color:var(--gold); letter-spacing:-0.5px; }
.logo-sub { font-size:0.48rem; font-weight:600; color:var(--text-muted); letter-spacing:1.8px; text-transform:uppercase; white-space:nowrap; }
.nav-logo-row { display:flex; align-items:baseline; gap:2px; }
.nav-links { display:flex; gap:0; list-style:none; height:72px; }
.nav-links li { display:flex; align-items:center; }
.nav-links a { display:flex; align-items:center; height:72px; padding:0 18px; color:var(--text-body); text-decoration:none; font-size:0.88rem; font-weight:500; border-bottom:3px solid transparent; transition:all 0.2s; }
.nav-links a:hover, .nav-links a.active { color:var(--navy); border-bottom-color:var(--gold); font-weight:600; }
.nav-actions { display:flex; gap:10px; align-items:center; }
.btn-ghost { color:var(--text-body); font-size:0.85rem; font-weight:600; text-decoration:none; padding:8px 16px; border:1.5px solid var(--border); border-radius:3px; transition:all 0.2s; }
.btn-ghost:hover { border-color:var(--gold); color:var(--gold); }
.btn-navy  { background:var(--navy); color:var(--white); font-size:0.85rem; font-weight:700; text-decoration:none; padding:10px 22px; border-radius:3px; transition:background 0.2s; }
.btn-navy:hover { background:var(--navy-mid); }
.btn-gold  { background:var(--gold); color:var(--navy); font-weight:700; font-size:0.88rem; text-decoration:none; padding:12px 28px; border-radius:3px; border:none; cursor:pointer; transition:background 0.2s; display:inline-block; }
.btn-gold:hover { background:var(--gold-light); }
.btn-outline { background:transparent; color:var(--white); font-weight:600; font-size:0.88rem; text-decoration:none; padding:12px 28px; border-radius:3px; border:1.5px solid rgba(255,255,255,0.3); transition:all 0.2s; display:inline-block; }
.btn-outline:hover { border-color:var(--gold); color:var(--gold); }
.nav-hamburger { display:none; background:none; border:none; font-size:1.4rem; cursor:pointer; color:var(--navy); }
.mobile-menu { display:none; background:var(--white); border-top:1px solid var(--border); padding:20px 24px; }
.mobile-menu.open { display:block; }
.mobile-menu ul { list-style:none; }
.mobile-menu ul li { padding:10px 0; border-bottom:1px solid var(--border); }
.mobile-menu ul li:last-child { border-bottom:none; }
.mobile-menu ul li a { color:var(--navy); text-decoration:none; font-weight:500; font-size:0.95rem; }

/* Page hero */
.page-hero { background:var(--navy); padding:72px 40px 64px; }
.page-hero-inner { max-width:1160px; margin:0 auto; }
.breadcrumb { display:flex; gap:8px; align-items:center; margin-bottom:16px; }
.breadcrumb a { color:rgba(255,255,255,0.45); font-size:0.78rem; text-decoration:none; }
.breadcrumb a:hover { color:var(--gold); }
.breadcrumb span { color:rgba(255,255,255,0.3); font-size:0.78rem; }
.page-hero .section-label { color:var(--gold); display:block; margin-bottom:10px; font-size:0.7rem; font-weight:700; letter-spacing:3px; text-transform:uppercase; }
.page-hero h1 { font-family:'Playfair Display',serif; font-size:clamp(2rem,4.5vw,3rem); font-weight:800; color:var(--white); line-height:1.12; margin-bottom:16px; }
.page-hero h1 em { color:var(--gold); font-style:normal; }
.page-hero-sub { color:rgba(255,255,255,0.6); max-width:600px; line-height:1.75; font-size:1rem; }
.section-label { font-size:0.7rem; font-weight:700; letter-spacing:3px; text-transform:uppercase; color:var(--gold); display:block; margin-bottom:10px; }

/* CTA section */
.cta-section { background:var(--navy); padding:72px 40px; }
.cta-inner { display:flex; align-items:center; justify-content:space-between; gap:40px; flex-wrap:wrap; }
.cta-section h2 { color:var(--white); font-family:'Playfair Display',serif; margin-bottom:10px; }
.cta-section p { color:rgba(255,255,255,0.55); max-width:520px; }
.cta-actions { display:flex; gap:12px; align-items:center; flex-shrink:0; }

/* Footer */
.footer { background:var(--navy); padding:72px 40px 0; }
.footer-grid { display:grid; grid-template-columns:1.8fr 1fr 1fr 1fr; gap:48px; padding-bottom:48px; }
.footer-brand .footer-logo { display:flex; align-items:baseline; gap:2px; margin-bottom:4px; }
.footer-logo .logo-ez  { font-size:1.6rem; color:var(--white); }
.footer-logo .logo-tax { font-size:1.6rem; }
.footer-tagline { font-size:0.7rem; color:rgba(255,255,255,0.35); letter-spacing:1.5px; text-transform:uppercase; margin-bottom:0; }
.footer-col h5 { font-family:'Playfair Display',serif; color:var(--white); font-size:0.9rem; margin-bottom:16px; }
.footer-col ul { list-style:none; }
.footer-col ul li { margin-bottom:10px; }
.footer-col ul li a { color:rgba(255,255,255,0.45); font-size:0.82rem; text-decoration:none; transition:color 0.2s; }
.footer-col ul li a:hover { color:var(--gold); }
.footer-col ul li:not(:has(a)) { color:rgba(255,255,255,0.4); font-size:0.82rem; }
.footer-bottom { border-top:1px solid rgba(201,168,76,0.12); padding:24px 0; display:flex; justify-content:space-between; }
.footer-bottom p { font-size:0.75rem; color:rgba(255,255,255,0.25); }

/* Form elements */
.form-group { display:flex; flex-direction:column; gap:6px; margin-bottom:16px; }
.form-group label { font-size:0.82rem; font-weight:600; color:var(--navy); }
.form-group input, .form-group select, .form-group textarea {
  border:1.5px solid var(--border); border-radius:4px; padding:11px 14px;
  font-family:'Inter',sans-serif; font-size:0.88rem; color:var(--navy);
  background:var(--white); outline:none; transition:border-color 0.2s;
  width:100%;
}
.form-group input:focus, .form-group select:focus, .form-group textarea:focus { border-color:var(--gold); }
.form-row { display:grid; grid-template-columns:1fr 1fr; gap:16px; }
.form-card { background:var(--white); border:1px solid var(--border); border-radius:6px; padding:40px; box-shadow:var(--shadow-md); }

/* ── ABOUT PAGE ── */
.about-values-grid { display:grid; grid-template-columns:1fr 1fr; gap:16px; }
.value-card { background:var(--off-white); border-radius:4px; padding:24px 20px; border-top:3px solid var(--gold); }
.value-icon { font-size:1.4rem; margin-bottom:10px; }
.value-card h4 { font-family:'Playfair Display',serif; color:var(--navy); margin-bottom:8px; font-size:1rem; }
.value-card p  { font-size:0.84rem; color:var(--text-muted); line-height:1.7; }

.pull-quote-section { background:var(--off-white); padding:64px 40px; }
.pull-quote-card { background:var(--navy); border-radius:6px; padding:48px 52px; position:relative; max-width:860px; margin:0 auto; }
.pull-quote-card::before { content:'\201C'; font-family:'Playfair Display',Georgia,serif; font-size:7rem; color:rgba(201,168,76,0.1); position:absolute; top:0; left:28px; line-height:1; }
.pull-quote-card p { font-family:'Playfair Display',serif; font-size:1.2rem; font-style:italic; color:var(--white); line-height:1.8; position:relative; }
.pull-quote-card cite { display:block; margin-top:20px; font-size:0.72rem; font-weight:700; letter-spacing:2px; text-transform:uppercase; color:var(--gold); font-style:normal; }

.differentiators-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:28px; }
.diff-item { padding:28px 24px; background:var(--white); border-radius:4px; border:1px solid var(--border); }
.diff-number { font-family:'Playfair Display',serif; font-size:2rem; font-weight:700; color:var(--gold); opacity:0.5; margin-bottom:10px; line-height:1; }
.diff-item h3 { color:var(--navy); font-size:1rem; margin-bottom:8px; }
.diff-item p  { font-size:0.84rem; color:var(--text-muted); line-height:1.7; }

.cred-list { display:flex; flex-direction:column; gap:16px; }
.cred-item { display:flex; gap:14px; align-items:flex-start; }
.cred-icon { width:32px; height:32px; background:var(--navy); border-radius:50%; display:flex; align-items:center; justify-content:center; color:var(--gold); font-weight:700; font-size:0.85rem; flex-shrink:0; margin-top:2px; }
.cred-item h4 { font-size:0.92rem; color:var(--navy); margin-bottom:4px; }
.cred-item p  { font-size:0.82rem; color:var(--text-muted); line-height:1.65; }

.credentials-visual { display:grid; grid-template-columns:1fr 1fr; gap:16px; }
.stat-card { background:var(--off-white); border-radius:4px; padding:28px 20px; text-align:center; border-bottom:3px solid var(--gold); }
.stat-num { font-family:'Playfair Display',serif; font-size:1.8rem; font-weight:700; color:var(--navy); display:block; margin-bottom:6px; }
.stat-label { font-size:0.72rem; color:var(--text-muted); letter-spacing:0.5px; }

/* ── BOOKINGS PAGE ── */
.booking-packages { display:grid; grid-template-columns:repeat(3,1fr); gap:24px; margin-top:16px; }
.package-card { background:var(--white); border:1px solid var(--border); border-radius:6px; padding:32px 28px; display:flex; flex-direction:column; position:relative; transition:box-shadow 0.25s; }
.package-card:hover { box-shadow:var(--shadow-md); }
.package-card.featured { border-color:var(--gold); border-width:2px; }
.package-badge { position:absolute; top:-12px; left:50%; transform:translateX(-50%); background:var(--gold); color:var(--navy); font-size:0.7rem; font-weight:700; letter-spacing:1px; text-transform:uppercase; padding:5px 14px; border-radius:2px; white-space:nowrap; }
.package-header { margin-bottom:20px; }
.package-icon { font-size:1.8rem; display:block; margin-bottom:10px; }
.package-header h3 { color:var(--navy); font-family:'Playfair Display',serif; margin-bottom:8px; font-size:1.1rem; }
.package-price { font-family:'Playfair Display',serif; font-size:2rem; font-weight:700; color:var(--gold); line-height:1; }
.package-price span { font-size:0.85rem; font-weight:400; color:var(--text-muted); font-family:'Inter',sans-serif; }
.package-features { list-style:none; margin-bottom:24px; flex:1; }
.package-features li { font-size:0.85rem; color:var(--text-muted); padding:7px 0; border-bottom:1px solid var(--off-white); line-height:1.5; }
.package-features li:last-child { border-bottom:none; }

.steps-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:24px; }
.step-item { text-align:center; padding:24px 16px; }
.step-num { width:48px; height:48px; border-radius:50%; background:var(--navy); color:var(--gold); font-family:'Playfair Display',serif; font-size:1.2rem; font-weight:700; display:flex; align-items:center; justify-content:center; margin:0 auto 16px; }
.step-item h3 { color:var(--navy); font-size:0.95rem; margin-bottom:8px; }
.step-item p  { font-size:0.84rem; color:var(--text-muted); line-height:1.7; }

.form-layout { display:grid; grid-template-columns:1fr 1.3fr; gap:60px; align-items:start; }
.form-intro h2 { color:var(--navy); font-family:'Playfair Display',serif; margin-bottom:12px; }
.form-intro p  { color:var(--text-muted); margin-bottom:0; line-height:1.75; }
.form-info-items { margin-top:28px; display:flex; flex-direction:column; gap:16px; }
.form-info-item { display:flex; gap:14px; align-items:flex-start; }
.form-info-icon { font-size:1.3rem; line-height:1; margin-top:2px; flex-shrink:0; }
.form-info-item strong { font-size:0.88rem; color:var(--navy); display:block; margin-bottom:2px; }
.form-info-item p { font-size:0.82rem; color:var(--text-muted); margin:0; }

/* ── SHOP PAGE ── */
.shop-intro-bar { display:grid; grid-template-columns:1fr auto; gap:40px; align-items:start; }
.shop-intro-text h2 { color:var(--navy); font-family:'Playfair Display',serif; margin-bottom:12px; }
.shop-intro-text p  { color:var(--text-muted); line-height:1.75; }
.shop-guarantee { background:var(--off-white); border-radius:4px; padding:24px 20px; display:flex; gap:14px; align-items:flex-start; max-width:280px; border-left:3px solid var(--gold); }
.guarantee-icon { font-size:1.4rem; flex-shrink:0; }
.shop-guarantee h4 { color:var(--navy); font-size:0.92rem; margin-bottom:6px; }
.shop-guarantee p  { font-size:0.8rem; color:var(--text-muted); line-height:1.65; }

.products-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:24px; }
.product-card { background:var(--white); border:1px solid var(--border); border-radius:6px; padding:28px 24px; display:flex; flex-direction:column; gap:12px; transition:box-shadow 0.25s, transform 0.25s; }
.product-card:hover { box-shadow:var(--shadow-md); transform:translateY(-2px); }
.product-badge-wrap { display:flex; gap:8px; align-items:center; flex-wrap:wrap; }
.product-category { font-size:0.68rem; font-weight:700; letter-spacing:1.5px; text-transform:uppercase; background:var(--gold-pale); color:var(--navy); padding:3px 10px; border-radius:2px; }
.product-badge-new { font-size:0.68rem; font-weight:700; letter-spacing:1px; text-transform:uppercase; background:var(--navy); color:var(--gold); padding:3px 10px; border-radius:2px; }
.product-icon { font-size:2rem; }
.product-card h3 { font-family:'Playfair Display',serif; color:var(--navy); font-size:1rem; line-height:1.3; }
.product-card p  { font-size:0.84rem; color:var(--text-muted); line-height:1.7; flex:1; }
.product-includes { list-style:none; }
.product-includes li { font-size:0.8rem; color:var(--text-muted); padding:5px 0; border-bottom:1px solid var(--off-white); }
.product-includes li:last-child { border-bottom:none; }
.product-footer { display:flex; align-items:center; justify-content:space-between; gap:12px; margin-top:auto; padding-top:12px; border-top:1px solid var(--border); }
.product-price { font-family:'Playfair Display',serif; font-size:1.4rem; font-weight:700; color:var(--navy); white-space:nowrap; }
.product-btn { padding:9px 16px; font-size:0.78rem; }

.faq-grid { display:grid; grid-template-columns:1fr 1fr; gap:24px; }
.faq-item { background:var(--white); border:1px solid var(--border); border-radius:4px; padding:24px; }
.faq-item h4 { color:var(--navy); font-size:0.95rem; margin-bottom:8px; }
.faq-item p  { font-size:0.84rem; color:var(--text-muted); line-height:1.7; }

/* ── CONTACT PAGE ── */
.contact-layout { display:grid; grid-template-columns:1fr 1.2fr; gap:60px; align-items:start; }
.contact-info h2 { color:var(--navy); font-family:'Playfair Display',serif; margin-bottom:12px; }
.contact-info p  { color:var(--text-muted); line-height:1.75; }
.contact-details { display:flex; flex-direction:column; gap:20px; }
.contact-detail-item { display:flex; gap:16px; align-items:flex-start; padding:16px; background:var(--off-white); border-radius:4px; }
.contact-icon { font-size:1.4rem; flex-shrink:0; margin-top:2px; }
.contact-detail-item h4 { color:var(--navy); font-size:0.9rem; margin-bottom:4px; }
.contact-detail-item p  { color:var(--text-muted); font-size:0.85rem; margin:0; line-height:1.6; }

.response-card { background:var(--off-white); border-radius:4px; padding:24px; }
.response-item { display:flex; gap:12px; align-items:flex-start; padding:8px 0; border-bottom:1px solid var(--border); }
.response-item:last-child { border-bottom:none; }
.response-dot { width:8px; height:8px; border-radius:50%; background:var(--gold); flex-shrink:0; margin-top:6px; }
.response-item p { font-size:0.84rem; color:var(--text-muted); line-height:1.6; margin:0; }

.alt-actions-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:24px; }
.alt-action-card { background:var(--white); border:1px solid var(--border); border-radius:6px; padding:32px 28px; text-align:center; }
.alt-icon { font-size:2rem; margin-bottom:16px; }
.alt-action-card h3 { color:var(--navy); font-family:'Playfair Display',serif; margin-bottom:8px; font-size:1.1rem; }
.alt-action-card p  { font-size:0.84rem; color:var(--text-muted); line-height:1.7; }

/* ── RESPONSIVE ADDITIONS ── */
@media(max-width:960px) {
  .nav-inner { padding:0 24px; }
  .nav-links, .nav-actions { display:none; }
  .nav-hamburger { display:block; }
  .grid-2-col { grid-template-columns:1fr; gap:36px; }
  .about-values-grid { grid-template-columns:1fr; }
  .differentiators-grid { grid-template-columns:1fr 1fr; }
  .booking-packages { grid-template-columns:1fr; }
  .steps-grid { grid-template-columns:1fr 1fr; }
  .form-layout { grid-template-columns:1fr; gap:36px; }
  .products-grid { grid-template-columns:1fr 1fr; }
  .faq-grid { grid-template-columns:1fr; }
  .contact-layout { grid-template-columns:1fr; gap:36px; }
  .alt-actions-grid { grid-template-columns:1fr; }
  .cta-inner { flex-direction:column; text-align:center; }
  .cta-actions { justify-content:center; }
  .footer-grid { grid-template-columns:1fr 1fr; gap:32px; }
  .shop-intro-bar { grid-template-columns:1fr; }
  .shop-guarantee { max-width:100%; }
  .credentials-visual { grid-template-columns:1fr 1fr; }
  .pull-quote-card { padding:40px 32px; }
  .container { padding:0 24px; }
  .section { padding:56px 0; }
  .page-hero { padding:56px 24px 48px; }
}

@media(max-width:600px) {
  .differentiators-grid { grid-template-columns:1fr; }
  .steps-grid { grid-template-columns:1fr; }
  .products-grid { grid-template-columns:1fr; }
  .form-row { grid-template-columns:1fr; }
  .footer-grid { grid-template-columns:1fr; }
  .footer-bottom { flex-direction:column; gap:6px; }
  .credentials-visual { grid-template-columns:1fr; }
  .product-footer { flex-direction:column; align-items:flex-start; }
}
