﻿/* ===============================
   CONNECTA – Elegant Light Theme
   =============================== */

:root{
  /* Colors */
  --text: #0f172a;          /* headings / primary text */
  --muted: #334155;         /* paragraph text */
  --border: #e5e7eb;        /* light borders */
  --card: #f8fafc;          /* card background */
  --badge: #eef2ff;         /* badge background */
  --primary: #2563eb;       /* primary CTAs/links */
  --primary-600: #1d4ed8;
  --accent: #20c997;        /* alt CTA */
}

/* Base */
*{ box-sizing: border-box; }
html,body{
  margin:0; padding:0;
  background:#ffffff; color:var(--text);
  font:16px/1.6 system-ui,-apple-system,"Segoe UI",Roboto,Arial,"Helvetica Neue","Noto Sans",sans-serif;
  -webkit-font-smoothing:antialiased; -moz-osx-font-smoothing:grayscale;
}
a{ color:var(--primary); text-decoration:none; }
a:hover{ text-decoration:underline; }
.small{ font-size:14px; color:var(--muted); }

.container{ max-width:1120px; margin:auto; padding:24px; }

/* Header / Nav */
.header{
  position:sticky; top:0; z-index:10;
  background:#ffffff; backdrop-filter:saturate(180%) blur(8px);
  border-bottom:1px solid var(--border);
}
.nav{ display:flex; align-items:center; gap:20px; }
.nav a{ color:var(--text); padding:10px 8px; border-radius:8px; opacity:.95; transition:color .15s ease, background .15s ease, opacity .15s ease; }
.nav a:hover{ background:#f1f5f9; color:var(--primary); opacity:1; }

.brand{ display:flex; align-items:center; gap:10px; font-weight:800; font-size:18px; color:var(--text); text-decoration:none; }
.brand img{ height:24px; }

/* Typography / Sections */
.hero{ padding:56px 0; }
h1{ font-size:40px; line-height:1.15; margin:0 0 12px; letter-spacing:-.02em; color:var(--text); }
h2{ font-size:28px; margin:28px 0 12px; letter-spacing:-.01em; color:var(--text); }
p.lead{ color:var(--muted); font-size:18px; max-width:900px; }

/* Grid helpers */
.row{ display:grid; grid-template-columns:repeat(12,minmax(0,1fr)); gap:20px; }
.col-6{ grid-column:span 6; }
@media (max-width:900px){ .col-6{ grid-column:span 12; } }

/* Cards / Panels */
.card{
  background:var(--card);
  border:1px solid var(--border);
  border-radius:14px;
  padding:18px;
  transition: box-shadow .15s ease, transform .15s ease, border-color .15s ease;
}
.card:hover{
  border-color:#dbe2ea;
  box-shadow:0 6px 20px rgba(2,6,23,.06);
  transform: translateY(-1px);
}

/* KPI tiles */
.kpis{ display:flex; gap:18px; flex-wrap:wrap; }
.kpi{
  flex:1 1 180px;
  background:var(--card);
  border:1px solid var(--border);
  border-radius:12px;
  padding:14px 16px;
  transition: box-shadow .15s ease, transform .15s ease, border-color .15s ease;
}
.kpi:hover{
  border-color:#dbe2ea;
  box-shadow:0 6px 20px rgba(2,6,23,.06);
  transform: translateY(-1px);
}

/* Lists */
.list{ margin:0; padding-left:18px; color:var(--muted); }

/* Badge */
.badge{
  display:inline-block;
  border:1px solid var(--border);
  border-radius:999px;
  padding:6px 12px;
  background:var(--badge);
  color:#334155;
  font-size:12px; font-weight:700;
  margin-bottom:10px;
}

/* Buttons */
.btn{
  display:inline-block;
  background:var(--primary);
  color:#fff;
  padding:12px 18px;
  border-radius:12px;
  font-weight:700;
  text-decoration:none;
  transition: background .15s ease, transform .05s ease, box-shadow .15s ease;
  box-shadow:0 6px 16px rgba(37,99,235,.18);
  border:none;
}
.btn:hover{ background:var(--primary-600); text-decoration:none; }
.btn:active{ transform: translateY(1px); }
.btn:focus-visible{ outline:3px solid rgba(37,99,235,.25); outline-offset:2px; }

.btn--alt{
  background:var(--accent);
  box-shadow:0 6px 16px rgba(32,201,151,.18);
}
.btn--alt:hover{ filter:brightness(.95); }

/* Footer */
.footer{
  border-top:1px solid var(--border);
  margin-top:40px;
  padding:16px 0;
  color:var(--muted);
  font-size:14px;
  background:#ffffff;
}
.footer .small a{ color:var(--muted); text-decoration:none; }
.footer .small a:hover{ color:var(--primary); text-decoration:underline; }

/* === Light Green background variant === */
:root{
  --bg-soft: #f5fbf7;      /* very pale green */
  --badge-green: #e8f6ee;  /* badge tint on green bg */
}

/* Page background + base surfaces */
html, body { background: var(--bg-soft); }

/* Keep header/footer on the same soft tone */
.header, .footer { background: var(--bg-soft); }

/* Make content cards/tiles pop on green */
.card, .kpi { background:#ffffff; }

/* Slightly greener badge to match the theme */
.badge { background: var(--badge-green); }

/* ===============================
   CONNECTA Cookie Banner
   =============================== */

.cookie-banner{
  position:fixed;
  left:0;
  right:0;
  bottom:0;
  z-index:9999;
  background:#ffffff;
  border-top:1px solid var(--border);
  box-shadow:0 -10px 30px rgba(2,6,23,.10);
}

.cookie-banner[hidden]{ display:none !important; }

.cookie-banner__title{
  background:linear-gradient(90deg, var(--accent), #16a34a);
  color:#ffffff;
  text-align:center;
  font-weight:800;
  letter-spacing:.04em;
  padding:10px 16px;
  font-size:15px;
}

.cookie-banner__body{
  max-width:1120px;
  margin:auto;
  padding:16px 24px 18px;
  display:grid;
  grid-template-columns: 1fr auto;
  gap:16px;
  align-items:center;
}

.cookie-banner__text{
  color:var(--muted);
  font-size:15px;
  line-height:1.65;
}

.cookie-banner__text strong{
  color:var(--text);
}

.cookie-banner__actions{
  display:flex;
  gap:10px;
  flex-wrap:wrap;
  justify-content:flex-end;
}

.cookie-btn{
  display:inline-block;
  border:1px solid var(--border);
  background:#ffffff;
  color:var(--text);
  padding:10px 16px;
  border-radius:12px;
  font-weight:700;
  cursor:pointer;
  transition:background .15s ease, border-color .15s ease, transform .05s ease;
}

.cookie-btn:hover{
  background:#f8fafc;
  border-color:#cbd5e1;
}

.cookie-btn:active{
  transform:translateY(1px);
}

.cookie-btn--primary{
  background:var(--primary);
  color:#ffffff;
  border-color:var(--primary);
  box-shadow:0 6px 16px rgba(37,99,235,.18);
}

.cookie-btn--primary:hover{
  background:var(--primary-600);
  border-color:var(--primary-600);
}

.cookie-btn--accent{
  background:var(--accent);
  color:#ffffff;
  border-color:var(--accent);
  box-shadow:0 6px 16px rgba(32,201,151,.18);
}

.cookie-btn--accent:hover{
  filter:brightness(.96);
}

@media (max-width: 900px){
  .cookie-banner__body{
    grid-template-columns:1fr;
  }

  .cookie-banner__actions{
    justify-content:flex-start;
  }
}