:root{
  /* Light cream "doge.gov"-like theme */
  --bg:#fbf6ed; /* warm cream background */
  --surface:#fffaf3; /* card surface, slightly off-white */
  --muted:#52555f; /* muted gray text for secondary copy (increased contrast) */
  --accent:#936f10; /* restored warm gold accent to previous tone */
  --accent-2:#f6e7b0; /* slightly desaturated lighter gold */
  --shadow-warm: rgba(0,0,0,0.06);
  --shadow-cool: rgba(2,24,43,0.04);
  /* Soft greige bars: warm, subtle separation that pairs with the cream background */
  --bar-surface-top: linear-gradient(180deg, #f5f2ec 0%, #efeae1 100%);
  --bar-surface-bottom: linear-gradient(180deg, #efeae1 0%, #f5f2ec 100%);
  /* Allow overriding logo color separately from accent so we can return it to the default text color */
  /* Logo color follows the main text color by default (restore original look) */
  --logo-color: var(--text);
  --white:#ffffff;
  --text: rgba(17,24,39,0.96); /* restored original text color */
  --radius:10px;
  --container:1100px;
}
/* Under Construction banner */
.site-banner--construction{position:fixed;left:0;right:0;top:88px;z-index:50;display:flex;justify-content:center;pointer-events:none}
.site-banner--construction .banner-inner{pointer-events:auto;max-width:var(--container);margin:0 16px;background:#fff3cd;border:1px solid rgba(147,111,16,0.12);color:#664d03;padding:10px 16px;border-radius:8px;display:flex;gap:12px;align-items:center;box-shadow:0 6px 18px rgba(0,0,0,0.06)}
.site-banner--construction .banner-inner strong{font-weight:700;margin-right:6px}
.site-banner--construction .banner-actions{margin-left:auto;display:flex;gap:8px;align-items:center}
.site-banner--construction .banner-dismiss{background:transparent;border:1px solid rgba(0,0,0,0.06);padding:6px 10px;border-radius:8px;cursor:pointer;color:var(--muted)}
.site-banner--construction .banner-learn{background:transparent;border:0;color:var(--accent);text-decoration:underline;cursor:pointer}
.site-banner--construction.hidden{display:none}

/* Ensure top-bar stays above the banner so dropdowns remain clickable */
.top-bar{z-index:60}

/* Logos and inline svgs that use currentColor will follow this color by default */
.logo{ color: var(--logo-color); display:inline-block; vertical-align:middle }
.logo svg{ width:100%; height:auto }
*{box-sizing:border-box}
html,body{height:100%}
.body-bg{background:linear-gradient(180deg,var(--bg) 0%, var(--bg) 100%)}
body{margin:0;font-family:Inter,Segoe UI,system-ui,-apple-system,"Helvetica Neue",Arial;color:var(--text);-webkit-font-smoothing:antialiased;background:var(--bg)}
.container{max-width:var(--container);margin:0 auto;padding:28px}

/* Fixed top and bottom bars (slightly taller and padded) */
.top-bar{position:fixed;left:0;right:0;height:80px;top:0;background:var(--bar-surface-top);backdrop-filter:blur(6px);z-index:60;border-top:0;padding:0 36px;box-shadow:none}

/* Ensure page content doesn't hide under bars (match new height + small gap) */
main{padding-top:100px;padding-bottom:48px}

/* Breadcrumb Navigation */
.breadcrumb-nav{
  background:var(--surface);
  border-bottom:1px solid rgba(0,0,0,0.04);
  padding:12px 0;
}
.breadcrumb{
  list-style:none;
  margin:0;
  padding:0;
  display:flex;
  align-items:center;
  gap:8px;
  font-size:14px;
}
.breadcrumb li{
  display:flex;
  align-items:center;
}
.breadcrumb li:not(:last-child)::after{
  content:'›';
  margin-left:8px;
  color:var(--muted);
  font-weight:600;
}
.breadcrumb a{
  color:var(--accent);
  text-decoration:none;
  transition:color 200ms ease;
}
.breadcrumb a:hover{
  color:var(--text);
  text-decoration:underline;
}
.breadcrumb li[aria-current="page"]{
  color:var(--muted);
  font-weight:600;
}
/* Responsive adjustments for contact grid and footer */
.contact-grid {grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));}
.footer-contact {margin-top: 12px;font-size: 1rem;}
.skip-link{
  position:absolute;
  left:-9999px;
  top:auto;
  width:1px;
  height:1px;
  overflow:hidden;
  z-index:9999;
}
.skip-link:focus{
  position:fixed;
  top:16px;
  left:16px;
  width:auto;
  height:auto;
  padding:12px 16px;
  background:var(--accent);
  color:#fff;
  text-decoration:none;
  border-radius:8px;
  font-weight:600;
  box-shadow:0 4px 12px rgba(0,0,0,0.3);
}

/* Enhanced focus styles */
*:focus{
  outline:2px solid var(--accent);
  outline-offset:2px;
}
button:focus, .btn:focus, input:focus, textarea:focus{
  outline:2px solid var(--accent);
  outline-offset:2px;
  box-shadow:0 0 0 4px rgba(147,111,16,0.1);
}
/* Header content placed inside top-bar (use existing .header-inner layout) */
.header-inner{display:flex;align-items:center;justify-content:space-between;gap:16px}
.logo img{display:block;max-height:50px;height:auto;width:auto;max-width:220px}
/* language switch */
.lang-switch{display:flex;gap:8px;align-items:center;padding-right:8px;margin-left:12px;flex-shrink:0}
.lang-switch .lang-btn{white-space:nowrap}
.lang-btn{background:transparent;color:var(--muted);padding:6px 10px;border-radius:10px;font-size:14px;cursor:pointer;min-width:40px;border:1px solid transparent;transition:background 420ms cubic-bezier(.2,.9,.2,1), color 420ms ease, box-shadow 420ms ease, transform 360ms ease}
.lang-btn:focus{outline:2px solid rgba(212,160,55,0.14);outline-offset:3px}
.lang-btn[aria-pressed="true"]{background:var(--accent);color:#fff;border:1px solid rgba(0,0,0,0.08);box-shadow:none;transform:translateY(-2px)}
.lang-code{margin-left:6px;font-weight:700;font-size:0.9rem;letter-spacing:0.06em}
.lang-dropdown{position:relative}
.lang-current{background:transparent;border:1px solid rgba(0,0,0,0.04);padding:8px 10px;border-radius:8px;cursor:pointer;color:var(--muted);font-weight:700}
.lang-current:focus{outline:2px solid rgba(212,160,55,0.14);outline-offset:3px}
.lang-list{position:absolute;right:0;top:calc(100% + 8px);background:var(--surface);border-radius:8px;box-shadow:0 6px 18px rgba(0,0,0,0.08);list-style:none;padding:6px 6px;margin:0;display:none;min-width:180px}
.lang-list[aria-hidden="false"], .lang-list.open{display:block}
.lang-list li{padding:8px 10px;cursor:pointer;border-radius:6px;color:var(--text)}
.lang-list li[aria-selected="true"]{background:var(--accent);color:#fff}
.lang-list li:hover{background:rgba(0,0,0,0.04)}
.lang-list li:focus{outline:2px solid rgba(212,160,55,0.14);outline-offset:3px}
.nav-toggle{display:none;background:transparent;border:1px solid rgba(0,0,0,0.06);color:var(--text);padding:8px 10px;border-radius:8px}
.main-nav a{color:var(--text); background: transparent; padding:8px 12px; border-radius:8px; text-decoration:none; margin-left:12px; display:inline-block}
.main-nav a:focus{outline:2px solid rgba(212,160,55,0.18);outline-offset:3px}
.main-nav a:hover{background:var(--accent); color:#fff}
.hero{padding:64px 0}
.hero-inner{display:flex;gap:32px;align-items:center}
.hero-copy{flex:1}
.hero h1{font-size:2.4rem;margin:0 0 12px}
.lede{color:var(--muted);font-size:1.05rem;margin:0 0 18px}
.cta-row .btn{margin-right:12px}
.cta-row .btn, .btn.primary{background:var(--accent);color:#fff;border:none;box-shadow:none;padding:10px 18px}
.cta-row .btn.outline{background:transparent;border:1px solid rgba(0,0,0,0.06);color:var(--text)}
.cta-row .btn:hover, .btn.primary:hover{filter:brightness(0.98);transform:translateY(-1px)}
.hero-media img{max-width:420px;border-radius:8px;display:block}

/* CTA entrance animation */
.cta-entrance{animation:ctaPop 420ms cubic-bezier(.2,.9,.2,1) both}
@keyframes ctaPop{
  0%{transform:translateY(12px) scale(0.98);opacity:0}
  60%{transform:translateY(-6px) scale(1.02);opacity:1}
  100%{transform:translateY(0) scale(1)}
}

/* Ripple effect */
.ripple{position:absolute;border-radius:50%;transform:scale(0);pointer-events:none;background:rgba(0,0,0,0.06);animation:rippleAnim 650ms ease-out}
@keyframes rippleAnim{to{transform:scale(1);opacity:0}}

.section{padding:48px 0}
.section h2{margin-top:0}
.section-lead{color:var(--muted)}
.grid{display:grid;gap:20px}
.grid-3{grid-template-columns:repeat(auto-fit,minmax(240px,1fr))}
.card{background:linear-gradient(180deg,rgba(0,0,0,0.02),rgba(0,0,0,0.01));padding:18px;border-radius:var(--radius);box-shadow:0 6px 18px var(--shadow-warm)}
.card{background:linear-gradient(180deg,rgba(0,0,0,0.02),rgba(0,0,0,0.01));padding:18px;border-radius:var(--radius);box-shadow:none}
.card img{width:100%;height:160px;object-fit:cover;border-radius:6px}
.btn{display:inline-block;padding:10px 16px;border-radius:8px;text-decoration:none;color:var(--text);background:var(--surface);border:1px solid rgba(0,0,0,0.04)}
/* Product card CTAs: distinct from other controls */
.btn.small{padding:8px 12px;font-size:0.95rem;position:relative;overflow:hidden;border-radius:8px}
/* outline accent with subtle inset when not primary */
.card .btn.small{background:transparent;color:var(--accent);border:2px solid rgba(122,86,14,0.12);font-weight:700;box-shadow:none;z-index:1}
.card .btn.small::after{content:'';position:absolute;left:0;top:0;height:100%;width:0;background:rgba(147,111,16,0.14);opacity:1;z-index:0;transition:width 260ms cubic-bezier(.2,.9,.2,1)}
.card .btn.small:hover{color:var(--text);border-color:transparent}
.card .btn.small:hover::after{width:100%}
.card .btn.small:focus{outline:3px solid rgba(122,86,14,0.18);outline-offset:3px}
/* add a small chevron to product CTAs */
.card .btn.small .chev{display:inline-block;margin-left:8px;transform:translateX(0);transition:transform 200ms ease}
.card .btn.small:hover .chev{transform:translateX(4px)}
.btn.primary{background:var(--accent);box-shadow:0 10px 30px rgba(0,0,0,0.28);color:#fff;border:none}
.btn.primary{background:var(--accent);box-shadow:none;color:#fff;border:none}
.btn.outline{background:transparent;border:1px solid rgba(0,0,0,0.08);color:var(--text)}

.narrow{max-width:760px;margin:0 auto}
.stats{display:flex;gap:24px;padding:0;list-style:none}
.stats li{color:var(--muted)}

.contact-form{background:transparent;padding:18px;border-radius:10px}
/* Make contact columns flat (no card chrome) */
.contact-details,
.contact-form-column{
  background: transparent;
  border: none;
  box-shadow: none;
  padding: 0; /* keep layout spacing minimal; inner .contact-form will keep its padding */
}
.form-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:14px}
/* Header content placed inside top-bar (use existing .header-inner layout) */
  .cta-row .btn:hover, .btn.primary:hover{filter:brightness(0.98);transform:translateY(-1px)}
.header-inner{display:flex;align-items:center;justify-content:space-between;gap:16px}
  .ripple{position:absolute;border-radius:50%;transform:scale(0);pointer-events:none;background:rgba(0,0,0,0.06);animation:rippleAnim 650ms ease-out}
.logo img{display:block;max-height:50px;height:auto;width:auto;max-width:220px}
  .card{background:linear-gradient(180deg,rgba(0,0,0,0.02),rgba(0,0,0,0.01));padding:18px;border-radius:var(--radius);box-shadow:0 6px 18px var(--shadow-warm)}
/* language switch */
  .btn{display:inline-block;padding:10px 16px;border-radius:8px;text-decoration:none;color:var(--text);background:var(--surface);border:1px solid rgba(0,0,0,0.04)}
.lang-switch{display:flex;gap:8px;align-items:center;padding-right:8px;margin-left:12px;flex-shrink:0}
  .btn.outline{background:transparent;border:1px solid rgba(0,0,0,0.08);color:var(--text)}
.lang-switch .lang-btn{white-space:nowrap}
  .contact-form{background:linear-gradient(180deg,rgba(0,0,0,0.01),transparent);padding:18px;border-radius:10px}
.lang-btn{background:transparent;color:var(--muted);padding:6px 10px;border-radius:10px;font-size:14px;cursor:pointer;min-width:40px;border:1px solid transparent;transition:background 420ms cubic-bezier(.2,.9,.2,1), color 420ms ease, box-shadow 420ms ease, transform 360ms ease}
  .contact-details{padding:0;border-radius:0;background:transparent}
.lang-btn:focus{outline:2px solid rgba(255,220,180,0.14);outline-offset:3px}
  .contact-details h3, .contact-left{color:var(--text)}
.lang-btn[aria-pressed="true"]{background:var(--accent);color:#fff;border:1px solid rgba(0,0,0,0.08);box-shadow:0 6px 18px rgba(0,0,0,0.18);transform:translateY(-2px)}
.lang-btn[aria-pressed="true"]{background:var(--accent);color:#fff;border:1px solid rgba(0,0,0,0.08);box-shadow:none;transform:translateY(-2px)}
  .contact-details .section-lead{color:rgba(17,24,39,0.7);margin-bottom:12px}
.lang-code{margin-left:6px;font-weight:700;font-size:0.9rem;letter-spacing:0.06em}
.nav-toggle{display:none;background:transparent;border:1px solid rgba(0,0,0,0.06);color:var(--text);padding:8px 10px;border-radius:8px}
.main-nav a{color:var(--text); background: transparent; padding:8px 12px; border-radius:8px; text-decoration:none; margin-left:12px; display:inline-block}
  .contact-details .map-link{color:var(--accent);text-decoration:underline}
.main-nav a:focus{outline:2px solid rgba(255,200,160,0.18);outline-offset:3px}
  .contact-form-column .contact-form{padding:0;border-radius:0;background:transparent;box-shadow:none;border:none}
.main-nav a:hover{background:var(--accent); color:#fff}
  .site-footer{border-top:0;padding:18px 0;margin-top:32px;background:var(--bar-surface-top);box-shadow:0 -6px 18px rgba(0,0,0,0.04), 0 -10px 24px var(--shadow-warm)}
.site-footer{border-top:0;padding:18px 0;margin-top:32px;background:var(--bar-surface-top);box-shadow:none}
.hero{padding:64px 0}
  .contact-details .map-link{color:var(--accent);text-decoration:underline}
.hero-inner{display:flex;gap:32px;align-items:center}
.hero-copy{flex:1}
.hero h1{font-size:2.4rem;margin:0 0 12px}
.lede{color:var(--muted);font-size:1.05rem;margin:0 0 18px}
.cta-row .btn{margin-right:12px}
.cta-row .btn, .btn.primary{background:var(--accent);color:#fff;border:none;box-shadow:0 8px 24px rgba(0,0,0,0.25);padding:10px 18px}
.cta-row .btn, .btn.primary{background:var(--accent);color:#fff;border:none;box-shadow:none;padding:10px 18px}
.cta-row .btn.outline{background:transparent;border:1px solid rgba(0,0,0,0.06);color:var(--text)}
.cta-row .btn:hover, .btn.primary:hover{filter:brightness(0.95);transform:translateY(-1px)}
.hero-media img{max-width:420px;border-radius:8px;display:block}

/* CTA entrance animation */
.cta-entrance{animation:ctaPop 420ms cubic-bezier(.2,.9,.2,1) both}
@keyframes ctaPop{
  0%{transform:translateY(12px) scale(0.98);opacity:0}
  60%{transform:translateY(-6px) scale(1.02);opacity:1}
  100%{transform:translateY(0) scale(1)}
}

/* Ripple effect */
.ripple{position:absolute;border-radius:50%;transform:scale(0);pointer-events:none;background:rgba(0,0,0,0.06);animation:rippleAnim 650ms ease-out}
@keyframes rippleAnim{to{transform:scale(1);opacity:0}}

.section{padding:48px 0}
.section h2{margin-top:0}
.section-lead{color:var(--muted)}
.grid{display:grid;gap:20px}
.grid-3{grid-template-columns:repeat(auto-fit,minmax(240px,1fr))}
.card{background:linear-gradient(180deg,rgba(0,0,0,0.02),rgba(0,0,0,0.01));padding:18px;border-radius:var(--radius);box-shadow:0 6px 18px var(--shadow-warm)}
.card img{width:100%;height:160px;object-fit:cover;border-radius:6px}
.btn{display:inline-block;padding:10px 16px;border-radius:8px;text-decoration:none;color:var(--text);background:var(--surface);border:1px solid rgba(0,0,0,0.04)}
.btn.small{padding:8px 12px;font-size:0.9rem}
.btn.primary{background:var(--accent);box-shadow:0 10px 30px rgba(0,0,0,0.28);color:#fff;border:none}
.btn.outline{background:transparent;border:1px solid rgba(0,0,0,0.08);color:var(--text)}

.narrow{max-width:760px;margin:0 auto}
.stats{display:flex;gap:24px;padding:0;list-style:none}
.stats li{color:var(--muted)}

.contact-form{background:linear-gradient(180deg,rgba(0,0,0,0.01),transparent);padding:18px;border-radius:10px}
.contact-details,
.contact-form-column,
.contact-form{
  background: transparent;
  border: none;
  box-shadow: none;
  padding: 0;
}
.form-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:14px}
/* form labels and controls */
label{display:block;color:var(--muted);font-size:0.95rem}
label span{display:block;margin-bottom:6px;color:var(--muted);font-weight:600}
input,textarea{width:100%;padding:10px;border-radius:8px;border:1px solid rgba(0,0,0,0.06);background:rgba(0,0,0,0.01);color:var(--text);box-shadow:inset 0 1px 0 rgba(0,0,0,0.02)}
textarea{min-height:120px;resize:vertical}
.form-status{color:var(--accent);margin-top:8px}
/* success and error states for form status */
.form-status.success{color:#4ade80 /* green-400 */;font-weight:600}
.form-status.error{color:#fb7185 /* rose-400 */;font-weight:600}

.site-footer{border-top:0;padding:18px 0;margin-top:32px;background:var(--bar-surface-top);box-shadow:none}
.footer-inner{display:flex;justify-content:space-between;align-items:center}
.footer-nav a{color:var(--muted);margin-left:12px;text-decoration:none}

.footer-credit{padding:8px 0 18px;background:transparent;color:var(--muted);font-size:0.95rem;border-top:1px solid rgba(17,24,39,0.03)}
.footer-credit .container{max-width:var(--container);margin:0 auto;padding:0 28px;display:flex;justify-content:flex-end}
.footer-credit{display:block}
.footer-credit a{color:var(--accent);text-decoration:none}
.footer-credit a:hover{text-decoration:underline}

/* Inline icon styles for contact details */
.contact-details .icon{vertical-align:middle;display:inline-block;margin-right:8px;min-width:16px;height:16px}
.contact-details .contact-text{vertical-align:middle}
.contact-details a.phone, .contact-details a.email{color:var(--text);text-decoration:none}
.contact-details a.phone .icon, .contact-details a.email .icon{opacity:0.95}

/* Contact left/right titles */
.contact-left{margin:0 0 8px 0;font-size:1.6rem;color:var(--text);font-weight:700}
.contact-right{margin:0 0 8px 0;font-size:1.6rem;text-align:left;color:var(--text);font-weight:700}

/* Contact details: flat style (no card chrome) but preserve spacing */
.contact-details{padding:22px;border-radius:0;background:transparent;border:none;box-shadow:none}
.contact-details h3, .contact-left{color:var(--text)}
.contact-details .section-lead{color:rgba(17,24,39,0.7);margin-bottom:12px}
.contact-details p, .contact-details .address-line{color:var(--muted);line-height:1.5}
.contact-details a.phone, .contact-details a.email{color:var(--text);display:inline-flex;align-items:center;gap:8px}
.contact-details .map-link{color:var(--accent);text-decoration:underline}

.contact-form-column{padding-top:22px}
.contact-form-column .contact-form{padding:22px;border-radius:0;background:transparent;box-shadow:none;border:none}
.contact-form-column .section-lead{color:rgba(17,24,39,0.84);text-align:left;margin:0 0 12px}
.contact-form .form-grid label span{color:var(--muted);font-weight:600}
.contact-form input, .contact-form textarea{background:rgba(0,0,0,0.01);border:1px solid rgba(0,0,0,0.04)}
.contact-form .btn.primary{background:var(--accent);box-shadow:0 8px 18px rgba(0,0,0,0.08);border:none;color:#fff}
.contact-form .btn.primary{background:var(--accent);box-shadow:none;border:none;color:#fff}

/* Form Validation Styles */
.validation-message {
  display: none;
  font-size: 0.875rem;
  margin-top: 4px;
  padding: 2px 0;
  color: #dc2626;
  font-weight: 500;
}

.validation-message.visible {
  display: block;
}

.contact-form input.invalid,
.contact-form textarea.invalid {
  border-color: #dc2626;
  background-color: rgba(220, 38, 38, 0.05);
}

.contact-form input.valid,
.contact-form textarea.valid {
  border-color: #16a34a;
  background-color: rgba(22, 163, 74, 0.05);
}

/* Character Counter */
.character-count {
  font-size: 0.8125rem;
  color: var(--muted);
  margin-top: 4px;
  text-align: right;
}

.character-count.warning {
  color: #ea580c;
}

.character-count.danger {
  color: #dc2626;
  font-weight: 600;
}

/* Form Security Indicators */
.security-indicator {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  font-size: 0.75rem;
  color: var(--muted);
  margin-top: 8px;
}

.security-indicator::before {
  content: "🔒";
  font-size: 0.875rem;
}

/* Form Loading State */
.contact-form.loading input,
.contact-form.loading textarea,
.contact-form.loading button {
  opacity: 0.6;
  pointer-events: none;
}

.contact-form.loading button {
  position: relative;
}

.contact-form.loading button::after {
  content: "";
  position: absolute;
  top: 50%;
  left: 50%;
  width: 16px;
  height: 16px;
  margin: -8px 0 0 -8px;
  border: 2px solid transparent;
  border-top: 2px solid #ffffff;
  border-radius: 50%;
  animation: spin 1s linear infinite;
}

@keyframes spin {
  0% { transform: rotate(0deg); }
  100% { transform: rotate(360deg); }
}

/* Slightly reduce the starkness of the Contact Us heading */
.contact-left{color:var(--text)}

@media (min-width:880px){
  /* ensure the contact-grid uses two columns on wider viewports (keeps existing auto-fit behavior) */
  .contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:24px;align-items:start;position:relative}
  .contact-right{align-self:start}
  /* Subtle vertical divider between left/right contact columns */
  .contact-grid::before{content:'';position:absolute;top:8px;bottom:8px;left:50%;width:1px;background:rgba(17,24,39,0.06);transform:translateX(-0.5px)}
  /* add internal padding so content doesn't touch the divider */
  .contact-details{padding-right:20px}
  .contact-form-column{padding-left:28px}
}
@media (max-width:879px){
  .contact-right{text-align:left;margin-top:12px}
  .contact-grid{display:block}
  
  /* Improve mobile form usability */
  .form-grid{grid-template-columns:1fr;gap:16px}
  .contact-form input, .contact-form textarea{
    padding:14px;
    font-size:16px; /* Prevents zoom on iOS Safari */
    border-radius:10px;
  }
  .btn{
    padding:14px 20px;
    font-size:16px;
    min-height:48px; /* Touch-friendly minimum */
  }
  
  /* Better mobile spacing */
  .container{padding:20px 16px}
  .hero{padding:48px 0}
  .section{padding:36px 0}
  
  /* Mobile-specific improvements */
  .breadcrumb-nav{padding:8px 0}
  .breadcrumb{font-size:13px;gap:6px}
  .lang-current{padding:10px 12px;min-height:44px}
  .lang-list li{padding:12px;min-height:44px}
  
  /* Improve mobile hero layout */
  .hero h1{font-size:2rem;line-height:1.2}
  .lede{font-size:1rem}
}

/* ===== COOKIE CONSENT BANNER ===== */
.cookie-consent-banner {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background: rgba(0, 0, 0, 0.75);
  z-index: 10000;
  display: none;
  align-items: center;
  justify-content: center;
  padding: 20px;
  backdrop-filter: blur(4px);
}

.cookie-consent-banner.show {
  display: flex;
  animation: fadeInScale 0.4s cubic-bezier(0.2, 0.9, 0.2, 1);
}

.cookie-consent-banner.hidden {
  display: none;
}

@keyframes fadeInScale {
  0% {
    opacity: 0;
    transform: scale(0.9);
  }
  100% {
    opacity: 1;
    transform: scale(1);
  }
}

.cookie-consent-content {
  background: var(--surface);
  border-radius: 16px;
  padding: 32px;
  max-width: 520px;
  width: 100%;
  max-height: 80vh;
  overflow-y: auto;
  box-shadow: 0 20px 60px rgba(0, 0, 0, 0.3);
  border: 1px solid rgba(255, 255, 255, 0.1);
  text-align: center;
}

.cookie-consent-text {
  margin-bottom: 24px;
}

.cookie-consent-text h4 {
  margin: 0 0 12px 0;
  color: var(--text);
  font-size: 1.4rem;
  font-weight: 700;
}

.cookie-consent-text p {
  margin: 0;
  color: var(--muted);
  font-size: 1rem;
  line-height: 1.5;
}

.cookie-policy-link {
  color: var(--accent);
  text-decoration: underline;
  font-weight: 600;
}

.cookie-policy-link:hover {
  color: var(--text);
}

.cookie-consent-actions {
  display: flex;
  gap: 12px;
  justify-content: center;
  flex-wrap: wrap;
  margin-top: 8px;
}

.cookie-consent-btn {
  padding: 12px 24px;
  border-radius: 10px;
  font-size: 1rem;
  font-weight: 600;
  cursor: pointer;
  border: none;
  transition: all 0.3s ease;
  min-width: 120px;
  text-align: center;
}

.cookie-consent-btn.accept {
  background: var(--accent);
  color: #fff;
  box-shadow: 0 4px 12px rgba(147, 111, 16, 0.3);
}

.cookie-consent-btn.accept:hover {
  filter: brightness(1.05);
  transform: translateY(-2px);
  box-shadow: 0 6px 16px rgba(147, 111, 16, 0.4);
}

.cookie-consent-btn.reject {
  background: #f5f5f5;
  color: var(--text);
  border: 1px solid rgba(0,0,0,0.15);
}

.cookie-consent-btn.reject:hover {
  background: #e8e8e8;
  transform: translateY(-1px);
}

.cookie-consent-btn.settings {
  background: transparent;
  color: var(--accent);
  border: 2px solid var(--accent);
  padding: 10px 20px;
  font-size: 0.9rem;
}

.cookie-consent-btn.settings:hover {
  background: var(--accent);
  color: #fff;
}

.cookie-policy-link {
  color: var(--accent);
  text-decoration: underline;
  font-size: 0.9rem;
}

.cookie-policy-link:hover {
  color: var(--text);
}

/* Cookie Settings Modal */
.cookie-settings-modal {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background: rgba(0,0,0,0.7);
  z-index: 10000;
  display: none;
  align-items: center;
  justify-content: center;
  padding: 20px;
}

.cookie-settings-modal.show {
  display: flex;
}

.cookie-settings-content {
  background: var(--surface);
  border-radius: 12px;
  padding: 30px;
  max-width: 600px;
  width: 100%;
  max-height: 80vh;
  overflow-y: auto;
  box-shadow: 0 10px 30px rgba(0,0,0,0.3);
}

.cookie-settings-content h3 {
  margin: 0 0 20px 0;
  color: var(--text);
  font-size: 1.4rem;
}

.cookie-category {
  margin-bottom: 24px;
  padding: 16px;
  border: 1px solid rgba(0,0,0,0.08);
  border-radius: 8px;
}

.cookie-category-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 12px;
}

.cookie-category h4 {
  margin: 0;
  color: var(--text);
  font-size: 1.1rem;
}

.cookie-toggle {
  position: relative;
  display: inline-block;
  width: 50px;
  height: 26px;
}

.cookie-toggle input {
  opacity: 0;
  width: 0;
  height: 0;
}

.cookie-toggle-slider {
  position: absolute;
  cursor: pointer;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background-color: #ccc;
  transition: 0.3s;
  border-radius: 26px;
}

.cookie-toggle-slider:before {
  position: absolute;
  content: "";
  height: 20px;
  width: 20px;
  left: 3px;
  bottom: 3px;
  background-color: white;
  transition: 0.3s;
  border-radius: 50%;
}

.cookie-toggle input:checked + .cookie-toggle-slider {
  background-color: var(--accent);
}

.cookie-toggle input:checked + .cookie-toggle-slider:before {
  transform: translateX(24px);
}

.cookie-toggle input:disabled + .cookie-toggle-slider {
  background-color: #ddd;
  cursor: not-allowed;
  opacity: 0.6;
}

/* Disabled and checked state - show it's locked in the "on" position */
.cookie-toggle input:disabled:checked + .cookie-toggle-slider {
  background-color: #888;
}

.cookie-toggle input:disabled:checked + .cookie-toggle-slider:before {
  transform: translateX(24px);
}

.cookie-category p {
  margin: 0;
  color: var(--muted);
  font-size: 0.9rem;
  line-height: 1.4;
}

.cookie-settings-actions {
  display: flex;
  gap: 12px;
  justify-content: flex-end;
  margin-top: 24px;
  padding-top: 20px;
  border-top: 1px solid rgba(0,0,0,0.08);
}

/* Mobile responsiveness for cookie consent */
@media (max-width: 768px) {
  .cookie-consent-banner {
    padding: 16px;
  }
  
  .cookie-consent-content {
    padding: 24px 20px;
    margin: 16px;
    max-width: none;
  }
  
  .cookie-consent-text h4 {
    font-size: 1.2rem;
  }
  
  .cookie-consent-text p {
    font-size: 0.95rem;
  }
  
  .cookie-consent-actions {
    flex-direction: column;
    gap: 10px;
  }
  
  .cookie-consent-btn {
    width: 100%;
    min-width: auto;
  }
  
  .cookie-settings-content {
    margin: 10px;
    padding: 20px;
  }
  
  .cookie-settings-actions {
    flex-direction: column;
  }
  
  .cookie-consent-btn.settings {
    order: -1;
    align-self: center;
    margin-bottom: 8px;
  }
}

/* === Visual overrides: CTA, nav and footer weight === */
/* Make the Request (outline) button match the primary action in the hero */
.cta-row .btn.outline{
  background: var(--accent) !important;
  color: #fff !important;
  border: none !important;
  box-shadow: none !important;
  transform: none;
}
.cta-row .btn.outline:hover{
  filter:brightness(0.95);
  transform:translateY(-1px);
}

/* Make top bar navigation items visually stronger (less faded) */
.top-bar .main-nav a{
  color: var(--text) !important;
  font-weight: 600 !important;
}

/* Make footer text slightly bolder and more legible */
.site-footer .footer-inner p,
.site-footer .footer-nav a{
  color: var(--text) !important;
  font-weight: 600 !important;
}

/* Footer in document flow: align to container and center content */
.site-footer .footer-inner{display:flex;align-items:center;justify-content:space-between;max-width:var(--container);margin:0 auto;padding:0 28px}

@media (max-width:880px){
  .hero-inner{flex-direction:column;text-align:center}
  .hero-media img{max-width:100%}
  .footer-inner{flex-direction:column;gap:12px}
  .nav-toggle{display:inline-block;min-height:44px;padding:10px 12px} /* Touch-friendly */
  .main-nav{position:absolute;right:20px;top:70px;background:rgba(2,6,23,0.95);padding:12px;border-radius:8px;display:none;z-index:70}
  .main-nav.open{display:block}
  /* compact header for small screens (do not wrap yet) */
  .top-bar{height:64px;padding:0 12px}
  .main-nav{display:none}
  .main-nav.open{display:block;position:fixed;right:12px;top:64px}
  .header-inner{align-items:center}
  .logo{flex:0 1 auto}
  .logo img{max-height:42px;max-width:160px}
  .lang-switch{display:flex;gap:6px;margin-left:6px;padding-right:4px}
  .lang-switch .lang-btn{font-size:13px;padding:8px 10px;border-radius:8px;color:var(--muted);background:transparent;border:1px solid transparent;transition:background 420ms ease,color 420ms ease,transform 360ms ease;min-height:44px} /* Touch-friendly */
  .lang-switch .lang-btn[aria-pressed="true"]{background:var(--accent);color:#fff;border:1px solid rgba(0,0,0,0.08);transform:translateY(-2px)}

  /* Mobile nav: ensure links are visible on dark background */
  .main-nav.open a{display:block;color:#fff !important;padding:12px 16px;border-radius:6px;margin:4px 0;text-decoration:none;min-height:44px;align-items:center} /* Touch-friendly */
  .main-nav.open a:hover{background:rgba(255,255,255,0.06);color:#fff !important}

@media (prefers-reduced-motion: reduce){
  .lang-btn{transition:none!important;transform:none!important}
  .cta-entrance{animation:none}
  .ripple{animation:none}
}
  .lang-btn .lang-code{display:none}
}

/* Very narrow screens: allow header items to wrap to avoid cramped layout */
@media (max-width:360px){
  .header-inner{flex-wrap:wrap;align-items:center}
  .logo{flex-basis:100%;display:flex;align-items:center}
  .logo img{max-height:36px}
  .lang-switch{flex-basis:auto;margin-left:0}
}

/* Extra-small adjustments to keep toggle + language buttons on one line */
@media (max-width:380px){
  .lang-switch{gap:4px}
  .lang-switch .lang-btn{font-size:11px;padding:3px 6px;border-radius:8px;min-width:32px;color:var(--muted);background:transparent;border:1px solid transparent}
  .nav-toggle{padding:6px 8px;font-size:18px}
  .logo img{max-height:32px}
}
