:root{
  --bg:#fafbfc;
  --bg2:#f0f2f5;
  --bg3:#e8ebef;
  --ink:#0d1117;
  --muted:#586069;
  --line:rgba(13,17,23,.10);
  --shadow:0 16px 48px rgba(13,17,23,.08);
  --shadow2:0 24px 72px rgba(13,17,23,.12);
  --r:20px;
  --max:1180px;

  /* AnalogyIT brand — green from logo + deep navy */
  --a1:#3DDC84;   /* primary green (logo) */
  --a2:#00b86e;   /* deeper green */
  --a3:#0d1117;   /* dark navy/black */
  --a4:#161b22;   /* softer dark */
  --a5:#e6fcf0;   /* light mint tint */
  --accent:#3DDC84;

  --dark:#0d1117;
  --dark2:#161b22;
  --glass:rgba(255,255,255,.82);
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:"SF Pro Display","SF Pro Text",-apple-system,BlinkMacSystemFont,"Segoe UI",Inter,Roboto,Helvetica,Arial,sans-serif;
  color:var(--ink);
  background:var(--bg);
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
.container{width:min(var(--max),calc(100% - 2rem));margin-inline:auto}
.small{color:var(--muted);font-weight:600;font-size:.92rem}
.note{color:var(--muted);font-weight:700;font-size:.9rem}

.skip-link{position:absolute;left:-999px;top:auto;width:1px;height:1px;overflow:hidden}
.skip-link:focus{left:1rem;top:1rem;width:auto;height:auto;padding:.75rem 1rem;background:#fff;border:1px solid var(--line);border-radius:12px;z-index:9999}

/* ── Header ── */
.header{
  position:sticky;top:0;z-index:1000;
  background:rgba(250,251,252,.88);
  backdrop-filter:blur(20px) saturate(180%);
  -webkit-backdrop-filter:blur(20px) saturate(180%);
  border-bottom:1px solid rgba(13,17,23,.06);
}
.nav{
  display:flex;align-items:center;justify-content:space-between;
  padding:1rem 0;gap:1rem;
}
.brand{display:flex;align-items:center;gap:.7rem}
.brand img{width:42px;height:42px}
.brand strong{font-size:1.05rem;letter-spacing:-.2px;color:var(--ink)}
.brand span{display:block;font-size:.8rem;color:var(--muted);font-weight:600}

.links{display:flex;gap:.15rem;align-items:center}
.links a{
  padding:.55rem .85rem;border-radius:10px;
  font-weight:700;font-size:.9rem;color:var(--ink);
  transition:background 160ms ease,color 160ms ease;
}
.links a:hover{background:var(--a5);color:var(--a2)}
.links a.active{background:var(--a5);color:var(--a2)}

.cta{display:flex;gap:.5rem;align-items:center}
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:.5rem;
  padding:.78rem 1.2rem;border-radius:12px;font-weight:700;font-size:.92rem;
  border:1px solid rgba(13,17,23,.12);
  background:#fff;color:var(--ink);
  box-shadow:0 1px 3px rgba(13,17,23,.06);
  cursor:pointer;
  transition:transform 160ms ease,box-shadow 160ms ease,background 160ms ease;
}
.btn:hover{transform:translateY(-1px);box-shadow:0 6px 20px rgba(13,17,23,.10)}
.btn.primary{
  color:#fff;border-color:transparent;
  background:linear-gradient(135deg,var(--a1),var(--a2));
  box-shadow:0 4px 16px rgba(61,220,132,.30);
}
.btn.primary:hover{box-shadow:0 8px 28px rgba(61,220,132,.40);transform:translateY(-2px)}
.btn.dark{
  color:#fff;border-color:rgba(255,255,255,.10);
  background:var(--dark);
  box-shadow:0 4px 16px rgba(13,17,23,.20);
}
.btn.ghost{background:transparent;box-shadow:none;border-color:rgba(13,17,23,.10)}
.btn.ghost:hover{background:var(--a5)}
.btn.small{padding:.55rem .82rem;font-size:.88rem}

.menu{display:none;border:1px solid rgba(13,17,23,.10);background:#fff;border-radius:10px;padding:.55rem .85rem;font-weight:700;font-size:.9rem;box-shadow:0 2px 8px rgba(13,17,23,.06);cursor:pointer}
.drawer{display:none;padding:0 0 1rem}
.drawer a{display:block;padding:.8rem .4rem;border-radius:10px;font-weight:700;transition:background 150ms ease}
.drawer a:hover{background:var(--a5)}

/* ── Hero ── */
.hero{
  position:relative;
  padding:5rem 0 3.5rem;
  overflow:hidden;
  background:var(--dark);
  color:#fff;
}
.hero::before{
  content:"";position:absolute;
  top:-30%;right:-10%;
  width:700px;height:700px;
  border-radius:50%;
  background:radial-gradient(circle,rgba(61,220,132,.20),transparent 65%);
  filter:blur(60px);
}
.hero::after{
  content:"";position:absolute;
  bottom:-20%;left:-5%;
  width:500px;height:500px;
  border-radius:50%;
  background:radial-gradient(circle,rgba(0,184,110,.12),transparent 60%);
  filter:blur(50px);
}
.hero-grid{
  position:relative;z-index:1;
  display:grid;grid-template-columns:1.1fr .9fr;
  gap:2.5rem;align-items:center;
}
.kicker{
  display:inline-flex;align-items:center;gap:.5rem;
  padding:.4rem .75rem;border-radius:8px;
  border:1px solid rgba(61,220,132,.25);
  background:rgba(61,220,132,.08);
  font-weight:700;font-size:.84rem;
  color:var(--a1);
}
.kdot{width:8px;height:8px;border-radius:50%;background:var(--a1);box-shadow:0 0 8px rgba(61,220,132,.60)}
h1{
  margin:.9rem 0 1rem;
  font-size:clamp(2.4rem,4.8vw,3.6rem);
  line-height:1.06;letter-spacing:-1px;
}
.grad{
  background:linear-gradient(135deg,var(--a1),var(--a2));
  -webkit-background-clip:text;background-clip:text;color:transparent;
}
.hero p{margin:0 0 1.2rem;color:rgba(255,255,255,.70);font-size:1.06rem;max-width:58ch}
.row{display:flex;gap:.65rem;flex-wrap:wrap;margin-top:1rem}
.pills{display:flex;gap:.5rem;flex-wrap:wrap;margin-top:1rem}
.pill{
  padding:.38rem .65rem;border-radius:8px;
  border:1px solid rgba(61,220,132,.20);
  background:rgba(61,220,132,.06);
  font-weight:700;font-size:.82rem;color:var(--a1);
}
.hero .pill{border-color:rgba(61,220,132,.25);background:rgba(61,220,132,.08)}

/* ── Bento panel ── */
.bento{
  position:relative;border-radius:24px;
  border:1px solid rgba(61,220,132,.18);
  background:rgba(22,27,34,.95);
  box-shadow:0 20px 60px rgba(0,0,0,.35);
  overflow:hidden;
}
.bento::before{
  content:"";position:absolute;inset:-50%;
  background:radial-gradient(circle at 20% 30%,rgba(61,220,132,.15),transparent 55%),
             radial-gradient(circle at 80% 60%,rgba(0,184,110,.10),transparent 50%);
  transform:rotate(10deg);
}
.bento-inner{position:relative;padding:1.4rem}
.avatar{
  width:200px;height:200px;margin:.2rem auto 0;
  border-radius:50%;overflow:hidden;
  background:var(--dark);
  border:4px solid rgba(61,220,132,.30);
  outline:2px solid rgba(61,220,132,.10);
}
.avatar img{width:100%;height:100%;object-fit:cover;object-position:center}
.cap{text-align:center;margin-top:.7rem;color:#fff}
.cap strong{display:block;font-size:1.1rem;letter-spacing:-.2px}
.cap span{display:block;margin-top:.2rem;color:rgba(255,255,255,.60);font-weight:600;font-size:.9rem}

.bgrid{display:grid;grid-template-columns:1fr 1fr;gap:.7rem;margin-top:1rem}
.tile{
  border-radius:14px;
  border:1px solid rgba(61,220,132,.12);
  background:rgba(255,255,255,.04);
  padding:.85rem;color:#fff;
}
.tile strong{display:block;font-size:1rem;color:var(--a1)}
.tile span{display:block;margin-top:.15rem;color:rgba(255,255,255,.55);font-weight:600;font-size:.85rem}

/* ── Sections ── */
.section{padding:3.5rem 0}
.section.alt{background:var(--bg2);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.section.dark{
  background:var(--dark);
  color:#fff;
}
.section.dark .small,.section.dark .lead,.section.dark p,.section.dark li{color:rgba(255,255,255,.70)}
.section.dark a{color:#fff}
.section.dark .card,.section.dark .panel,.section.dark details{
  background:rgba(255,255,255,.05);
  border-color:rgba(61,220,132,.12);
  box-shadow:0 16px 48px rgba(0,0,0,.25);
}

h2{margin:0 0 .6rem;font-size:clamp(1.7rem,3vw,2.3rem);letter-spacing:-.6px}
.lead{margin:0 0 1.4rem;color:var(--muted);max-width:75ch;font-size:1.02rem}

/* ── Cards ── */
.cards{display:grid;grid-template-columns:repeat(12,1fr);gap:1rem}
.card{
  grid-column:span 4;border-radius:var(--r);
  border:1px solid var(--line);
  background:#fff;
  box-shadow:0 2px 8px rgba(13,17,23,.04);
  padding:1.3rem;
  transition:transform 200ms ease,box-shadow 200ms ease,border-color 200ms ease;
}
.card:hover{transform:translateY(-4px);box-shadow:var(--shadow);border-color:rgba(61,220,132,.25)}
.card h3{margin:.15rem 0 .5rem;letter-spacing:-.3px}
.card p{margin:0;color:var(--muted)}
.card ul{margin:.8rem 0 0 1.1rem;color:var(--muted)}
.card li{margin:.25rem 0}
.badge{
  display:inline-flex;align-items:center;gap:.4rem;
  padding:.32rem .6rem;border-radius:8px;
  border:1px solid rgba(61,220,132,.18);
  background:var(--a5);
  font-weight:700;font-size:.8rem;color:var(--a2);
}
.badge .dot{width:7px;height:7px;border-radius:50%;background:var(--a1);box-shadow:0 0 6px rgba(61,220,132,.50)}

/* ── Split & Panel ── */
.split{display:grid;grid-template-columns:1fr 1fr;gap:1.5rem;align-items:start}
.panel{
  border-radius:var(--r);
  border:1px solid var(--line);
  background:#fff;
  box-shadow:var(--shadow);
  padding:1.5rem;
}
.panel h3{margin:.1rem 0 .45rem}
.panel p{margin:0 0 1rem;color:var(--muted)}

/* ── Steps ── */
.steps{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem}
.step{
  border-radius:var(--r);
  border:1px solid var(--line);
  background:#fff;
  box-shadow:0 2px 8px rgba(13,17,23,.04);
  padding:1.2rem;
  transition:transform 200ms ease,box-shadow 200ms ease;
}
.step:hover{transform:translateY(-3px);box-shadow:var(--shadow)}
.step strong{display:block;font-size:1.04rem;letter-spacing:-.2px}
.step p{margin:.4rem 0 0;color:var(--muted)}
.num{
  width:40px;height:40px;border-radius:12px;
  display:flex;align-items:center;justify-content:center;
  font-weight:900;font-size:.95rem;
  color:#fff;background:linear-gradient(135deg,var(--a1),var(--a2));
  box-shadow:0 4px 12px rgba(61,220,132,.25);
  margin-bottom:.6rem;
}

/* ── Page header ── */
.pagehead{
  padding:3rem 0 1.5rem;
  background:var(--dark);color:#fff;
  position:relative;overflow:hidden;
}
.pagehead::before{
  content:"";position:absolute;
  top:-50%;right:-15%;
  width:600px;height:600px;border-radius:50%;
  background:radial-gradient(circle,rgba(61,220,132,.14),transparent 60%);
  filter:blur(50px);
}
.pagehead h1{margin:0;font-size:clamp(2rem,4vw,2.8rem);letter-spacing:-.7px;position:relative}
.pagehead p{margin:.6rem 0 0;color:rgba(255,255,255,.65);max-width:70ch;position:relative}

/* ── FAQ ── */
details{
  border-radius:var(--r);border:1px solid var(--line);
  background:#fff;box-shadow:0 2px 8px rgba(13,17,23,.04);
  padding:1rem 1.1rem;
}
details+details{margin-top:.75rem}
summary{cursor:pointer;font-weight:800;letter-spacing:-.2px}
details p{margin:.65rem 0 0;color:var(--muted)}

/* ── Forms ── */
.form{
  border-radius:var(--r);border:1px solid var(--line);
  background:#fff;box-shadow:var(--shadow);
  padding:1.3rem;
}
.field{display:flex;flex-direction:column;gap:.3rem;margin-bottom:.8rem}
label{font-weight:700;font-size:.92rem}
input,select,textarea{
  border-radius:12px;border:1px solid rgba(13,17,23,.12);
  padding:.75rem .9rem;font:inherit;outline:none;
  background:#fff;
  transition:border-color 200ms ease,box-shadow 200ms ease;
}
textarea{min-height:140px;resize:vertical}
input:focus,select:focus,textarea:focus{
  border-color:var(--a1);
  box-shadow:0 0 0 4px rgba(61,220,132,.12);
}

/* ── Footer ── */
.footer{
  padding:2.5rem 0;
  border-top:1px solid var(--line);
  background:var(--dark);color:#fff;
}
.fgrid{display:grid;grid-template-columns:1.2fr .8fr .8fr;gap:1.2rem}
.footer h4{margin:.1rem 0 .5rem;letter-spacing:-.2px}
.footer a{color:rgba(255,255,255,.80);font-weight:600;transition:color 150ms ease}
.footer a:hover{color:var(--a1)}
.footer .small{color:rgba(255,255,255,.50)}
.footer .pill{border-color:rgba(61,220,132,.20);background:rgba(61,220,132,.06);color:var(--a1)}
.legal{
  margin-top:1.3rem;padding-top:1rem;
  border-top:1px solid rgba(255,255,255,.08);
  color:rgba(255,255,255,.45);font-size:.88rem;
  display:flex;flex-wrap:wrap;gap:.5rem;align-items:center;justify-content:space-between;
}

/* ── Motion ── */
.reveal{opacity:0;transform:translateY(12px)}
.reveal.is-visible{opacity:1;transform:none;transition:opacity 450ms ease,transform 450ms ease}
@media(prefers-reduced-motion:no-preference){
  .btn,.card,.panel,details,.bento,.tile,.step{transition:transform 180ms ease,box-shadow 180ms ease,border-color 180ms ease}
}

/* ── Responsive ── */
@media(max-width:1100px){.card{grid-column:span 6}}
@media(max-width:980px){
  .hero-grid{grid-template-columns:1fr}
  .split{grid-template-columns:1fr}
  .fgrid{grid-template-columns:1fr}
  .steps{grid-template-columns:1fr}
  .card{grid-column:span 12}
}
@media(max-width:900px){
  .links,.cta{display:none}
  .menu{display:inline-flex}
  .drawer{display:block}
  .drawer[hidden]{display:none}
}
