/* DMAR PRO THEME v2 (Netlify) */
*{box-sizing:border-box}html,body{margin:0;padding:0}
:root{--bg:#fff;--text:#333;--muted:#566070;--brand:#0A5694;--border:#E6EAF0;--radius:16px;--shadow:0 10px 30px rgba(0,0,0,.07);--max:1200px;--green:#0b8a4a;--notice-text:#9a3412}
body{font-family:Inter,ui-sans-serif,system-ui,-apple-system,Segoe UI,Roboto,Helvetica,Arial;color:var(--text);background:var(--bg);line-height:1.6}
h1,h2,h3{line-height:1.15;margin:0 0 8px}
a{color:var(--brand);text-decoration:none}
.container{max-width:var(--max);margin:0 auto;padding:0 20px}
.btn{display:inline-flex;align-items:center;gap:.5rem;background:var(--brand);color:#fff;padding:.78rem 1.1rem;border-radius:999px;font-weight:700;border:1px solid #084a7e;box-shadow:var(--shadow);transition:transform .15s ease}
.btn:hover{transform:translateY(-1px)}.btn.alt{background:#fff;color:var(--brand);border-color:var(--brand)}
.btn:hover{transform:translateY(-1px)}.btn.alt{background:#fff;color:var(--brand);border-color:var(--brand)}.btn.ghost{background:transparent;color:var(--brand);border-color:transparent;box-shadow:none}
.badge{display:inline-block;padding:.28rem .6rem;border:1px solid var(--border);border-radius:999px;color:#0A5694;background:#eaf3fb;font-size:.8rem}
.small{font-size:.95rem;color:#556070}
.privacy-consent{margin-top:16px}
.privacy-consent p{margin:0 0 8px}
.privacy-consent .privacy-checkbox{display:grid;grid-template-columns:auto 1fr;gap:10px;align-items:flex-start;line-height:1.5}
.privacy-consent .privacy-checkbox input{margin-top:3px}
.privacy-consent .privacy-checkbox span{display:block}
hr.sep{border:none;height:1px;background:var(--border);margin:20px 0}



/* Mobile drawer: full viewport below header */
.mobile{
  position: fixed;
  left: 0;
  right: 0;
  top: var(--hdr-h, 64px);                 /* starts below header */
  height: calc(100dvh - var(--hdr-h, 64px));/* fills rest of screen */
  background: #fff;
  border-top: 1px solid var(--border, #e5e7eb);
  padding: 16px;
  display: none;                            /* hidden by default */
  z-index: 1000;                            /* above page */
  overflow: auto;                           /* scroll if long */
  -webkit-overflow-scrolling: touch;
}

.mobile.open{ display: block; }

.mobile a{
  display: block;
  padding: 14px 16px;                       /* large tap targets */
  color: #111;
  font-weight: 700;
  font-size: 16px;
  border-bottom: 1px solid var(--border, #e5e7eb);
}

/* Dimmed background behind the drawer */
.scrim{
  position: fixed; inset: 0;
  background: rgba(0,0,0,.35);
  z-index: 999;                             /* just under drawer */
  opacity: 0; pointer-events: none;
  transition: opacity .15s ease;
}
.scrim.open{ opacity: 1; pointer-events: auto; }



/* Hero */
.hero{position:relative;padding:90px 0 40px;background:linear-gradient(180deg,#f6f9fc 0%,#ffffff 66%)}
.hero .wrap{display:grid;gap:24px;grid-template-columns:1.1fr .9fr;align-items:center}
.hero h1{font-size:clamp(32px,4.5vw,54px)}
.subtitle{color:var(--muted);max-width:80ch}
.hero .art{min-height:300px;border-radius:22px;border:1px solid var(--border);overflow:hidden;box-shadow:var(--shadow)}
.hero .art img{width:100%;height:100%;object-fit:cover;display:block}

/* Sections */
.section{padding:60px 0}.section h2{font-size:clamp(24px,3.2vw,34px);margin:0 0 10px}.section p.lead{color:var(--muted);max-width:80ch}
.grid{display:grid;gap:24px}
.cards{grid-template-columns:repeat(auto-fit,minmax(260px,1fr))}
.card{background:#fff;border:1px solid var(--border);border-radius:var(--radius);padding:20px;box-shadow:var(--shadow)}
.kpi{display:flex;gap:14px;align-items:center;color:#566070;font-size:.95rem;flex-wrap:wrap}
.table{width:100%;border-collapse:collapse}.table th,.table td{padding:12px 10px;border-bottom:1px solid var(--border);text-align:left}.table th{color:#0A5694;font-weight:700}
body.cookies .table{font-size:.95rem}
body.cookies .table code{font-size:.9em}
@media (max-width:640px){body.cookies .table th,body.cookies .table td{padding:8px 6px;font-size:.82rem;line-height:1.4}body.cookies .table th{font-size:.78rem}body.cookies .table td:first-child{min-width:135px}body.cookies .table td{word-break:break-word}}
.faq dt{font-weight:700;margin-top:14px}.faq dd{margin:6px 0 16px 0;color:#556070}

/* Sustainability wave */
.s-hero{position:relative;isolation:isolate;padding:80px 0 40px;background:linear-gradient(180deg,rgba(11,138,74,.12),#fff 60%)}
.wave{position:absolute;inset:auto 0 0;height:160px;overflow:hidden;z-index:-1}
.wave svg{display:block;width:100%;height:160px}
#flow1{animation:flow 14s linear infinite}#flow2{animation:flow 18s linear infinite reverse;opacity:.6}@keyframes flow{to{transform:translateX(-50%)}}
.brand-row{display:flex;gap:20px;align-items:center;flex-wrap:wrap;opacity:.9}.brand-row img{height:38px;filter:grayscale(10%) saturate(110%)}

/* Footer & sticky CTA */
footer{padding-bottom: 70px !important;}
footer{border-top:1px solid var(--border);background:#f7f9fc;padding:30px 0;color:#334155;font-size:.95rem}
footer .cols{display:grid;gap:20px;grid-template-columns:2fr 1fr 1fr}@media (max-width:900px){footer .cols{grid-template-columns:1fr}}
.sticky-cta{position:fixed;right:16px;bottom:16px;z-index:80}
.notice{
  background: #fff7ed; /* subtle warm background retained */
  border: 1px solid var(--notice-border); /* use semantic notice border variable */
  color: var(--notice-text); /* use semantic notice color */
  border-radius: 12px;
  padding: 10px 12px;
  font-size: .9rem;
}

/* Utilities */
.hidden{display:none!important}

/* ==== Mobile polish (v3) ==== */

/* Form controls (mobile-friendly, 16px+ to avoid iOS zoom) */
input, textarea, select {
  width: 100%;
  padding: 10px 12px;
  border: 1px solid var(--border);
  border-radius: 12px;
  font-size: 16px;
  outline: none;
  background: #fff;
}
input:focus, textarea:focus, select:focus {
  border-color: var(--brand);
  box-shadow: 0 0 0 3px rgba(10,86,148,.15);
}

/* Buttons: minimum 44px touch targets */
.btn { min-height: 44px; }
a, button { -webkit-tap-highlight-color: rgba(0,0,0,0); }

/* Hero and grids collapse nicely on phones */
@media (max-width: 1020px){
  .nav .mid { display:none }
  .burger { display:inline-flex }
  .nav .right .btn.alt { display:none } /* hide brochure on small screens */
}
@media (max-width: 780px){
  .container{ padding: 0 16px }
  .hero{ padding:56px 0 20px }
  .hero .wrap{ grid-template-columns: 1fr; gap:16px }
  .hero .art{ height: 300px }
  .section{ padding: 42px 0 }
  .cards{ grid-template-columns: 1fr }
  figure.card img{ height: 180px }
  footer .cols{ grid-template-columns: 1fr }
}

/* Mobile drawer height & scroll */
.mobile{
  max-height: calc(100dvh - 110px);
  overflow:auto;
  -webkit-overflow-scrolling: touch;
}

/* Subtle improvements to readability */
body{ line-height: 1.65 }
.subtitle{ font-size: 1.02rem }


/* --- Mobile stability + overlay --- */
html,body{overflow-x:hidden}
.scrim{position:fixed;inset:0;background:rgba(0,0,0,.35);opacity:0;pointer-events:none;transition:opacity .15s ease;z-index:59}
.scrim.open{opacity:1;pointer-events:auto}
.mobile{position:fixed;left:0;right:0;top:110px;background:#fff;border-top:1px solid var(--border);padding:18px;display:none;z-index:60;max-height:calc(100dvh - 110px);overflow:auto;-webkit-overflow-scrolling:touch}
.mobile.open{display:block}
@media (max-width:780px){
  .topbar{position:static}
  .sticky-cta{display:none}
}
html.nav-open, body.nav-open{overflow:hidden;touch-action:none}


/* ===== Mobile compact header + action bar (v5) ===== */
@media (max-width: 780px){
  .logo{ height:22px }
  .nav{ min-height:64px }
  .nav .right .btn{ display:none }       /* hide big CTAs on phone */
  .nav .right .btn.burger{ display:inline-flex; } /* keep burger visible */
  .btn.burger{ padding:8px 12px; font-size:14px }
  .hero h1{ font-size: clamp(26px, 7.5vw, 42px); }
  .subtitle{ font-size: 1rem }
}
 .grid-2,.grid-3{grid-template-columns:1fr}
 form .row{grid-template-columns:1fr}
 h1{font-size:clamp(24px,7vw,36px)}
h2{font-size:clamp(18px,5.5vw,24px)}
 /* Compact the Contact & Careers pages on phones (visually ~20–25% tighter) */
body.contact .container.compact,
body.careers .container.compact { font-size:0.94rem }
body.contact .card, body.careers .card { padding:10px }
body.contact .grid-2, body.careers .grid-2 { gap:12px }
 body.contact input, body.contact select, body.contact textarea,
 body.careers input, body.careers select, body.careers textarea { padding:9px 11px }
  /* keep inputs at 16px+ for accessibility (avoid iOS zoom); size reduction is spacing-focused */
 

/* Mobile bottom action bar (safe-area aware) */
.action-bar{
  position:fixed;left:0;right:0;
  bottom:0;
  background:#f8fafc;border-top:1px solid rgba(148,163,184,.45);
  padding:8px 12px calc(8px + env(safe-area-inset-bottom, 0));
  display:none;z-index:70;gap:8px;align-items:center;justify-content:center
}
@media (max-width:780px){ .action-bar{ display:flex } }
.action-bar .btn{ flex:1 1 0; justify-content:center; min-height:38px; padding:0.3rem }


.action-bar .btn:hover{background:#e2e8f0;transform:none}
.action-bar .btn:active{background:#cbd5f5}
.action-bar .btn.alt{background:#fff;border-color:rgba(148,163,184,.6);color:var(--brand)}

/* NAV SLIDE */
.mobile{transform:translateY(-8px);opacity:0;transition:transform .18s ease, opacity .18s ease}
.mobile.open{transform:translateY(0);opacity:1}
.scrim{transition:opacity .15s ease}


/* ===== v7 mobile drawer & header polish ===== */
header{position:sticky;top:0;z-index:1000;background:rgba(255,255,255,.98);backdrop-filter:blur(8px)}
.nav{min-height:64px}

.mobile{
  position:fixed;left:0;right:0;top: var(--hdr-h,64px);
  padding-top: 16px;
  background:#fff;border-top:1px solid var(--border);
  display:none;z-index:999;max-height: calc(100dvh - var(--hdr-h,64px));overflow:auto;
  -webkit-overflow-scrolling:touch;
  box-shadow:0 8px 24px rgba(0,0,0,.12);
}
.mobile.open{display:block}
.mobile a{display:block;padding:12px 18px;border-bottom:1px solid var(--border);font-weight:600;color:#111}

.scrim{position:fixed;inset:0;background:rgba(0,0,0,.35);opacity:0;pointer-events:none;z-index:998}
.scrim.open{opacity:1;pointer-events:auto}

.btn.burger{pointer-events:auto}

/* Slide animation */
.mobile{transform:translateY(-8px);opacity:0;transition:transform .18s ease,opacity .18s ease}
.mobile.open{transform:translateY(0);opacity:1}




/* v8: ensure header is always clickable and above all */
header, .nav, .nav .right, .btn.burger{ position:relative; z-index: 1001; }
.mobile{ z-index: 1000; }
.scrim{ z-index: 999; }

/* Protect from any accidental overlay from first section */
main > section:first-child{ position:relative; z-index: 0; }

/* Improved mobile drawer for visibility */
.mobile {
  position: fixed;
  left: 0;
  right: 0;
  top: var(--hdr-h, 64px);
  background: #fff;
  border-top: 1px solid var(--border);
  display: none;
  z-index: 1000;
  max-height: calc(100dvh - var(--hdr-h, 64px));
  overflow: auto;
  -webkit-overflow-scrolling: touch;
  box-shadow: 0 8px 32px rgba(0,0,0,.18);
  padding: 32px 24px 24px 24px;
  border-radius: 0 0 18px 18px;
  opacity: 0;
  transform: translateY(-12px);
  transition: transform .22s cubic-bezier(.4,0,.2,1), opacity .22s cubic-bezier(.4,0,.2,1);
}
.mobile.open {
  display: block;
  opacity: 1;
  transform: translateY(0);
}
.mobile a {
  display: block;
  padding: 18px 12px;
  border-bottom: 1px solid var(--border);
  font-weight: 600;
  color: #111;
  font-size: 1.15rem;
}

/* Improved scrim overlay for mobile nav */
.scrim {
  position: fixed;
  inset: 0;
  background: rgba(0,0,0,.45);
  opacity: 0;
  pointer-events: none;
  z-index: 999;
  transition: opacity .18s cubic-bezier(.4,0,.2,1);
}
.scrim.open {
  opacity: 1;
  pointer-events: auto;
}
/* Announcement bar */
.topbar{
  position:sticky;         /* sits at the very top while scrolling */
  top:0;
  z-index:1002;            /* higher than header */
  background:linear-gradient(90deg,#0b8a4a 0%, #0a4730 45%, #0a0f14 100%);
  color:#fff;
}
.careers-grid{
  grid-template-columns: 1.2fr 0.8fr;
}
.topbar .row{
  display:flex;align-items:center;justify-content:center;
  gap:12px;min-height:38px;padding:6px 20px;
}
.topbar .dot{width:8px;height:8px;border-radius:999px;background:#fff;opacity:.9}
.topbar .close{position:absolute;right:10px;top:6px;background:transparent;border:0;color:#fff;font-size:18px;cursor:pointer}

/* Header (refined) */
header{position:sticky;top:0;z-index:1001;background:rgba(255,255,255,.95);backdrop-filter:blur(8px);border-bottom:1px solid var(--border)}
.nav{display:flex;align-items:center;gap:18px;min-height:64px}
.nav .left{display:flex;align-items:center;gap:16px}
.logo{height:28px}
.nav .mid{flex:1 1 auto;display:flex;justify-content:center}
.nav .mid ul{display:flex;gap:22px;list-style:none;margin:0;padding:0}
.nav .mid a{color:#111;font-weight:600;opacity:.85}
.nav .mid a:hover{opacity:1}
.nav .right{display:flex;gap:10px;align-items:center}
.burger{display:none}
@media (max-width:1020px){
  .nav .mid{display:none}
  .burger{display:inline-flex}
}
/* Home-only: make the hero (port) photo smaller */
body.home .hero .art{
  min-height: 0;     /* override the existing min-height:300px */
  height: 320px;     /* smaller on desktop */
  max-width: 780px;  /* optional: keeps the image from spanning too wide */
  margin: 12px auto; /* centers the art block nicely */
}
/* opt-in extra compact, if desired */
@media (max-width:780px){
  .compact-xs .card{ padding:8px }
  .compact-xs .grid-2{ gap:10px }
  .compact-xs input, .compact-xs select, .compact-xs textarea{ padding:8px 10px }
  .compact-xs .lead{ font-size:1rem }
}

/* Contact page layout */
body.contact main{ padding-bottom:60px }
body.contact .section{ padding-top:48px }
body.contact .contact-grid{
  grid-template-columns:minmax(0,1.2fr) minmax(0,.8fr);
  align-items:start;
  gap:28px;
}
body.contact .contact-card{ padding:26px }
body.contact .contact-form{ display:flex; flex-direction:column; gap:16px }
body.contact .form-grid{ grid-template-columns:repeat(2,minmax(0,1fr)); gap:12px }
body.contact .message-field textarea{ min-height:170px; resize:vertical }
body.contact .form-actions{ display:flex; gap:12px; align-items:center; flex-wrap:wrap }
body.contact .form-actions .btn{ flex:0 0 auto }
body.contact .form-actions #form-msg{ flex:1 1 auto; min-width:160px }
@media (max-width:960px){
  body.contact .contact-grid{ grid-template-columns:minmax(0,1fr); }
  body.careers .careers-grid{ 
    grid-template-columns: minmax(0, 1fr);
   }
}
@media (max-width:640px){
  body.contact .section{ padding-top:32px }
  body.contact .contact-card{ padding:20px }
  body.contact .form-grid{ grid-template-columns:1fr }
  body.contact .message-field textarea{ min-height:150px }
  body.contact .form-actions{ align-items:flex-start }
}

/* Cookie banner */
.cookie-banner{position:fixed;inset:auto 12px 12px;background:rgba(15,25,35,.82);backdrop-filter:blur(6px);color:#fff;z-index:1200;opacity:0;pointer-events:none;transform:translateY(100%);transition:transform .3s ease,opacity .3s ease;padding:12px;border-radius:18px}
.cookie-banner.open{opacity:1;pointer-events:auto;transform:translateY(0)}
.cookie-banner__inner{max-width:var(--max);margin:0 auto;display:grid;gap:16px;grid-template-columns:minmax(0,2fr) minmax(0,1fr);align-items:flex-start;max-height:calc(100dvh - 48px);overflow:auto}
.cookie-banner__content h2{margin:0 0 8px;font-size:1.22rem}
.cookie-banner__content p{margin:0 0 8px;color:#f1f5f9;font-size:.95rem}
.cookie-banner__list{list-style:none;margin:0;padding:0;display:grid;gap:10px}
.cookie-banner__list li{background:rgba(15,25,35,.55);border:1px solid rgba(148,163,184,.35);border-radius:14px;padding:10px 14px;display:flex;justify-content:space-between;align-items:center;gap:16px}
.cookie-banner__list label{display:flex;justify-content:space-between;align-items:center;gap:20px;cursor:pointer}
.cookie-banner__list strong{display:block;color:#fff}
.cookie-banner__list p{margin:6px 0 0;font-size:.85rem;color:#e2e8f0}
.cookie-banner__actions{display:flex;flex-wrap:wrap;gap:8px;justify-content:flex-end}
.cookie-banner__actions .btn{min-width:128px;justify-content:center}
.cookie-banner .toggle{position:relative;width:46px;height:24px}
.cookie-banner .toggle input{opacity:0;width:0;height:0}
.cookie-banner .slider{position:absolute;inset:0;background:rgba(148,163,184,.45);border-radius:999px;transition:all .2s ease}
.cookie-banner .slider::after{content:"";position:absolute;height:18px;width:18px;left:4px;top:3px;background:#fff;border-radius:50%;transition:transform .2s ease}
.cookie-banner .toggle input:checked + .slider{background:var(--brand)}
.cookie-banner .toggle input:checked + .slider::after{transform:translateX(20px)}
body.cookie-banner-open{overflow:hidden}
@media (max-width:900px){.cookie-banner__inner{grid-template-columns:1fr}.cookie-banner__actions{justify-content:flex-start}}
@media (max-width:600px){.cookie-banner{padding:10px 12px 14px;inset:auto 8px 8px;border-radius:14px}.cookie-banner__inner{max-height:calc(100dvh - 32px)}.cookie-banner__content h2{font-size:1.08rem}.cookie-banner__actions{flex-direction:column;align-items:stretch}.cookie-banner__actions .btn{width:100%}.cookie-banner__list li{padding:9px 12px}.cookie-banner__list label{align-items:flex-start;gap:12px}}
/* Make the logo actually smaller */
header .logo { 
  display: flex; align-items: center; 
  height: 30px !important;            /* controls the link box */
}
header .logo img{
  height: 100% !important;             /* image follows the box */
  width: auto; 
  display: block;
}

/* Phone size */
@media (max-width:780px){
  header .logo{ height: 24px !important; }
}
