:root{
  --color-primary:#0F4C81;
  --color-secondary:#1A73E8;
  --color-background:#FFFFFF;
  --color-footer-bg:#0A2940;
  --color-button:#0F4C81;

  --color-section-1:#FFFFFF;
  --color-section-2:#F5F7FA;
  --color-section-3:#FFFFFF;
  --color-section-4:#E8F4FD;

  --color-border:#D6DEE6;
  --color-border-light:#E8EEF3;
  --color-accent:#1A73E8;
  --color-text:#0A2940;
  --color-text-muted:#475569;
  --color-white:#FFFFFF;

  --font-sans:"Inter", "Source Sans 3", system-ui, -apple-system, "Segoe UI", Roboto, "Helvetica Neue", Arial, "Noto Sans", "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", sans-serif;
  --font-headings:"Source Sans 3", "Inter", system-ui, -apple-system, "Segoe UI", Roboto, "Helvetica Neue", Arial, "Noto Sans", "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", sans-serif;

  --space-1:0.25rem;
  --space-2:0.5rem;
  --space-3:0.75rem;
  --space-4:1rem;
  --space-5:1.25rem;
  --space-6:1.5rem;
  --space-8:2rem;
  --space-10:2.5rem;
  --space-12:3rem;
  --space-16:4rem;
  --space-20:5rem;

  --radius-0:0;
  --radius-1:0.125rem;
  --radius-2:0.25rem;
  --radius-3:0.5rem;
  --radius-4:0.75rem;

  --shadow-sm:0 1px 2px rgba(15,76,129,0.06);
  --shadow-md:0 4px 12px rgba(15,76,129,0.10);
  --shadow-lg:0 10px 30px rgba(15,76,129,0.14);

  --line-height-base:1.6;
  --line-height-heading:1.25;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:var(--font-sans);
  font-size:16px;
  line-height:var(--line-height-base);
  color:var(--color-text);
  background:var(--color-background);
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
}

h1,h2,h3,h4,h5,h6{
  font-family:var(--font-headings);
  font-weight:700;
  line-height:var(--line-height-heading);
  letter-spacing:-0.01em;
  margin:0 0 var(--space-4);
  color:var(--color-text);
}
h1{font-size:clamp(2rem,4vw,2.75rem)}
h2{font-size:clamp(1.5rem,3vw,2.125rem)}
h3{font-size:clamp(1.25rem,2.25vw,1.5rem)}
h4{font-size:1.125rem}
h5{font-size:1rem}
h6{font-size:0.875rem}

p{margin:0 0 var(--space-4)}
a{color:var(--color-primary);text-decoration:none}
a:hover{text-decoration:underline}
small{font-size:0.875rem;color:var(--color-text-muted)}

img{max-width:100%;height:auto;display:block}
svg{display:block}

.container{
  width:100%;
  max-width:1200px;
  margin:0 auto;
  padding:0 var(--space-6);
}

header{
  position:sticky;
  top:0;
  z-index:50;
  background:var(--color-white);
  border-bottom:1px solid var(--color-border-light);
}

.header-bar{
  display:flex;
  align-items:center;
  justify-content:space-between;
  min-height:72px;
  gap:var(--space-6);
}

.brand{
  display:flex;
  align-items:center;
  gap:var(--space-3);
  font-weight:800;
  color:var(--color-primary);
  text-decoration:none;
  letter-spacing:0.02em;
}

.brand-mark{
  width:36px;height:36px;border-radius:4px;
  background:linear-gradient(135deg,var(--color-primary),var(--color-secondary));
  box-shadow:var(--shadow-sm);
  border:1px solid rgba(10,41,64,0.08);
}

nav ul{
  display:flex;
  gap:var(--space-6);
  list-style:none;
  margin:0;padding:0;
}
nav a{
  color:var(--color-text);
  font-weight:600;
  padding:var(--space-2) var(--space-3);
  border-radius:var(--radius-2);
  transition:background .2s ease, color .2s ease;
}
nav a:hover{background:rgba(26,115,232,0.08);text-decoration:none}
nav a.active, nav a:focus{
  outline:none;background:rgba(26,115,232,0.12);
}

.header-cta{
  display:flex;align-items:center;gap:var(--space-3)
}

.hero{
  background:var(--color-section-4);
  position:relative;
  overflow:hidden;
}
.hero::before{
  content:"";
  position:absolute;inset:0;
  background:radial-gradient(1200px 400px at 80% -20%, rgba(26,115,232,0.12), transparent 60%);
  pointer-events:none;
}
.hero .container{
  padding-top:var(--space-16);
  padding-bottom:var(--space-16);
}
.hero-grid{
  display:grid;grid-template-columns:1.2fr 1fr;gap:var(--space-10);align-items:center;
}
.hero h1{margin-bottom:var(--space-5)}
.hero p{font-size:1.125rem;color:var(--color-text-muted)}

.section{
  padding:var(--space-16) 0;
  border-top:1px solid var(--color-border-light);
}
.section:first-of-type{border-top:none}
.section:nth-child(2){background:var(--color-section-2)}
.section:nth-child(3){background:var(--color-section-3)}
.section:nth-child(4){background:var(--color-section-4)}

.accent-bar{
  width:6px;border-radius:6px;background:linear-gradient(180deg,var(--color-primary),var(--color-secondary));
  box-shadow:var(--shadow-sm);
  margin-right:var(--space-3);
}

.section-header{
  display:flex;align-items:flex-start;gap:var(--space-3);
  margin-bottom:var(--space-10);
}
.section-header p{color:var(--color-text-muted);max-width:60ch}

.grid{
  display:grid;gap:var(--space-6);
}
.grid-3{grid-template-columns:repeat(3,1fr)}
.grid-2{grid-template-columns:repeat(2,1fr)}

.card{
  background:var(--color-white);
  border:1px solid var(--color-border);
  border-radius:var(--radius-3);
  padding:var(--space-6);
  box-shadow:var(--shadow-sm);
  transition:transform .2s ease, box-shadow .2s ease, border-color .2s ease;
}
.card:hover{
  transform:translateY(-2px);
  box-shadow:var(--shadow-md);
  border-color:rgba(26,115,232,0.35);
}
.card h3{margin-bottom:var(--space-3)}
.card p{color:var(--color-text-muted)}

.badge{
  display:inline-block;
  padding:0.25rem 0.5rem;
  background:rgba(26,115,232,0.10);
  color:var(--color-secondary);
  border:1px solid rgba(26,115,232,0.25);
  border-radius:var(--radius-2);
  font-weight:700;
  font-size:0.75rem;
  letter-spacing:0.05em;
  text-transform:uppercase;
  margin-bottom:var(--space-3);
}

.btn{
  display:inline-flex;align-items:center;justify-content:center;
  height:44px;padding:0 var(--space-5);
  border:1px solid transparent;border-radius:var(--radius-2);
  font-weight:700;letter-spacing:0.02em;
  cursor:pointer;transition:background .2s ease, color .2s ease, border-color .2s ease, transform .08s ease;
  user-select:none;
}
.btn:active{transform:translateY(1px)}
.btn-primary{
  background:var(--color-button);
  color:var(--color-white);
  box-shadow:var(--shadow-sm);
}
.btn-primary:hover{background:#0d3e6b}
.btn-secondary{
  background:transparent;color:var(--color-secondary);
  border-color:rgba(26,115,232,0.4);
}
.btn-secondary:hover{
  background:rgba(26,115,232,0.10);
  border-color:var(--color-secondary);
}
.btn-neutral{
  background:var(--color-white);color:var(--color-text);
  border-color:var(--color-border);
}
.btn-neutral:hover{
  border-color:rgba(26,115,232,0.4);box-shadow:var(--shadow-sm);
}

.form{
  background:var(--color-white);border:1px solid var(--color-border);
  border-radius:var(--radius-3);padding:var(--space-6);box-shadow:var(--shadow-sm);
}
.form-row{display:flex;gap:var(--space-4);flex-wrap:wrap}
.form-group{flex:1 1 280px;min-width:220px;display:flex;flex-direction:column;gap:var(--space-2);margin-bottom:var(--space-4)}
.label{font-weight:600;color:var(--color-text)}
.input,.textarea,.select{
  appearance:none;background:var(--color-white);
  border:1px solid var(--color-border);border-radius:var(--radius-2);
  padding:0.75rem 0.875rem;font:inherit;color:var(--color-text);
  transition:border-color .2s ease, box-shadow .2s ease, background .2s ease;
}
.textarea{min-height:120px;resize:vertical}
.input:focus,.textarea:focus,.select:focus{
  outline:none;border-color:var(--color-secondary);
  box-shadow:0 0 0 3px rgba(26,115,232,0.18);
}
.help{font-size:0.875rem;color:var(--color-text-muted)}

footer{
  background:var(--color-footer-bg);
  color:var(--color-white);
  padding:var(--space-12) 0 var(--space-8);
}
.footer-grid{
  display:grid;gap:var(--space-8);grid-template-columns:2fr 1fr 1fr;align-items:flex-start;
}
footer a{color:#dbeafe;text-decoration:none}
footer a:hover{text-decoration:underline}
.footer-brand{
  font-weight:800;color:#FFFFFF;letter-spacing:0.02em;margin-bottom:var(--space-3)
}
.footer p{color:#cbd5e1}

hr.sep{
  height:1px;background:rgba(255,255,255,0.12);
  border:0;margin:var(--space-8) 0;
}

.to-top{
  display:inline-flex;align-items:center;gap:0.5rem;
  padding:0.5rem 0.75rem;border:1px solid rgba(255,255,255,0.25);
  border-radius:var(--radius-2);color:#fff;text-decoration:none;
  transition:background .2s ease, border-color .2s ease;
}
.to-top:hover{background:rgba(255,255,255,0.08);text-decoration:none;border-color:rgba(255,255,255,0.4)}

.kpi{
  display:grid;grid-template-columns:repeat(4,1fr);gap:var(--space-6);margin:var(--space-8) 0;
}
.kpi-item{
  padding:var(--space-5);
  background:var(--color-white);
  border:1px solid var(--color-border);
  border-radius:var(--radius-3);
  text-align:center;
  box-shadow:var(--shadow-sm);
}
.kpi-item strong{
  display:block;font-size:1.75rem;color:var(--color-primary);margin-bottom:var(--space-2)
}

@media (max-width: 1024px){
  .hero-grid{grid-template-columns:1fr;gap:var(--space-8)}
  .grid-3{grid-template-columns:repeat(2,1fr)}
  .kpi{grid-template-columns:repeat(2,1fr)}
  .footer-grid{grid-template-columns:1fr 1fr}
}
@media (max-width: 640px){
  .header-bar{flex-direction:column;align-items:flex-start;gap:var(--space-4);padding:var(--space-4) 0}
  nav ul{flex-wrap:wrap}
  .grid-3,.grid-2{grid-template-columns:1fr}
  .kpi{grid-template-columns:1fr}
  .form-row{flex-direction:column}
}

:focus-visible{
  outline:2px solid var(--color-secondary);
  outline-offset:2px;
}

::selection{
  background:rgba(26,115,232,0.18);
}

@media (prefers-reduced-motion: reduce){
  *{animation-duration:0.01ms !important;animation-iteration-count:1 !important;transition-duration:0.01ms !important;scroll-behavior:auto !important}
}


/* Cookie Banner Additional Styles for Tailwind */
.cookie-banner-hover-effect:hover {
    transform: translateY(-1px);
    box-shadow: 0 4px 8px rgba(0, 0, 0, 0.15);
}

@media (prefers-reduced-motion: reduce) {
    .cookie-banner-hover-effect:hover {
        transform: none;
    }
}