/* ==========================================================================
   AlloBox.tel — Styles principaux
   Auteur : Appel Telecom
   Description : Feuille de style principale du site AlloBox.tel
   Version : 1.0.0
   Date : 2025-11-10
   ========================================================================== */

/* Variables et couleurs globales */
:root {
  --bg:#0b0f1a;
  --bg2:#101827;
  --card:#111827;
  --ink:#e5e7eb;
  --muted:#9aa4b2;
  --accent:#a78bfa;
  --line:rgba(255,255,255,.08);
}

/* Général */
html,body {
  height:100%;
  margin:0;
  background:
    radial-gradient(circle at 50% 20%, rgba(167,139,250,.15), transparent 70%),
    linear-gradient(180deg,var(--bg),var(--bg2));
  color:var(--ink);
  font:15px/1.55 system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;
}
/* Conteneur principal */
.container {
  width:100%;
  max-width:1120px;
  margin:0 auto;
  padding:20px 24px;
  box-sizing:border-box;
}

section {
  padding:40px 0;
}

a {
  color:var(--ink);
  text-decoration:none;
}
a:hover {
  color:#fff;
  text-decoration:underline;
}

.btn {
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:8px;
  padding:11px 16px;
  border-radius:14px;
  border:1px solid var(--line);
  background:transparent;
  color:var(--ink);
  cursor:pointer;
}
.btn--primary {
  background:var(--accent);
  border-color:var(--accent);
  color:#fff;
}
.btn--ghost {
  background:transparent;
  border-color:var(--line);
}

/* Header */
header.site {
  position:sticky;
  top:0;
  backdrop-filter:saturate(160%) blur(6px);
  background:rgba(16,24,39,.6);
  border-bottom:1px solid var(--line);
  z-index:10;
}
.nav {display:flex;align-items:center;justify-content:space-between;gap:12px;}
.nav-left {display:flex;align-items:center;gap:16px;}
.nav a {opacity:.9;}
.nav a:hover {opacity:1;}
.logo {display:flex;align-items:center;gap:10px;}

/* Hero */
.hero {padding:42px 0 22px;}
.hero-grid {display:grid;gap:18px;grid-template-columns:1.1fr .9fr;align-items:center;}
.hero h1 {font-size:36px;margin:8px 0;}
.hero p {color:var(--muted);margin:0 0 10px;}
.hero .cta {display:flex;justify-content:center;margin-top:14px;gap:10px;flex-wrap:wrap;}
.panel {background:var(--card);border:1px solid var(--line);border-radius:16px;padding:16px;}

/* Features */
.features {display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin:26px 0;}
.feature {background:var(--card);border:1px solid var(--line);border-radius:16px;padding:18px;}
.feature h4 {margin:0 0 6px;}
.muted {color:var(--muted);}

/* Pricing */
.pricing-head {display:flex;align-items:center;justify-content:space-between;gap:12px;margin:28px 0 14px;}
.pricing-grid {display:grid;gap:16px;grid-template-columns:repeat(3,1fr);}
.pricecard {background:var(--card);border:1px solid var(--line);border-radius:18px;box-shadow:0 14px 34px rgba(0,0,0,.28);padding:20px;transition:transform .15s ease, box-shadow .15s ease;}
.pricecard:hover {transform:translateY(-2px);box-shadow:0 18px 42px rgba(0,0,0,.32);}
.pricecard.featured {outline:2px solid var(--accent);}
.pricecard h3 {margin:0 0 8px;}
.price {font-size:28px;margin:10px 0 2px;}
.price small {font-size:12px;color:var(--muted);}
.bullets {margin:14px 0 16px;padding-left:18px;}
.bullets li {margin:6px 0;}
.note {color:var(--muted);text-align:center;font-size:13px;margin-top:8px;}
.agency .slogan {font-size:16px;color:#fff;background:linear-gradient(90deg, rgba(167,139,250,.18), transparent);padding:10px;border-radius:10px;border:1px dashed var(--accent);}

/* Contact */
.contact-card {background:var(--card);border:1px solid var(--line);border-radius:16px;padding:18px;display:grid;gap:14px;}
.contact-grid {display:grid;grid-template-columns:repeat(2,1fr);gap:10px;}
.contact-grid textarea {grid-column:1 / -1;}
.contact-grid .agree {grid-column:1 / -1;display:flex;align-items:center;gap:8px;color:var(--muted);}
.contact-grid input,.contact-grid textarea {width:100%;padding:10px;border-radius:10px;border:1px solid var(--line);background:#0b1224;color:var(--ink);}
.contact-grid .hp {position:absolute;left:-5000px;opacity:0;height:0;width:0;}
#contactForm button[type="submit"] {grid-column:1 / -1;display:block;margin:14px auto 0;width:100%;max-width:280px;text-align:center;}
.notice {border-radius:12px;padding:10px 14px;font-size:14px;}
.notice.ok {background:rgba(80,200,120,.12);border:1px solid rgba(80,200,120,.35);color:#b7f3cc;}
.notice.err {background:rgba(255,0,0,.08);border:1px solid rgba(255,0,0,.35);color:#fecaca;}
@media (max-width:760px){.contact-grid{grid-template-columns:1fr;}}

/* CTA */
.cta-block {background:var(--card);border:1px solid var(--line);border-radius:16px;padding:18px;display:flex;align-items:center;justify-content:space-between;gap:12px;}

/* Footer */
footer {
  border-top: 1px solid var(--line);
  margin-top: 36px;
}
footer .container {
  padding: 18px;
}
footer a {
  color: var(--muted);
  text-decoration: none;
}
footer a:hover {
  color: #fff;
  text-decoration: underline;
}

/* Footer aligné sur une seule ligne avec lien Stripe centré */
.footer-line {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 14px;
  flex-wrap: wrap;
  text-align: center;
}

.footer-left,
.footer-right {
  flex: 1;
  min-width: 240px;
}

.footer-center {
  flex-shrink: 0;
}

/* Style du lien Stripe — version plus fine */
.stripe-portal-link {
  display: inline-block;
  padding: 3px 10px;          /* ↓ réduit la hauteur */
  font-size: 14px;            /* ↓ texte plus sobre */
  color: #fff;
  background: linear-gradient(90deg, rgba(167,139,250,.25), rgba(167,139,250,.15));
  border: 1px solid var(--accent);
  border-radius: 8px;         /* coins légèrement moins arrondis */
  font-weight: 500;
  text-decoration: none;
  transition: all .2s ease;
}

.stripe-portal-link:hover {
  background: var(--accent);
  color: #fff;
  box-shadow: 0 0 8px rgba(167,139,250,.4);
}
/* Responsive */
@media (max-width:980px) {
  .hero-grid { grid-template-columns:1fr; }
  .features { grid-template-columns:1fr; }
  .pricing-grid { grid-template-columns:1fr; }
  .cta-block { flex-direction:column; align-items:flex-start; }
}

@media (max-width:760px) {
  .footer-line {
    flex-direction: column;
    gap: 8px;
  }
}