/* ÖlKompass Minimalist Brand CSS - style.css */
/* CSS RESET + Normalization */
html,body,div,span,applet,object,iframe,
h1,h2,h3,h4,h5,h6,p,blockquote,pre,a,abbr,acronym,address,code,del,dfn,em,img,ins,kbd,q,s,samp,small,strong,sub,sup,tt,var,b,u,i,center,dl,dt,dd,ol,ul,li,fieldset,form,label,legend,table,caption,tbody,tfoot,thead,tr,th,td,article,aside,canvas,details,embed,figure,figcaption,footer,header,hgroup,main,menu,nav,output,ruby,section,summary,time,mark,audio,video {
  margin:0; padding:0; border:0; font-size:100%; font:inherit; vertical-align:baseline;
}
html {
  box-sizing:border-box;
}
*,*:before,*:after {
  box-sizing:inherit;
}
body {
  line-height:1.5;
  font-family:'Open Sans', Arial, Helvetica, sans-serif;
  font-size:16px;
  background:#fff;
  color:#183153;
  -webkit-font-smoothing:antialiased;
  min-height:100vh;
}
img,embed,object,video {
  max-width:100%; height:auto;
}
ul,ol {
  list-style:none;
}
a {
  color:inherit;
  text-decoration:none;
  transition:color 0.2s;
}
button,input,select,textarea {
  font-family:inherit;
  font-size:inherit;
  color:inherit;
  background:none;
  border:none;
  outline:none;
}

/* ================= GLOBAL BRAND VARS ================= */
:root {
  --color-primary:#183153;
  --color-secondary:#A7B4C4;
  --color-accent:#F5C646;
  --color-bg:#fff;
  --color-bg-light:#f9fafc;
  --color-card:#fff;
  --color-grey:#edf0f6;
  --color-text:#183153;
  --color-text-light:#445065;
  --color-shadow:rgba(24,49,83,0.06);
  --radius:12px;
  --shadow:0 2px 8px var(--color-shadow);
  --font-display:'Roboto Slab', Times, serif;
  --font-body:'Open Sans', Arial, Helvetica, sans-serif;
}

/* =================== LAYOUT & CONTAINERS ===================== */
.container {
  width:100%;
  max-width:1200px;
  margin:0 auto;
  padding:0 16px;
  box-sizing:border-box;
}
.content-wrapper {
  display:flex;
  flex-direction:column;
  gap:24px;
}
.section {
  margin-bottom:60px;
  padding:40px 20px;
  background:var(--color-bg-light);
  border-radius:var(--radius);
}

/* HEADER & NAVIGATION */
header {
  background:var(--color-bg);
  box-shadow:0 1px 8px rgba(24,49,83,0.04);
  position:relative;
  z-index:50;
}
.header-flex {
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:20px;
  padding:20px 0;
}
header img {
  height:40px;
  width:auto;
}
.main-nav {
  display:flex;
  align-items:center;
  gap:24px;
}
.main-nav a {
  font-size:16px;
  padding:4px 0;
  color:var(--color-text);
  border-bottom:2px solid transparent;
  transition:border-color 0.2s;
  font-family:var(--font-body);
}
.main-nav a:hover,
.main-nav a:focus {
  border-bottom:2px solid var(--color-accent);
  color:var(--color-primary);
}
.cta-button {
  background:var(--color-accent);
  color:var(--color-primary);
  font-weight:bold;
  letter-spacing:0.02em;
  font-size:16px;
  border-radius:24px;
  padding:12px 30px;
  box-shadow:0 2px 8px var(--color-shadow);
  border:none;
  outline:none;
  cursor:pointer;
  transition:background 0.18s,box-shadow 0.18s,transform 0.15s;
  display:inline-block;
  font-family:var(--font-body);
}
.cta-button:hover,
.cta-button:focus {
  background:#ffe082;
  color:var(--color-primary);
  box-shadow:0 4px 16px rgba(245,198,70,0.19);
  transform:translateY(-2px) scale(1.035);
}
.mobile-menu-toggle {
  background:none;
  border:none;
  font-size:2rem;
  color:var(--color-primary);
  padding:4px 10px;
  cursor:pointer;
  display:none;
  line-height:1;
  transition:color 0.2s,background 0.2s;
}
.mobile-menu-toggle:focus {
  outline:2px solid var(--color-accent);
}

/* ================== MOBILE MENU =================== */
.mobile-menu {
  position:fixed;
  top:0; left:0;
  width:100vw; height:100vh;
  background:rgba(24,49,83,0.95);
  z-index:100;
  display:flex;
  flex-direction:column;
  align-items:flex-end;
  transform:translateX(100%);
  transition:transform 0.38s cubic-bezier(.77,0,.175,1);
  will-change:transform;
  pointer-events:none;
}
.mobile-menu.open {
  transform:translateX(0);
  pointer-events:auto;
}
.mobile-menu-close {
  font-size:2.2rem;
  color:#fff;
  background:none;
  border:none;
  margin:20px 32px 0 0;
  align-self:flex-end;
  cursor:pointer;
  transition:color 0.18s;
}
.mobile-menu-close:hover,
.mobile-menu-close:focus {
  color:var(--color-accent);
}
.mobile-nav {
  display:flex;
  flex-direction:column;
  align-items:flex-start;
  gap:24px;
  margin:40px 24px 0 32px;
  width:80%;
}
.mobile-nav a {
  color:#fff;
  font-size:1.2rem;
  font-weight:bold;
  padding:12px 0;
  border-bottom:2px solid transparent;
  width:100%;
  transition:border 0.18s;
  font-family:var(--font-body);
}
.mobile-nav a:hover,
.mobile-nav a:focus {
  border-bottom:2px solid var(--color-accent);
  color:var(--color-accent);
}

/* ===================== HERO SECTIONS ===================== */
.hero,.comparison-hero,.tech-hero,.profit-hero,.reports-hero,.thank-you-section {
  min-height:340px;
  background:var(--color-bg);
  display:flex;
  align-items:center;
  margin-bottom:0;
}
.hero h1, .comparison-hero h1,.tech-hero h1,.profit-hero h1,.reports-hero h1,.thank-you-section h1 {
  font-family:var(--font-display);
  font-size:2rem;
  color:var(--color-primary);
  margin-bottom:10px;
  font-weight:700;
}
.hero p,
.comparison-hero p,
.tech-hero p,
.profit-hero p,
.reports-hero h2,
.thank-you-section p {
  font-size:1.1rem;
  color:var(--color-text-light);
  margin-bottom:18px;
}

/* ================= SPLIT SECTIONS ================== */
.content-grid {
  display:flex;
  flex-wrap:wrap;
  gap:20px;
  justify-content:space-between;
}
.text-image-section {
  display:flex;
  align-items:center;
  gap:30px;
  flex-wrap:wrap;
}

/* ================== FEATURE GRID ================== */
.feature-grid {
  display:flex;
  flex-wrap:wrap;
  gap:28px;
  margin:24px 0 0 0;
}
.feature-item {
  display:flex;
  flex-direction:column;
  align-items:flex-start;
  gap:15px;
  flex:1 1 220px;
  min-width:200px;
  padding:24px 20px 20px 20px;
  background:var(--color-card);
  border-radius:var(--radius);
  box-shadow:0 2px 10px var(--color-shadow);
  transition:box-shadow 0.22s,transform 0.22s;
}
.feature-item img {
  width:34px; height:34px;
  margin-bottom:4px;
}
.feature-item h3 {
  font-family:var(--font-display);
  font-size:1.16rem;
  font-weight:600;
  color:var(--color-primary);
  margin:0 0 7px 0;
}
.feature-item p {
  font-size:1rem;
  color:var(--color-text-light);
}
.feature-item:hover {
  box-shadow:0 8px 36px rgba(24,49,83,0.09);
  transform:translateY(-3px) scale(1.03);
}

/* ==================== CARDS ==================== */
.card-container {
  display:flex;
  flex-wrap:wrap;
  gap:24px;
}
.card {
  margin-bottom:20px;
  position:relative;
  background:var(--color-card);
  border-radius:var(--radius);
  box-shadow:var(--shadow);
  padding:28px 22px;
  flex:1 1 270px;
  min-width:240px;
  transition:box-shadow 0.22s,transform 0.22s;
}
.card:hover {
  box-shadow:0 12px 36px rgba(24,49,83,0.10);
  transform:translateY(-4px) scale(1.028);
}

/* ================= TABLES ================== */
table {
  width:100%;
  border-collapse:separate;
  border-spacing:0;
  background:var(--color-card);
  border-radius:var(--radius);
  overflow:hidden;
  box-shadow:var(--shadow);
  font-size:1rem;
  margin:0 0 12px 0;
}
thead {
  background:var(--color-bg-light);
}
th,td {
  padding:16px 14px;
  text-align:left;
  border-bottom:1px solid #e6e7ec;
  color:var(--color-text);
  font-family:var(--font-body);
}
th {
  font-weight:bold;
}
tbody tr:last-child td {
  border-bottom:none;
}
table.mini-comparison-table th,
table.mini-comparison-table td {
  font-size:1rem;
  padding:10px 8px;
}

/* =================== COMMON LISTS ==================== */
.quick-facts, .benefits-list, .faq-list {
  margin:16px 0 0 0;
  padding-left:23px;
}
.quick-facts li, .benefits-list li, .faq-list li {
  list-style:disc;
  color:var(--color-text-light);
  font-size:1rem;
  margin-bottom:10px;
  line-height:1.6;
}

/* ==================== INSIGHTS & REPORTS ================== */
.insights-list, .reports-list {
  display:flex;
  flex-wrap:wrap;
  gap:32px;
}
.insight-preview, .report-summary {
  background:var(--color-card);
  border-radius:var(--radius);
  box-shadow:var(--shadow);
  padding:22px 18px 18px 18px;
  flex:1 1 320px;
  min-width:260px;
  display:flex;
  flex-direction:column;
  gap:12px;
  transition:box-shadow 0.22s,transform 0.22s;
}
.insight-preview:hover, .report-summary:hover {
  box-shadow:0 10px 32px rgba(24,49,83,0.08);
  transform:translateY(-3px) scale(1.025);
}
.insight-preview h3,
.report-summary h3 {
  font-family:var(--font-display);
  font-size:1.13rem;
  margin-bottom:6px;
  color:var(--color-primary);
}
.insight-preview p,
.report-summary p {
  font-size:1rem;
  color:var(--color-text-light);
}
.insight-preview a, .report-summary a {
  color:var(--color-primary);
  text-decoration:underline;
  font-weight:600;
  font-size:1rem;
  margin-top:6px;
  transition:color 0.16s;
}
.insight-preview a:hover, .report-summary a:hover {
  color:var(--color-accent);
}

.topic-filters {
  display:flex;
  align-items:center;
  gap:12px;
  margin-top:18px;
}
.topic-filters button {
  background:var(--color-bg-light);
  border-radius:18px;
  padding:6px 16px;
  border:none;
  color:var(--color-primary);
  font-weight:600;
  margin-right:6px;
  cursor:pointer;
  transition:background 0.16s;
}
.topic-filters button:hover,
.topic-filters button:focus {
  background:var(--color-accent);
  color:var(--color-primary);
}

.signup-success {
  background:#eff1f5;
  border-radius:var(--radius);
  padding:16px 19px;
  margin-top:14px;
}

/* ===================== CTA SECTION ====================== */
.cta {
  background:var(--color-card);
  border-radius:var(--radius);
  box-shadow:var(--shadow);
  margin:48px 0 24px 0;
  padding:38px 22px;
  text-align:center;
}
.cta h2 {
  font-family:var(--font-display);
  font-size:1.4rem;
  color:var(--color-primary);
  margin-bottom:8px;
}
.cta p {
  font-size:1.07rem;
  color:var(--color-text-light);
  margin-bottom:18px;
}

/* =============== TESTIMONIALS =============== */
.testimonials {
  margin:36px 0 24px 0;
  padding:0;
  background:transparent;
}
.testimonial-card {
  display:flex;
  flex-direction:column;
  align-items:flex-start;
  gap:20px;
  padding:20px;
  margin-bottom:20px;
  background:#fff;
  box-shadow:0 4px 16px rgba(24,49,83,0.06);
  border-radius:var(--radius);
  border-left:6px solid var(--color-accent);
  transition:box-shadow 0.18s,transform 0.18s;
}
.testimonial-card p {
  color:#183153;
  font-size:1.07rem;
  margin-bottom:0;
  line-height:1.55;
}
.testimonial-card strong {
  font-weight:700;
  color:var(--color-primary);
}
.testimonial-card:hover {
  box-shadow:0 10px 36px rgba(24,49,83,0.09);
  transform:translateY(-2px);
}

/* ============== CUSTOM CHART PLACEHOLDER ============ */
.chart-placeholder {
  width:100%;
  min-height:80px;
  background:var(--color-grey);
  border-radius:var(--radius);
  color:var(--color-secondary);
  display:flex;
  align-items:center; justify-content:center;
  font-size:1.13rem;
  margin-bottom:16px;
}

/* =============== MISC ======================== */
.dropdown {
  background:var(--color-bg-light);
  color:var(--color-primary);
  border-radius:20px;
  padding:6px 18px;
  font-size:1rem;
  margin-left:16px;
  display:inline-block;
}
.comparison-metrics-legend {
  background:#f7f9fa;
  border-radius:var(--radius);
  padding:16px 18px;
  margin-top:16px;
}
.company-selection-info {
  display:flex;
  flex-wrap:wrap;
  align-items:center;
  gap:16px;
  margin-bottom:20px;
}
.case-studies-highlight {
  background:var(--color-bg-light);
  padding:18px 12px;
  border-radius:var(--radius);
  margin-bottom:16px;
}

/* ============== MAP PLACEHOLDER =============== */
.map-placeholder {
  background:var(--color-bg-light);
  border-radius:var(--radius);
  padding:18px;
  margin-top:16px;
  display:flex;
  flex-direction:column;
  align-items:flex-start;
  gap:10px;
}
.map-placeholder img {
  width:40px; margin-bottom:6px;
}

/* ========== FAQ (Accordion style simple) ============= */
.faq-list li {
  border-bottom:1px solid #e7eaf0;
  padding-bottom:14px;margin-bottom:14px;
}
.faq-list li:last-child {
  border-bottom:none;
  margin-bottom:0;
}

/* ========== FOOTER =============== */
footer {
  margin-top:42px;
  background:var(--color-bg);
  border-top:1px solid #eef1f5;
  z-index:15;
  position:relative;
}
footer .content-wrapper {
  flex-direction:column;
  gap:18px;
  align-items:center;
  padding:32px 12px 20px 12px;
}
.footer-nav {
  display:flex;
  flex-wrap:wrap;
  gap:16px;
  margin:14px 0 6px 0;
  font-size:1rem;
  font-family:var(--font-body);
}
.footer-nav a {
  color:var(--color-secondary);
  transition:color 0.15s;
  border-bottom:1px solid transparent;
  padding-bottom:2px;
}
.footer-nav a:hover,
.footer-nav a:focus {
  color:var(--color-primary);
  border-bottom:1px solid var(--color-accent);
}
.footer-contact-snippet {
  display:flex;
  flex-wrap:wrap;
  align-items:center;
  gap:10px 22px;
  color:var(--color-secondary);
  font-size:0.97rem;
}
.footer-contact-snippet img {
  width:17px; height:17px; margin-bottom:-3px;
}
.footer-legal {
  color:#8e9db0;
  font-size:0.92rem;
  text-align:center;
  margin-top:14px;
}

/* ============== COOKIE CONSENT BANNER =============== */
.cookie-banner {
  position:fixed;
  bottom:0; left:0;
  width:100vw;
  z-index:999;
  background:var(--color-bg-light);
  box-shadow:0 -1px 16px rgba(24,49,83,0.07);
  display:none;
  flex-direction:row;
  align-items:center;
  justify-content:space-between;
  gap:20px;
  padding:24px 32px;
  font-size:1rem;
  border-radius:16px 16px 0 0;
  opacity:1;
  transition:transform 0.25s,opacity 0.25s;
}
.cookie-banner.hide {
  opacity:0; pointer-events:none; transform:translateY(100%);
}
.cookie-banner .cookie-text {
  color:var(--color-primary);
  font-size:1.05rem;
  max-width:500px;
}
.cookie-banner .cookie-actions {
  display:flex; gap:16px;
}
.cookie-banner button {
  background:var(--color-accent);
  color:var(--color-primary);
  padding:8px 18px;
  border:none;
  border-radius:20px;
  font-size:1rem;
  font-weight:600;
  cursor:pointer;
  transition:background 0.16s, color 0.14s;
}
.cookie-banner button.cookie-reject {
  background:#ededed;
  color:var(--color-text-light);
}
.cookie-banner button.cookie-settings {
  background:var(--color-bg);
  color:var(--color-primary);
  border:1px solid var(--color-accent);
}
.cookie-banner button:hover,
.cookie-banner button:focus {
  background:#ffe082;
  color:var(--color-primary);
}

/* =========== Cookie Settings Modal ============= */
.cookie-modal {
  position:fixed;
  left:50%; top:50%;
  transform:translate(-50%,-50%) scale(0.92);
  background:#fff;
  z-index:2001;
  box-shadow:0 8px 36px rgba(24,49,83,0.18);
  border-radius:var(--radius);
  padding:38px 30px 30px 30px;
  min-width:310px;
  max-width:92vw;
  opacity:0;
  pointer-events:none;
  transition:opacity 0.24s,transform 0.24s;
}
.cookie-modal.open {
  opacity:1;
  pointer-events:auto;
  transform:translate(-50%,-50%) scale(1);
}
.cookie-modal h2 {
  font-family:var(--font-display);
  font-size:1.13rem;
  margin-bottom:14px;
  color:var(--color-primary);
}
.cookie-modal .cookie-category {
  display:flex; align-items:center; gap:10px;
  margin-bottom:17px;
}
.cookie-modal .cookie-toggle {
  width:40px; height:22px;
  border-radius:12px;
  background:var(--color-grey);
  position:relative;
  transition:background 0.2s;
}
.cookie-modal .cookie-toggle input[type="checkbox"] {
  display:none;
}
.cookie-modal .cookie-toggle .switch {
  position:absolute;
  left:2px; top:2px;
  width:18px; height:18px;
  background:var(--color-primary);
  border-radius:50%;
  transition:transform 0.2s, background 0.2s;
}
.cookie-modal .cookie-toggle input[type="checkbox"]:checked + .switch {
  transform:translateX(18px);
  background:var(--color-accent);
}
.cookie-modal .cookie-footer {
  margin-top:24px;
  display:flex; gap:20px; justify-content:flex-end;
}
.cookie-modal .close-modal {
  position:absolute;
  top:16px; right:20px;
  background:none;
  border:none;
  font-size:1.7rem;
  color:var(--color-primary);
  cursor:pointer;
  transition:color 0.17s;
}
.cookie-modal .close-modal:hover,
.cookie-modal .close-modal:focus {
  color:var(--color-accent);
}

/* ============== HEADINGS & TYPOGRAPHY =============== */
h1 {
  font-size:2rem;
  font-family:var(--font-display);
  font-weight:700;
  margin-bottom:10px;
  color:var(--color-primary);
}
h2 {
  font-size:1.4rem;
  font-family:var(--font-display);
  font-weight:600;
  color:var(--color-primary);
  margin-bottom:7px;
}
h3 {
  font-size:1.13rem;
  font-family:var(--font-display);
  font-weight:600;
  color:var(--color-primary);
  margin-bottom:4px;
}
h1,h2,h3 { letter-spacing:0.01em; }
p,strong {
  font-family:var(--font-body);
}
strong { font-weight:700; }

/* ================== TEXT SECTION =================== */
.text-section {
  margin-bottom:28px;
  display:flex;
  flex-direction:column;
  gap:10px;
}

/* =============== UTILITIES =================== */
.d-none { display:none !important; }


/* ================== RESPONSIVE DESIGN ===================== */
@media (max-width:1200px) {
  .container { max-width:97vw; }
}
@media (max-width:990px) {
  .feature-grid, .insights-list, .reports-list { flex-direction:column; }
  .card-container { gap:16px; }
}
@media (max-width:900px) {
  .header-flex { flex-wrap:wrap; gap:10px; }
}
@media (max-width:768px) {
  /* Hamburger shown, menu hidden */
  .main-nav,.cta-button { display:none; }
  .mobile-menu-toggle { display:block; }
  .header-flex { gap:10px; }
  .section {
    margin-bottom:34px;
    padding:28px 7px;
  }
  .feature-grid { gap:16px; }
  .cta { padding:24px 7px; }
  .testimonials { margin:22px 0 5px 0; }
  .case-studies-highlight { padding:13px 7px; }
  .card-container { gap:12px; }
  .content-grid, .insights-list, .reports-list { flex-direction:column; }
  .text-image-section {
    flex-direction:column;
    gap:14px;
    align-items:flex-start;
  }
  .company-selection-info { flex-direction:column; gap:7px; }
  .cookie-banner { flex-direction:column; align-items:flex-start; gap:13px; padding:15px 14px; }
}
@media (max-width:520px) {
  .container { padding:0 4px; }
  .hero h1, .comparison-hero h1, .tech-hero h1, .profit-hero h1, .reports-hero h1 { font-size:1.23rem; }
  .cta { padding:13px 3px; }
  .cookie-banner { padding:10px 2px; }
  .cookie-modal { padding:18px 6px 16px 6px; }
}

/* ========== ANIMATIONS & MICRO INTERACTIONS ========== */
.cta-button,
.feature-item,
.insight-preview,
.report-summary,
.card {
  transition:box-shadow 0.18s, transform 0.18s, background 0.24s;
}
a, button, .mobile-menu-toggle, .mobile-nav a, .footer-nav a {
  transition:color 0.16s,background 0.16s,border 0.16s;text-decoration:none;
}

/* ========== VISUAL FOCUS STATES ========== */
a:focus,
button:focus,
input:focus {
  outline:2px solid var(--color-accent);
  outline-offset:2px;
}

/* ============= PRINT CSS ============= */
@media print {
  header,footer,.cookie-banner,.mobile-menu { display:none !important; }
  body { background:#fff; color:#000; }
  .section, .feature-item, .card, .testimonial-card, .cta, .case-studies-highlight, .map-placeholder { box-shadow:none; border:none; background:#fff; }
}

/* ===================== END ======================= */
