/* =============================
   Reset & Normalize
   ============================= */
*,*::before,*::after{box-sizing:border-box}
html{-webkit-text-size-adjust:100%}
body{margin:0;font-family:Verdana,Geneva,sans-serif;background:#FFFFFF;color:#1C2230;line-height:1.7;font-size:16px}
img{max-width:100%;height:auto;display:block}
a{color:inherit;text-underline-offset:3px}
button{font:inherit;color:inherit;background:none;border:none;padding:0;cursor:pointer}
input,select,textarea{font:inherit}

/* =============================
   Theme Variables (with fallbacks)
   ============================= */
:root{
  --primary:#1F3A5F;
  --secondary:#2F6B4F;
  --accent:#F5F7FA;
  --paper:#FFFFFF;
  --ink:#1C2230;
  --muted:#5A6575;
  --border:#E0E6EE;
  --shadow:rgba(15,23,42,.08);
  --radius:10px;
  --radius-sm:6px;
  --space-1:8px;
  --space-2:12px;
  --space-3:16px;
  --space-4:24px;
  --space-5:32px;
  --space-6:40px;
  --space-7:60px;
}

/* =============================
   Typography – Elegant Classic
   ============================= */
h1,h2,h3,h4,h5,h6{font-family:Georgia,'Times New Roman',serif;color:var(--primary);margin:0 0 var(--space-2);line-height:1.25;letter-spacing:.2px}
h1{font-size:32px}
h2{font-size:24px}
h3{font-size:18px}
h4{font-size:16px}
p,ul,ol{margin:0 0 var(--space-3);color:var(--ink)}
ul,ol{padding-left:20px}
strong{font-weight:700;color:var(--ink)}
small{font-size:85%;color:var(--muted)}

/* Links */
a{color:var(--primary);text-decoration:underline}
a:hover{color:var(--secondary)}
a:focus{outline:2px solid #9FB3C8;outline-offset:2px}

/* =============================
   Global Layout (Flexbox only)
   ============================= */
section{display:flex}
section>.container{display:flex;width:100%;padding:24px 16px}
.container>.content-wrapper{display:flex;width:100%;max-width:1100px;margin:0 auto;flex-direction:column;gap:16px;align-items:flex-start}

/* Ensure consistent vertical rhythm inside content wrappers */
.content-wrapper>*+*{margin-top:20px}
.text-section{display:flex;flex-direction:column;gap:8px;padding:8px 0}
.text-section>*+*{margin-top:8px}

/* Mandatory spacing & alignment patterns */
.section{margin-bottom:60px;padding:40px 20px}
.card-container{display:flex;flex-wrap:wrap;gap:24px}
.card{margin-bottom:20px;position:relative;display:flex;flex-direction:column;background:#fff;border:1px solid var(--border);border-radius:var(--radius);box-shadow:0 6px 18px var(--shadow);padding:20px;transition:transform .2s ease,box-shadow .2s ease}
.card:hover{transform:translateY(-2px);box-shadow:0 10px 26px var(--shadow)}
.content-grid{display:flex;flex-wrap:wrap;gap:20px;justify-content:space-between}
.content-grid>*{flex:1 1 260px;min-width:240px}
.text-image-section{display:flex;align-items:center;gap:30px;flex-wrap:wrap}
.text-image-section .text,.text-image-section .image{flex:1 1 320px}
.testimonial-card{display:flex;align-items:center;gap:20px;padding:20px;background:#FFFFFF;border:1px solid var(--border);border-radius:var(--radius);box-shadow:0 8px 24px var(--shadow)}
.testimonial-card p{margin:0;color:var(--ink)}
.feature-item{display:flex;flex-direction:column;align-items:flex-start;gap:15px}

/* =============================
   Header & Navigation
   ============================= */
header{position:relative;z-index:100;background:#fff;border-bottom:1px solid var(--border);box-shadow:0 2px 12px rgba(0,0,0,.02)}
header .content-wrapper{flex-direction:row;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap}
.logo img{height:38px;width:auto}

/* Main desktop nav */
.main-nav{display:none;align-items:center;gap:16px}
.main-nav a{color:var(--ink);text-decoration:none;padding:8px 10px;border-radius:6px;transition:background .2s ease,color .2s ease}
.main-nav a:hover{background:var(--accent);color:var(--primary)}

/* Header CTAs */
.header-ctas{display:flex;align-items:center;gap:10px;flex-wrap:wrap}

/* Buttons */
.button{display:inline-flex;align-items:center;justify-content:center;padding:10px 16px;border-radius:var(--radius-sm);border:1px solid var(--primary);background:transparent;color:var(--primary);text-decoration:none;font-weight:600;letter-spacing:.2px;transition:all .2s ease;box-shadow:0 1px 0 rgba(0,0,0,.04)}
.button:hover{transform:translateY(-1px)}
.button:active{transform:translateY(0)}
.button.primary{background:var(--primary);color:#fff;border-color:var(--primary)}
.button.primary:hover{background:#223f69;border-color:#223f69}
.button.secondary{border-color:var(--secondary);color:var(--secondary)}
.button.secondary:hover{background:var(--secondary);color:#fff}
.button.reject{border-color:#8B9AAF;color:#3c4b63}
.button.reject:hover{background:#E8EEF6}
.button.settings{border-color:var(--primary);color:var(--primary)}
.button.settings:hover{background:var(--accent)}

/* Mobile burger */
.mobile-menu-toggle{display:inline-flex;align-items:center;justify-content:center;width:40px;height:40px;border:1px solid var(--border);border-radius:8px;color:var(--primary);background:#fff;transition:background .2s ease,border-color .2s ease}
.mobile-menu-toggle:hover{background:var(--accent);border-color:#cad3df}

/* Slide-in mobile menu */
.mobile-menu{position:fixed;top:0;right:0;bottom:0;width:85%;max-width:360px;background:#fff;border-left:1px solid var(--border);box-shadow:-6px 0 24px rgba(0,0,0,.08);transform:translateX(100%);transition:transform .3s ease;z-index:1200;display:flex;flex-direction:column;gap:16px;padding:20px}
.mobile-menu.open{transform:translateX(0)}
.mobile-menu-close{align-self:flex-end;font-size:24px;line-height:1;color:var(--primary)}
.mobile-nav{display:flex;flex-direction:column;gap:8px}
.mobile-nav a{color:var(--ink);text-decoration:none;padding:10px 8px;border-radius:6px;transition:background .2s ease,color .2s ease}
.mobile-nav a:hover{background:var(--accent);color:var(--primary)}

/* =============================
   Hero Section
   ============================= */
.hero>.container{background:var(--accent);border-bottom:1px solid var(--border);padding-top:40px;padding-bottom:40px}
.hero .content-wrapper{gap:16px}
.hero p{color:var(--muted)}
.cta-group{display:flex;flex-wrap:wrap;gap:12px}

/* =============================
   Content Elements
   ============================= */
.text-section h2,.text-section h3,.text-section h4{color:var(--primary)}
li{margin-bottom:8px}

/* Icon alignment in contact rows */
.text-section img{height:18px;width:auto;display:inline-block;vertical-align:middle;margin-right:6px}

/* =============================
   Testimonials – readability first
   ============================= */
/* Already set via .testimonial-card above for contrast */

/* =============================
   Footer
   ============================= */
footer section>.container{background:#FBFCFE;border-top:1px solid var(--border)}
.footer-nav{display:flex;flex-wrap:wrap;gap:12px}
.footer-nav a{text-decoration:none;color:#2A3446;padding:6px 8px;border-radius:6px}
.footer-nav a:hover{background:var(--accent);color:var(--primary)}

/* =============================
   Cookie Consent (Banner + Modal)
   ============================= */
.cookie-banner{position:fixed;left:0;right:0;bottom:0;display:flex;justify-content:center;padding:16px;background:rgba(255,255,255,.98);border-top:1px solid var(--border);box-shadow:0 -8px 24px var(--shadow);z-index:1300;transform:translateY(110%);transition:transform .35s ease}
.cookie-banner.show{transform:translateY(0)}
.cookie-banner .content{display:flex;max-width:1100px;width:100%;gap:16px;align-items:center;flex-wrap:wrap}
.cookie-banner p{margin:0;flex:1 1 280px;color:var(--ink)}
.cookie-buttons{display:flex;gap:10px;flex-wrap:wrap}
.cookie-modal-backdrop{position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(17,24,39,.45);z-index:1400;opacity:0;pointer-events:none;transition:opacity .3s ease}
.cookie-modal-backdrop.show{opacity:1;pointer-events:auto}
.cookie-modal{position:fixed;left:0;right:0;bottom:0;margin:0 auto;max-width:680px;background:#fff;border-top-left-radius:12px;border-top-right-radius:12px;box-shadow:0 -12px 30px rgba(0,0,0,.18);z-index:1500;transform:translateY(100%);transition:transform .35s ease;display:flex;flex-direction:column;gap:16px;padding:20px;border:1px solid var(--border)}
.cookie-modal.show{transform:translateY(0)}
.cookie-modal .modal-header{display:flex;align-items:center;justify-content:space-between}
.cookie-modal .modal-body{display:flex;flex-direction:column;gap:12px}
.cookie-toggle{display:flex;align-items:center;justify-content:space-between;padding:10px 12px;border:1px solid var(--border);border-radius:8px}
.toggle{width:46px;height:26px;border-radius:26px;background:#E5E7EB;display:flex;align-items:center;padding:3px}
.toggle .knob{width:20px;height:20px;background:#fff;border-radius:50%;box-shadow:0 1px 4px rgba(0,0,0,.2);transform:translateX(0);transition:transform .2s ease,background .2s ease}
.toggle.on{background:var(--secondary)}
.toggle.on .knob{transform:translateX(20px)}

/* =============================
   Utilities
   ============================= */
.muted{color:var(--muted)}
.centered{display:flex;align-items:center;justify-content:center}

/* =============================
   Responsive – mobile first
   ============================= */
@media (max-width:768px){
  /* Required: text-image stack on mobile */
  .text-image-section{flex-direction:column}
}

@media (min-width:600px){
  h1{font-size:36px}
  h2{font-size:26px}
}

@media (min-width:768px){
  h1{font-size:40px}
  h2{font-size:28px}
  section>.container{padding-left:24px;padding-right:24px}
  .cta-group{gap:16px}
}

@media (min-width:992px){
  .main-nav{display:flex}
  .mobile-menu-toggle{display:none}
  .mobile-menu{display:none}
  header .content-wrapper{flex-wrap:nowrap}
}

/* =============================
   Additional micro-interactions
   ============================= */
.main-nav a,.footer-nav a{transition:transform .2s ease,background .2s ease,color .2s ease}
.main-nav a:active,.footer-nav a:active{transform:translateY(1px)}

/* =============================
   Elegant spacing helpers for sections
   ============================= */
section + section .container{border-top:0}

/* =============================
   Dark-on-Light rule for testimonials & reviews (contrast)
   ============================= */
/* Ensured by .testimonial-card: white background and dark text */

/* End of stylesheet */