/* =========================================================
   Kalinotes — Page Fonctionnalités
   Extends css/style.css (same tokens)
   ========================================================= */

/* ---------- Hero (human) ---------- */
.feat-hero{
  background:linear-gradient(180deg, var(--hero-tint) 0%, #F7FAF4 60%, var(--white) 100%);
  padding:64px 0 72px;
}
.feat-hero-grid{
  display:grid;grid-template-columns:1.05fr .95fr;gap:54px;align-items:center;
}
.feat-hero-text .eyebrow{margin-bottom:.3em}
.feat-hero h1{
  font-family:var(--f-sans);font-weight:800;
  font-size:clamp(34px,4.4vw,52px);line-height:1.08;letter-spacing:-1.6px;
  color:var(--green-900);margin-bottom:20px;
}
.feat-hero h1 .script{
  display:block;font-family:var(--f-script);font-weight:400;
  font-size:clamp(26px,3vw,34px);letter-spacing:-.5px;
  color:var(--green-800);margin-bottom:6px;
}
.feat-hero h1 mark{background:linear-gradient(transparent 58%, var(--lime) 58%);padding:0 .08em}
.feat-hero-lead{font-size:17px;line-height:1.65;color:var(--text);max-width:520px}
.feat-hero-cta{display:flex;gap:14px;flex-wrap:wrap;margin-top:28px}
.feat-hero-trust{margin-top:18px;font-size:14px;color:var(--muted);font-style:italic}

.feat-hero-media{position:relative}
.feat-hero-photo{
  width:100%;height:auto;display:block;border-radius:var(--radius-lg);
  box-shadow:var(--shadow-float);object-fit:cover;aspect-ratio:4/3;
}
.feat-hero-badge{
  position:absolute;left:-18px;bottom:24px;
  display:flex;align-items:center;gap:12px;
  background:#fff;border:1px solid var(--border);border-radius:14px;
  padding:12px 16px;box-shadow:var(--shadow-float);max-width:250px;
}
.feat-hero-badge .fhb-ic{
  width:40px;height:40px;border-radius:10px;flex:0 0 40px;display:grid;place-items:center;
  background:var(--lime);font-size:20px;
}
.feat-hero-badge strong{display:block;font-size:13px;color:var(--green-900)}
.feat-hero-badge span{font-size:12px;color:var(--muted)}

/* ---------- Two surfaces (extension + dashboard) ---------- */
.surfaces{padding:72px 0}
.surfaces-grid{display:grid;grid-template-columns:1fr 1fr;gap:24px;max-width:1000px;margin:0 auto}
.surface-card{
  background:var(--white);border:1px solid var(--border);
  border-radius:var(--radius-lg);padding:32px;
}
.surface-card .s-ic{
  width:52px;height:52px;border-radius:14px;display:grid;place-items:center;
  font-size:26px;margin-bottom:18px;
}
.surface-card.ext .s-ic{background:var(--lime-soft)}
.surface-card.dash .s-ic{background:var(--green-900);color:var(--lime)}
.surface-card h3{font-family:var(--f-sans);font-weight:800;font-size:22px;color:var(--green-900);margin-bottom:10px}
.surface-card p{font-size:15px;line-height:1.6;color:var(--text);margin-bottom:16px}
.surface-card ul{display:flex;flex-direction:column;gap:8px}
.surface-card li{position:relative;padding-left:24px;font-size:14px;color:var(--text);line-height:1.5}
.surface-card li::before{content:"✓";position:absolute;left:0;color:var(--green-accent);font-weight:800}

/* ---------- Feature group ---------- */
.feat-group{padding:64px 0}
.feat-group.alt{background:var(--bg-soft)}

/* tag chips */
.feat-tag{
  display:inline-flex;align-items:center;gap:6px;
  font-size:12px;font-weight:700;letter-spacing:.3px;
  padding:5px 12px;border-radius:var(--radius-pill);margin-bottom:14px;
}
.feat-tag.ext{background:var(--lime-soft);color:var(--green-900)}
.feat-tag.dash{background:var(--green-900);color:var(--lime)}
.feat-tag.ia{background:#FBE9DF;color:#B5532B}

/* ---------- Feature row (media + text) ---------- */
.feat-row{
  display:grid;grid-template-columns:1fr 1fr;gap:56px;align-items:center;
  max-width:1120px;margin:0 auto;
}
.feat-row + .feat-row{margin-top:72px}
.feat-row.reverse .feat-figure{order:-1}
.feat-text h3{
  font-family:var(--f-sans);font-weight:800;font-size:clamp(24px,2.6vw,30px);
  line-height:1.2;letter-spacing:-.6px;color:var(--green-900);margin-bottom:14px;
}
.feat-text > p{font-size:16px;line-height:1.65;color:var(--text);margin-bottom:18px}
.feat-list{display:flex;flex-direction:column;gap:11px}
.feat-list li{position:relative;padding-left:30px;font-size:15px;line-height:1.5;color:var(--text)}
.feat-list li::before{
  content:"";position:absolute;left:0;top:3px;width:18px;height:18px;border-radius:6px;
  background:var(--lime-soft) url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23548A3A' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='20 6 9 17 4 12'/%3E%3C/svg%3E") center/12px no-repeat;
}
.feat-list li strong{color:var(--text-strong);font-weight:600}

/* media frame */
.feat-figure{
  position:relative;border-radius:var(--radius-lg);overflow:hidden;
  border:1px solid var(--border);box-shadow:var(--shadow-float);
  background:var(--white);
}
.feat-figure img,
.feat-figure video{width:100%;height:auto;display:block}
.feat-figure figcaption{
  font-size:12.5px;color:var(--muted);padding:10px 14px;border-top:1px solid var(--border);
  background:var(--bg-soft);
}
/* video placeholder overlay */
.feat-figure.is-video::after{content:"";position:absolute;inset:0;background:rgba(0,40,28,.06)}
.feat-figure .play-btn{
  position:absolute;inset:0;margin:auto;z-index:2;
  width:70px;height:70px;border-radius:50%;border:0;cursor:pointer;
  background:rgba(255,255,255,.92);display:grid;place-items:center;
  box-shadow:0 8px 24px rgba(0,0,0,.22);transition:transform .2s;
}
.feat-figure .play-btn:hover{transform:scale(1.07)}
.media-tag{
  position:absolute;top:12px;left:12px;z-index:3;
  font-size:11px;font-weight:700;color:#fff;background:rgba(0,62,47,.78);
  padding:4px 10px;border-radius:var(--radius-pill);backdrop-filter:blur(4px);
}

/* ---------- Mini feature grid ---------- */
.feat-cards{
  display:grid;grid-template-columns:repeat(3,1fr);gap:22px;
  max-width:1080px;margin:44px auto 0;
}
.feat-card{
  background:var(--white);border:1px solid var(--border);border-radius:var(--radius);
  padding:24px;
}
.feat-card .fc-ic{
  width:44px;height:44px;border-radius:12px;display:grid;place-items:center;
  background:var(--lime-soft);font-size:22px;margin-bottom:14px;
}
.feat-card h4{font-size:16px;font-weight:700;color:var(--green-900);margin-bottom:8px}
.feat-card p{font-size:14px;line-height:1.55;color:var(--text)}

/* ---------- Highlight (dark) block: macros ---------- */
.feat-highlight{
  background:var(--green-900);color:#fff;border-radius:var(--radius-lg);
  padding:48px;max-width:1120px;margin:0 auto;
  display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:center;
}
.feat-highlight .fh-tag{background:var(--lime);color:var(--green-900)}
.feat-highlight h3{font-family:var(--f-sans);font-weight:800;font-size:clamp(24px,2.6vw,30px);line-height:1.2;letter-spacing:-.6px;margin-bottom:14px}
.feat-highlight > div > p{color:rgba(255,255,255,.82);font-size:16px;line-height:1.65;margin-bottom:20px}
.macro-chips{display:flex;flex-wrap:wrap;gap:10px}
.macro-chips code{
  font-family:"SFMono-Regular",ui-monospace,Menlo,monospace;font-size:13px;
  background:rgba(255,255,255,.1);color:var(--lime);border:1px solid rgba(255,255,255,.18);
  padding:7px 12px;border-radius:8px;
}
.macro-visual{
  background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.14);
  border-radius:var(--radius);padding:22px;
}
.macro-visual .mv-line{display:flex;align-items:center;justify-content:space-between;padding:11px 0;border-bottom:1px solid rgba(255,255,255,.1);font-size:14px}
.macro-visual .mv-line:last-child{border-bottom:0}
.macro-visual .mv-score{font-weight:800;color:var(--lime)}

/* ---------- Connectors row ---------- */
.feat-connectors{display:flex;flex-wrap:wrap;gap:16px;justify-content:center;margin-top:36px}
.conn-card{
  display:flex;align-items:center;gap:12px;background:var(--white);
  border:1px solid var(--border);border-radius:14px;padding:14px 20px;min-width:210px;
}
.conn-card img{width:34px;height:34px;object-fit:contain}
.conn-card strong{display:block;font-size:14px;color:var(--green-900)}
.conn-card span{font-size:12px;color:var(--muted)}

/* ---------- Browsers ---------- */
.browsers{display:flex;gap:18px;justify-content:center;flex-wrap:wrap;margin-top:36px}
.browser-pill{
  display:flex;align-items:center;gap:10px;background:var(--white);
  border:1px solid var(--border);border-radius:var(--radius-pill);padding:12px 22px;
  font-weight:700;color:var(--green-900);font-size:15px;
}
.browser-pill .bp-ic{font-size:20px}

/* ---------- responsive ---------- */
@media (max-width:900px){
  .feat-hero-grid{grid-template-columns:1fr;gap:36px}
  .feat-hero-media{max-width:520px}
  .surfaces-grid{grid-template-columns:1fr;max-width:520px}
  .feat-row{grid-template-columns:1fr;gap:28px}
  .feat-row.reverse .feat-figure{order:0}
  .feat-row + .feat-row{margin-top:54px}
  .feat-cards{grid-template-columns:1fr 1fr}
  .feat-highlight{grid-template-columns:1fr;gap:30px;padding:34px}
}
@media (max-width:560px){
  .feat-cards{grid-template-columns:1fr}
  .feat-hero-badge{left:0}
  .surface-card,.feat-card{padding:22px}
}
