/* ================================================================
   iComptoir Services — Feuille de style partagée
   Utilisée par TOUTES les pages du site.
   Ne pas dupliquer dans les <style> inline des .html
   ================================================================ */

/* ── Variables ── */
:root {
  --red:      #D93841;
  --red-dark: #B02E36;
  --red-lite: #f5e0e1;
  --ink:      #111111;
  --ink-mid:  #444444;
  --ink-soft: #888888;
  --bg:       #FFFFFF;
  --bg-off:   #F7F7F5;
  --border:   #E8E8E8;
  --radius:   10px;
}

*, *::before, *::after { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body { font-family: 'Open Sans', sans-serif; color: var(--ink-mid); background: var(--bg); }
h1,h2,h3,h4,h5,h6 { font-family: 'Raleway', sans-serif; letter-spacing: -0.02em; }
a { color: var(--red); text-decoration: none; transition: color .2s; }
a:hover { color: var(--red-dark); }

/* ════════════════════════════════════════
   HEADER
   ════════════════════════════════════════ */
#header {
  height: 72px;
  background: rgba(255,255,255,0.97);
  backdrop-filter: blur(12px);
  box-shadow: 0 1px 0 var(--border);
  transition: box-shadow .3s;
}
#header.header-scrolled { box-shadow: 0 4px 20px rgba(0,0,0,0.08); }
#header .logo img { max-height: 62px; width: auto; display: block; }

/* Lang switcher */
.lang-switcher { display:inline-flex; align-items:center; gap:5px; margin-left:14px; flex-shrink:0; }
.lang-switcher a { font-family:'Raleway',sans-serif; font-size:12px; font-weight:800; letter-spacing:.06em; padding:5px 10px; border-radius:5px; border:1.5px solid transparent; transition:all .2s; line-height:1; }
.lang-switcher a.lang-active { color:var(--red); border-color:var(--red); background:var(--red-lite); }
.lang-switcher a.lang-en { color:var(--ink-soft); border-color:var(--border); }
.lang-switcher a.lang-en:hover { color:var(--ink); border-color:var(--ink-mid); }
.lang-sep { color:var(--border); font-size:13px; }

/* Sister pill */
.sister-pill {
  display:inline-flex; align-items:center; gap:6px;
  font-family:'Raleway',sans-serif; font-size:11.5px; font-weight:800;
  padding:6px 14px; border-radius:100px;
  border:1.5px solid rgba(217,56,65,.3);
  color:var(--red); background:var(--red-lite);
  transition:all .2s; margin-left:12px; white-space:nowrap;
}
.sister-pill:hover { background:var(--red); color:#fff; border-color:var(--red); }

/* ── NAVBAR ── */
#navbar { display:flex; align-items:center; }
#navbar ul {
  display: flex !important;
  flex-direction: row;
  align-items: center;
  list-style: none;
  margin: 0; padding: 0;
}
#navbar ul li { padding: 0; }
#navbar a {
  font-family: 'Raleway', sans-serif;
  font-size: 13.5px; font-weight: 600;
  color: var(--ink-mid); padding: 10px 0 10px 20px;
  letter-spacing: 0.01em; white-space: nowrap;
  display: block; text-decoration: none;
}
#navbar a:hover, #navbar a.active { color: var(--red); }
#navbar .getstarted {
  background: var(--red); color: #fff !important;
  padding: 9px 20px; border-radius: 6px;
  margin-left: 16px; font-size: 13px;
  transition: background .2s, transform .15s;
}
#navbar .getstarted:hover { background: var(--red-dark) !important; transform: translateY(-1px); }
.mobile-nav-toggle { font-size:28px; cursor:pointer; display:none; line-height:0; color:var(--ink); background:none; border:none; padding:0; }

/* Breakpoint intermédiaire 16" */
@media (max-width: 1199px) {
  #navbar a { font-size: 12.5px; padding: 10px 0 10px 12px; }
  #navbar .getstarted { padding: 9px 14px; margin-left: 10px; font-size: 12px; }
  .sister-pill { display: none; }
  .lang-switcher { margin-left: 8px; }
}

/* ════════════════════════════════════════
   HERO (page d'accueil)
   ════════════════════════════════════════ */
#hero {
  height: 78vh; min-height: 520px;
  background: url("../img/hero-services.jpg") center center / cover no-repeat;
  position: relative; overflow: visible;
  margin-bottom: -140px; z-index: 1;
}
#hero::before {
  content: '';
  position: absolute; inset: 0;
  background: linear-gradient(135deg,
    rgba(10,10,10,0.72) 0%,
    rgba(10,10,10,0.45) 50%,
    rgba(217,56,65,0.18) 100%);
}
#hero .hero-container {
  position: absolute; inset: 0;
  display: flex; flex-direction: column;
  justify-content: center; align-items: center;
  text-align: center; padding: 0 20px;
}
#hero .hero-eyebrow {
  display: inline-flex; align-items: center; gap: 8px;
  background: rgba(255,255,255,0.1);
  border: 1px solid rgba(255,255,255,0.25);
  color: #fff; font-size: 11px; font-weight: 700;
  letter-spacing: 0.12em; text-transform: uppercase;
  padding: 7px 16px; border-radius: 100px;
  margin-bottom: 24px;
}
#hero .hero-eyebrow::before { content: '●'; color: var(--red); font-size: 8px; animation: blink 2s infinite; }
@keyframes blink { 0%,100%{opacity:1} 50%{opacity:.3} }
#hero h1 {
  font-size: clamp(2.4rem, 5.5vw, 4.2rem);
  font-weight: 800; color: #fff;
  margin: 0 0 16px; line-height: 1.1;
  text-shadow: 0 2px 20px rgba(0,0,0,.3);
}
#hero h1 span { color: var(--red); }
#hero h2 {
  color: rgba(255,255,255,0.8);
  font-size: clamp(1rem, 2vw, 1.25rem);
  font-family: 'Open Sans', sans-serif;
  font-weight: 300; margin-bottom: 40px;
  max-width: 540px;
}
.hero-actions { display: flex; gap: 14px; flex-wrap: wrap; justify-content: center; }
#hero .btn-get-started {
  font-family: 'Raleway', sans-serif; font-weight: 700;
  font-size: 14px; letter-spacing: .03em;
  padding: 14px 32px; border-radius: 8px;
  border: 2px solid #fff; color: #fff;
  transition: background .2s, color .2s, transform .15s;
}
#hero .btn-get-started:hover { background: #fff; color: var(--ink); transform: translateY(-2px); }
#hero .btn-get-started.filled { background: var(--red); border-color: var(--red); }
#hero .btn-get-started.filled:hover { background: var(--red-dark); border-color: var(--red-dark); color: #fff; }
.hero-tags { display:flex; flex-wrap:wrap; gap:8px; justify-content:center; margin:18px 0; }
.hero-tags span {
  background:rgba(255,255,255,.08); border:1px solid rgba(255,255,255,.15);
  color:rgba(255,255,255,.7); padding:4px 14px; border-radius:100px;
  font-size:12px; font-family:'Raleway',sans-serif; font-weight:700; letter-spacing:.06em;
}

/* ── Hero pages intérieures (pas d'overlap) ── */
#hero-inner {
  min-height: 220px;
  background: linear-gradient(135deg, rgba(10,10,10,0.88) 0%, rgba(217,56,65,0.25) 100%),
              url("../img/hero-services.jpg") center / cover no-repeat;
  display: flex; align-items: center;
  padding: 100px 0 48px;
}
#hero-inner h1 { font-size: clamp(1.8rem, 4vw, 3rem); font-weight: 800; color: #fff; margin: 0 0 10px; }
#hero-inner p  { color: rgba(255,255,255,.75); font-size: 15px; margin: 0; max-width: 560px; }
#hero-inner .hero-eyebrow { margin-bottom: 16px; }

/* ════════════════════════════════════════
   MAIN / SECTIONS
   ════════════════════════════════════════ */
#main { margin-top: 70px; z-index: 3; position: relative; }
section { padding: 80px 0; overflow: hidden; }

.section-title { text-align: center; padding-bottom: 48px; }
.section-title h2 { font-size: 2rem; font-weight: 800; color: var(--ink); margin-bottom: 12px; font-family: 'Raleway', sans-serif; }
.section-title h2::after { content: ''; display: block; width: 44px; height: 3px; background: var(--red); border-radius: 2px; margin: 14px auto 0; }
.section-title p { color: var(--ink-soft); font-size: 15px; max-width: 540px; margin: 0 auto; }

/* ── SERVICES icon-box ── */
#services { background: var(--bg-off); }
.services .icon-box { padding: 32px 24px; background: #fff; border: 1px solid var(--border); border-radius: var(--radius); box-shadow: 0 2px 12px rgba(0,0,0,0.04); transition: transform .25s, box-shadow .25s, border-color .25s; margin: 0 0 28px; position: relative; overflow: hidden; }
.services .icon-box::before { content: ''; position: absolute; top: 0; left: 0; right: 0; height: 3px; background: var(--red); transform: scaleX(0); transform-origin: left; transition: transform .3s; }
.services .icon-box:hover { transform: translateY(-4px); box-shadow: 0 12px 32px rgba(0,0,0,.09); border-color: var(--red-lite); }
.services .icon-box:hover::before { transform: scaleX(1); }
.services .icon { position: static; float: left; margin-right: 18px; margin-top: 2px; }
.services .icon i { font-size: 42px; line-height: 1; }
.services .title { font-family: 'Raleway', sans-serif; font-size: 15px; font-weight: 700; margin: 0 0 8px; color: var(--ink); }
.services .title a { color: var(--ink); }
.services .icon-box:hover .title a { color: var(--red); }
.services .description { font-size: 13.5px; color: var(--ink-soft); line-height: 1.65; margin: 0; }
.svc-pills { display:flex; flex-wrap:wrap; gap:6px; margin-top:10px; }
.svc-pill { font-size:11px; color:var(--ink-soft); background:var(--bg-off); border:1px solid var(--border); padding:3px 9px; border-radius:100px; }
.svc-price-badge { display:inline-block; font-family:'Raleway',sans-serif; font-size:12px; font-weight:800; color:var(--red); background:var(--red-lite); padding:3px 10px; border-radius:100px; margin-top:8px; }

/* ── CTA band ── */
.cta { background: linear-gradient(135deg, var(--red) 0%, var(--red-dark) 100%); padding: 60px 0; }
.cta h3 { color: #fff; font-size: 1.55rem; font-weight: 800; margin-bottom: 8px; }
.cta p { color: rgba(255,255,255,.8); margin-bottom: 0; font-size: 15px; }
.cta .cta-btn { font-family: 'Raleway', sans-serif; font-weight: 700; font-size: 14px; padding: 12px 28px; border-radius: 8px; border: 2px solid #fff; color: #fff; transition: background .2s, color .2s, transform .15s; margin-top: 14px; display: inline-block; letter-spacing: .03em; }
.cta .cta-btn:hover { background: #fff; color: var(--red); transform: translateY(-2px); }

/* ── ABOUT ── */
#about { background: #fff; }
.about .container { box-shadow: 0 4px 40px rgba(0,0,0,0.06); border-radius: 16px; padding: 48px 40px; background: #fff; }
.about .content h3 { font-size: 1.4rem; font-weight: 800; color: var(--ink); margin-bottom: 16px; }
.about .content ul { list-style: none; padding: 0; }
.about .content ul li { padding: 9px 0 9px 28px; position: relative; font-size: 14px; border-bottom: 1px solid var(--border); }
.about .content ul li:last-child { border-bottom: none; }
.about .content ul i { font-size: 18px; color: var(--red); position: absolute; left: 0; top: 10px; }

/* ── TARIFICATION ── */
#tarification { background: var(--bg-off); }
.pricing-cards { display: grid; grid-template-columns: repeat(3,1fr); gap: 24px; }
@media(max-width:900px){ .pricing-cards { grid-template-columns: 1fr; max-width:420px; margin:0 auto; } }
.price-card { background:#fff; border:1px solid var(--border); border-radius:var(--radius); padding:36px 28px; box-shadow:0 2px 12px rgba(0,0,0,.04); transition:transform .25s, box-shadow .25s; position:relative; }
.price-card:hover { transform:translateY(-4px); box-shadow:0 12px 32px rgba(0,0,0,.09); }
.price-card.featured { border:2px solid var(--red); }
.price-card.featured::after { content:'POPULAIRE'; position:absolute; top:-1px; right:24px; font-family:'Raleway',sans-serif; font-size:9px; font-weight:800; letter-spacing:.15em; background:var(--red); color:#fff; padding:4px 12px; border-radius:0 0 8px 8px; }
.price-name { font-family:'Raleway',sans-serif; font-size:11px; font-weight:800; letter-spacing:.12em; text-transform:uppercase; color:var(--ink-soft); margin-bottom:16px; }
.price-amount { display:flex; align-items:baseline; gap:4px; margin-bottom:6px; }
.price-amount .num { font-family:'Raleway',sans-serif; font-size:3rem; font-weight:800; color:var(--ink); line-height:1; }
.price-amount .unit { font-size:15px; color:var(--ink-soft); }
.price-note { font-size:13px; color:var(--red); font-weight:700; font-family:'Raleway',sans-serif; margin-bottom:20px; }
.price-divider { border:none; border-top:1px solid var(--border); margin:20px 0; }
.price-features { list-style:none; padding:0; margin:0 0 28px; display:flex; flex-direction:column; gap:11px; }
.price-features li { display:flex; gap:10px; font-size:13.5px; color:var(--ink-mid); align-items:flex-start; }
.price-features li i { color:var(--red); flex-shrink:0; margin-top:2px; font-size:14px; }
.price-warning { background:var(--red-lite); border:1px solid rgba(217,56,65,.25); border-radius:8px; padding:14px 16px; margin-bottom:22px; }
.price-warning .pw-label { font-family:'Raleway',sans-serif; font-size:10px; font-weight:800; letter-spacing:.1em; text-transform:uppercase; color:var(--red); margin-bottom:6px; }
.price-warning .pw-amount { font-family:'Raleway',sans-serif; font-size:1.8rem; font-weight:800; color:var(--ink); line-height:1; }
.price-warning .pw-amount span { font-size:14px; color:var(--ink-soft); font-weight:600; }
.price-warning .pw-note { font-size:12px; color:var(--ink-mid); margin-top:5px; line-height:1.5; }
.btn-price { display:block; text-align:center; font-family:'Raleway',sans-serif; font-weight:700; font-size:14px; padding:12px; border-radius:8px; text-decoration:none; transition:all .2s; }
.btn-price.outline { border:1.5px solid var(--border); color:var(--ink-mid); }
.btn-price.outline:hover { border-color:var(--red); color:var(--red); background:var(--red-lite); }
.btn-price.filled { background:var(--red); color:#fff !important; border:none; }
.btn-price.filled:hover { background:var(--red-dark); transform:translateY(-1px); }

/* ── TÉMOIGNAGES ── */
#temoignages { background: var(--bg-off); padding: 80px 0; }
.testimonial-card { background:#fff; border:1px solid var(--border); border-radius:var(--radius); padding:32px 28px; position:relative; box-shadow:0 2px 12px rgba(0,0,0,.04); transition:transform .25s,box-shadow .25s; height:100%; }
.testimonial-card:hover { transform:translateY(-4px); box-shadow:0 12px 32px rgba(0,0,0,.09); }
.testimonial-card::before { content:'\201C'; font-family:'Raleway',sans-serif; font-size:5rem; color:var(--red-lite); line-height:1; position:absolute; top:12px; left:20px; pointer-events:none; }
.testimonial-stars { color:#f59e0b; font-size:15px; margin-bottom:12px; }
.testimonial-text { font-size:14px; color:var(--ink-mid); line-height:1.7; margin-bottom:20px; font-style:italic; }
.testimonial-author { display:flex; align-items:center; gap:12px; }
.testimonial-avatar { width:42px; height:42px; border-radius:50%; background:var(--red); color:#fff; display:flex; align-items:center; justify-content:center; font-family:'Raleway',sans-serif; font-weight:800; font-size:15px; flex-shrink:0; }
.testimonial-name { font-family:'Raleway',sans-serif; font-weight:700; font-size:14px; color:var(--ink); }
.testimonial-role { font-size:12px; color:var(--ink-soft); }

/* ── FAQ ── */
#faq { background:#fff; padding:80px 0; }
.faq-item { border:1px solid var(--border); border-radius:var(--radius); margin-bottom:14px; overflow:hidden; transition:border-color .2s; }
.faq-item.open { border-color:var(--red-lite); }
.faq-question { padding:20px 24px; font-family:'Raleway',sans-serif; font-weight:700; font-size:15px; color:var(--ink); cursor:pointer; display:flex; justify-content:space-between; align-items:center; gap:16px; transition:color .2s; user-select:none; }
.faq-question:hover { color:var(--red); }
.faq-question i { flex-shrink:0; font-size:18px; transition:transform .3s; color:var(--red); }
.faq-answer { padding:0 24px; max-height:0; overflow:hidden; transition:max-height .35s ease, padding .3s; }
.faq-answer p { font-size:14px; color:var(--ink-soft); line-height:1.75; padding-bottom:20px; margin:0; }
.faq-item.open .faq-answer { max-height:400px; padding-top:4px; }
.faq-item.open .faq-question i { transform:rotate(180deg); }
.faq-item.open .faq-question { color:var(--red); }

/* ── PARALLAX (scroll — fixed cassé iOS/GPU) ── */
.parallax { background-image: url("../img/server-min.png"); height: 280px; background-attachment: scroll; background-position: center; background-repeat: no-repeat; background-size: cover; position: relative; }
.parallax::before { content:''; position:absolute; inset:0; background:rgba(10,10,10,.5); }

/* ════════════════════════════════════════
   SISTER BAND
   ════════════════════════════════════════ */
.sister-band { background:#f0efed; border-top:1px solid var(--border); border-bottom:1px solid var(--border); }
.sister-band .container { padding-top:0; padding-bottom:0; }
.sister-band .sb-inner { display:flex; align-items:center; flex-wrap:wrap; gap:0; }
.sb-item { display:flex; align-items:center; gap:10px; padding:14px 24px 14px 0; margin-right:24px; border-right:1px solid var(--border); text-decoration:none; transition:opacity .2s; }
.sb-item:hover { opacity:.75; }
.sb-item:last-of-type { border-right:none; }
.sb-dot { width:8px; height:8px; border-radius:50%; flex-shrink:0; }
.sb-dot.red  { background:var(--red); }
.sb-dot.blue { background:#3a7bd5; }
.sb-dot.grn  { background:#4caf50; }
.sb-info small { font-family:'Raleway',sans-serif; font-size:9px; font-weight:800; letter-spacing:.12em; text-transform:uppercase; color:var(--ink-soft); display:block; }
.sb-info strong { font-family:'Raleway',sans-serif; font-size:13px; font-weight:700; color:var(--ink); display:block; }
.sb-info strong .r { color:var(--red); }
.sb-info strong .b { color:#3a7bd5; }
.sb-info strong .g { color:#4caf50; }
.sb-lang { margin-left:auto; display:flex; align-items:center; gap:6px; }
.sb-lang a { font-family:'Raleway',sans-serif; font-size:11px; font-weight:800; letter-spacing:.06em; padding:5px 11px; border-radius:5px; text-decoration:none; transition:all .15s; }
.sb-lang .fr { color:var(--red); background:var(--red-lite); border:1.5px solid rgba(217,56,65,.25); }
.sb-lang .en { color:var(--ink-soft); border:1.5px solid var(--border); }
.sb-lang .en:hover { color:var(--ink); border-color:var(--ink-soft); }

/* ════════════════════════════════════════
   FOOTER
   ════════════════════════════════════════ */
#footer { background: #111; padding: 0 0 28px; color: #999; font-size: 14px; }
#footer .footer-top { padding-top: 72px; padding-bottom: 20px; }
#footer .footer-top .footer-info img { max-height: 52px; margin-bottom: 18px; }
#footer .footer-top .footer-info p { color: #777; line-height: 1.8; font-size: 14px; max-width: 220px; }
#footer .footer-badges { display:flex; gap:10px; flex-wrap:wrap; margin-top:16px; }
#footer .footer-badge { display:inline-flex; align-items:center; gap:6px; font-size:10px; font-weight:700; font-family:'Raleway',sans-serif; text-transform:uppercase; letter-spacing:.08em; background:#1a1a1a; border:1px solid #2a2a2a; color:#666; padding:5px 10px; border-radius:6px; }
#footer .footer-badge i { color:var(--red); font-size:12px; }
#footer .footer-badge.green i { color:#4caf50; }
#footer .footer-top h4 { font-size: 12px; font-weight: 700; color: #fff; text-transform: uppercase; letter-spacing: .1em; padding-bottom: 14px; position: relative; margin-bottom: 16px; }
#footer .footer-top h4::before, #footer .footer-top h4::after { content:''; position:absolute; left:0; bottom:0; height:2px; }
#footer .footer-top h4::before { right:0; background:#2a2a2a; }
#footer .footer-top h4::after { background:var(--red); width:40px; }
#footer .footer-top .footer-links ul { list-style:none; padding:0; margin:0; }
#footer .footer-top .footer-links ul li { padding:0 0 10px; }
#footer .footer-top .footer-links ul a { color:#777; transition:color .2s, padding-left .15s; font-size:14px; display:flex; align-items:center; gap:6px; }
#footer .footer-top .footer-links ul a:hover { color:var(--red); padding-left:4px; }
#footer .footer-top .footer-contact p { color:#777; line-height:1.8; }
#footer .footer-top .footer-contact strong { color:#bbb; }
#footer .footer-top .footer-contact a { color:#999; }
#footer .footer-top .footer-contact a:hover { color:var(--red); }
#footer .footer-top .social-links a { display:inline-flex; align-items:center; justify-content:center; width:34px; height:34px; border-radius:6px; background:#222; color:#888; margin-right:6px; font-size:15px; transition:background .2s, color .2s; }
#footer .footer-top .social-links a:hover { background:var(--red); color:#fff; }
.footer-nl-form { display:flex; flex-direction:column; gap:8px; margin-top:12px; }
.footer-nl-form input[type="email"] { border:1px solid #2a2a2a; background:#1a1a1a; color:#ccc; padding:10px 14px; border-radius:6px; font-size:13px; font-family:'Open Sans',sans-serif; outline:none; transition:border-color .2s; }
.footer-nl-form input[type="email"]:focus { border-color:rgba(217,56,65,.4); }
.footer-nl-form button { background:var(--red); border:none; color:#fff; padding:11px; border-radius:6px; font-family:'Raleway',sans-serif; font-weight:800; font-size:13px; cursor:pointer; transition:background .2s; }
.footer-nl-form button:hover { background:var(--red-dark); }
.footer-logo-img { max-height:68px; width:auto; margin-bottom:8px; }
.footer-tagline { color:#777; line-height:1.8; font-size:14px; margin-top:12px; }
#footer .copyright { text-align:center; padding-top:28px; color:#444; font-size:13px; margin-top:40px; }
#footer .copyright a { color:#666; }
#footer .copyright a:hover { color:var(--red); }
.footer-platforms { display:flex; flex-wrap:wrap; gap:7px; justify-content:center; margin-top:12px; }
.footer-platforms a { font-family:'Raleway',sans-serif; font-size:11.5px; font-weight:700; padding:4px 13px; border-radius:100px; border:1px solid #2a2a2a; color:#555; text-decoration:none; transition:all .2s; }
.footer-platforms a:hover { color:var(--red); border-color:rgba(217,56,65,.3); }
.footer-platforms a.aff { color:var(--red); border-color:rgba(217,56,65,.25); }

/* ── BACK TO TOP ── */
.back-to-top { position:fixed; visibility:hidden; opacity:0; right:20px; bottom:20px; z-index:996; background:var(--red); width:38px; height:38px; border-radius:8px; transition:all .4s; display:flex; align-items:center; justify-content:center; text-decoration:none; }
.back-to-top i { font-size:22px; color:#fff; line-height:0; }
.back-to-top:hover { background:var(--red-dark); }
.back-to-top.active { visibility:visible; opacity:1; }

/* ════════════════════════════════════════
   CHAT WIDGET
   ════════════════════════════════════════ */
#ic-bubble { position:fixed; bottom:24px; right:24px; z-index:9998; width:56px; height:56px; border-radius:50%; background:var(--red); border:none; cursor:pointer; display:flex; align-items:center; justify-content:center; box-shadow:0 4px 20px rgba(217,56,65,.45); transition:transform .2s, box-shadow .2s; outline:none; }
#ic-bubble:hover { transform:scale(1.08); box-shadow:0 6px 28px rgba(217,56,65,.6); }
#ic-bubble svg { transition:transform .3s; }
#ic-bubble.open svg { transform:rotate(45deg); }
#ic-bubble::before { content:''; position:absolute; inset:-6px; border-radius:50%; border:2px solid rgba(217,56,65,.35); animation:icPulse 2.5s ease-out infinite; }
@keyframes icPulse { 0%{opacity:1;transform:scale(1)} 100%{opacity:0;transform:scale(1.5)} }
#ic-notif { position:absolute; top:2px; right:2px; width:14px; height:14px; border-radius:50%; background:#fff; border:2.5px solid var(--red); font-size:8px; font-weight:800; color:var(--red); display:flex; align-items:center; justify-content:center; pointer-events:none; }
#ic-panel { position:fixed; bottom:92px; right:24px; z-index:9999; width:370px; height:510px; background:#1c1414; border-radius:14px; border:1px solid rgba(217,56,65,.22); box-shadow:0 16px 60px rgba(0,0,0,.55); display:flex; flex-direction:column; overflow:hidden; transform-origin:bottom right; transform:scale(.88) translateY(14px); opacity:0; pointer-events:none; transition:transform .28s cubic-bezier(.34,1.56,.64,1), opacity .2s; }
#ic-panel.open { transform:scale(1) translateY(0); opacity:1; pointer-events:all; }
.ic-hdr { display:flex; align-items:center; gap:10px; padding:13px 15px 11px; border-bottom:1px solid rgba(217,56,65,.22); background:#141010; flex-shrink:0; }
.ic-av { width:35px; height:35px; border-radius:50%; background:var(--red); display:flex; align-items:center; justify-content:center; font-family:'Raleway',sans-serif; font-size:12px; font-weight:800; color:#fff; flex-shrink:0; }
.ic-hname { font-family:'Raleway',sans-serif; font-size:13px; font-weight:700; color:#ede8e4; }
.ic-hstatus { font-size:10.5px; color:#5cb85c; display:flex; align-items:center; gap:4px; margin-top:1px; }
.ic-hstatus::before { content:''; width:5px; height:5px; border-radius:50%; background:#5cb85c; }
.ic-xbtn { background:none; border:none; cursor:pointer; color:#8a8080; padding:4px; border-radius:6px; display:flex; align-items:center; justify-content:center; transition:color .15s, background .15s; margin-left:auto; }
.ic-xbtn:hover { color:#ede8e4; background:rgba(255,255,255,.08); }
#ic-msgs { flex:1; overflow-y:auto; padding:14px 12px 6px; display:flex; flex-direction:column; gap:10px; scroll-behavior:smooth; }
#ic-msgs::-webkit-scrollbar { width:3px; }
#ic-msgs::-webkit-scrollbar-thumb { background:rgba(217,56,65,.2); border-radius:2px; }
.icm { display:flex; gap:7px; max-width:93%; animation:icmIn .2s ease; }
@keyframes icmIn { from{opacity:0;transform:translateY(5px)} to{opacity:1;transform:none} }
.icm.user { align-self:flex-end; flex-direction:row-reverse; }
.icm.bot  { align-self:flex-start; }
.icm-av { width:26px; height:26px; border-radius:50%; background:var(--red); flex-shrink:0; display:flex; align-items:center; justify-content:center; font-size:9px; font-weight:800; color:#fff; margin-top:2px; font-family:'Raleway',sans-serif; }
.icm.user .icm-av { background:#2e2020; color:#8a8080; }
.icm-b { padding:9px 12px; border-radius:11px; font-size:13px; line-height:1.55; max-width:calc(100% - 34px); font-family:'Open Sans',sans-serif; }
.icm.bot  .icm-b { background:#141010; border:1px solid rgba(217,56,65,.22); color:#ede8e4; border-bottom-left-radius:3px; }
.icm.user .icm-b { background:var(--red); color:#fff; border-bottom-right-radius:3px; }
.ic-dots { display:flex; gap:4px; align-items:center; padding:3px 2px; }
.ic-dots span { width:6px; height:6px; border-radius:50%; background:var(--red); opacity:.3; animation:icd 1.2s infinite; }
.ic-dots span:nth-child(2){animation-delay:.2s}
.ic-dots span:nth-child(3){animation-delay:.4s}
@keyframes icd { 0%,80%,100%{opacity:.25;transform:scale(.8)} 40%{opacity:1;transform:scale(1.15)} }
#ic-quick { display:flex; flex-wrap:wrap; gap:5px; padding:4px 12px 0; }
.ic-qbtn { font-size:11px; padding:5px 10px; border-radius:20px; border:1px solid rgba(217,56,65,.22); background:transparent; color:#8a8080; cursor:pointer; transition:all .15s; white-space:nowrap; font-family:'Open Sans',sans-serif; }
.ic-qbtn:hover { background:rgba(217,56,65,.12); color:var(--red); border-color:var(--red); }
.ic-inputbar { padding:10px 12px 12px; border-top:1px solid rgba(217,56,65,.22); background:#141010; display:flex; gap:8px; align-items:flex-end; flex-shrink:0; }
#ic-input { flex:1; background:#221616; border:1px solid rgba(217,56,65,.22); border-radius:10px; padding:9px 12px; color:#ede8e4; font-size:13.5px; font-family:'Open Sans',sans-serif; resize:none; min-height:40px; max-height:100px; line-height:1.4; outline:none; transition:border-color .2s; }
#ic-input::placeholder { color:#8a8080; }
#ic-input:focus { border-color:rgba(217,56,65,.5); }
#ic-send { width:38px; height:38px; border-radius:10px; background:var(--red); border:none; cursor:pointer; display:flex; align-items:center; justify-content:center; flex-shrink:0; transition:background .15s, transform .1s; }
#ic-send:hover { background:var(--red-dark); }
#ic-send:active { transform:scale(.95); }
#ic-send:disabled { background:#3a2a2a; cursor:not-allowed; opacity:.45; }
.ic-foot { text-align:center; font-size:10px; color:#8a8080; padding:5px 0 7px; background:#141010; }
.ic-foot a { color:var(--red); text-decoration:none; }
.ic-cursor { animation:icblink .8s step-end infinite; }
@keyframes icblink { 0%,100%{opacity:1} 50%{opacity:0} }

/* ── COOKIE BANNER ── */
#cookie-banner { position:fixed; bottom:0; left:0; right:0; z-index:99999; background:#111; border-top:3px solid var(--red); padding:16px 24px; display:flex; align-items:center; flex-wrap:wrap; gap:14px; box-shadow:0 -6px 32px rgba(0,0,0,.55); font-family:'Open Sans',sans-serif; font-size:13px; transform:translateY(100%); transition:transform .4s cubic-bezier(.4,0,.2,1); }
#cookie-banner.show { transform:translateY(0); }
.cb-text { flex:1; min-width:200px; color:rgba(255,255,255,.75); line-height:1.6; }
.cb-text strong { color:#fff; }
.cb-text a { color:var(--red); text-decoration:underline; }
.cb-btns { display:flex; gap:8px; }
.cb-btn { border-radius:6px; padding:9px 20px; font-family:'Raleway',sans-serif; font-weight:800; font-size:12px; cursor:pointer; border:none; transition:all .2s; }
.cb-accept { background:var(--red); color:#fff; }
.cb-accept:hover { background:var(--red-dark); }
.cb-refuse { background:transparent; color:rgba(255,255,255,.6); border:1.5px solid rgba(255,255,255,.2) !important; }
.cb-refuse:hover { border-color:rgba(255,255,255,.5) !important; color:#fff; }

/* ════════════════════════════════════════
   RESPONSIVE
   ════════════════════════════════════════ */
@media (max-width: 991px) {
  #navbar ul { display: none !important; }
  #navbar ul.navbar-mobile { display:flex !important; flex-direction:column; position:fixed; top:72px; left:0; right:0; background:rgba(255,255,255,.98); backdrop-filter:blur(12px); padding:8px 0 16px; box-shadow:0 8px 32px rgba(0,0,0,.12); z-index:999; }
  #navbar ul.navbar-mobile li { width:100%; }
  #navbar ul.navbar-mobile a { padding:14px 28px; font-size:15px; border-bottom:1px solid var(--border); display:block; }
  #navbar .getstarted { margin:10px 28px 0; display:block; text-align:center; }
  .mobile-nav-toggle { display:block; }
  .lang-switcher { margin-left:8px; }
  .sister-pill { display:none; }
}
@media (max-width: 768px) {
  #hero { height:100vh; margin-bottom:-60px; }
  #hero h1 { font-size:2rem; }
  .about .container { padding:28px 16px; }
  #ic-panel { width:calc(100vw - 20px); right:10px; bottom:80px; }
  #ic-bubble { right:14px; bottom:14px; }
}
@media(max-width:640px) {
  .sister-band .sb-inner { flex-direction:column; align-items:flex-start; }
  .sb-item { border-right:none; margin-right:0; border-bottom:1px solid var(--border); width:100%; }
  .sb-lang { padding:12px 0; width:100%; }
}