/* ═══════════════════════════════════════════════
   GestiPilot — Shared Stylesheet
   ═══════════════════════════════════════════════ */

*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}

:root{
  --white:#ffffff;--bg:#fafbfc;--gray-50:#f7f8fa;--gray-100:#f0f2f5;
  --gray-200:#e2e6ec;--gray-300:#cdd3dc;--gray-400:#9ca5b4;
  --gray-500:#6b7687;--gray-600:#4a5568;--gray-700:#2d3748;
  --gray-800:#1a202c;--gray-900:#0f1117;
  --green:#16a34a;--green-light:#22c55e;--green-bg:#f0fdf4;
  --green-border:#bbf7d0;--green-dark:#15803d;
  --red:#dc2626;--red-bg:#fef2f2;--red-border:#fecaca;
  --amber:#d97706;--amber-bg:#fffbeb;--amber-border:#fde68a;
  --blue:#2563eb;--blue-bg:#eff6ff;--blue-border:#bfdbfe;
  --font:'Inter',-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;
  --r:10px;--rL:14px;
  --shadow:0 1px 3px rgba(0,0,0,.06),0 1px 2px rgba(0,0,0,.04);
  --shadow-md:0 4px 12px rgba(0,0,0,.07);
  --shadow-lg:0 12px 40px rgba(0,0,0,.08);
}

html{scroll-behavior:smooth;font-size:16px}
body{font-family:var(--font);background:var(--white);color:var(--gray-800);
  -webkit-font-smoothing:antialiased;overflow-x:hidden;line-height:1.6}
a{color:inherit;text-decoration:none}
img{display:block;max-width:100%}

/* ── Buttons ── */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;
  font-family:var(--font);font-weight:600;font-size:14px;border-radius:var(--r);
  padding:10px 22px;border:none;cursor:pointer;transition:all .15s;text-decoration:none}
.btn-primary{background:var(--green);color:white}
.btn-primary:hover{background:var(--green-dark);transform:translateY(-1px);box-shadow:0 4px 14px rgba(22,163,74,.25)}
.btn-outline{background:transparent;color:var(--gray-600);border:1.5px solid var(--gray-300)}
.btn-outline:hover{border-color:var(--gray-400);color:var(--gray-800);background:var(--gray-50)}
.btn-danger{background:var(--red);color:white}
.btn-danger:hover{background:#b91c1c}
.btn-lg{padding:13px 28px;font-size:15px;font-weight:700}
.btn-sm{padding:7px 14px;font-size:13px}
.btn-full{width:100%}
.btn:disabled{opacity:.5;cursor:not-allowed;transform:none!important}

/* ── Form inputs ── */
.input{width:100%;background:var(--white);border:1.5px solid var(--gray-300);
  border-radius:var(--r);padding:11px 14px;font-size:14px;color:var(--gray-800);
  font-family:var(--font);outline:none;transition:border-color .2s}
.input:focus{border-color:var(--green);box-shadow:0 0 0 3px rgba(22,163,74,.1)}
.input::placeholder{color:var(--gray-400)}
select.input{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath d='M3 5l3 3 3-3' stroke='%239ca5b4' stroke-width='1.5' fill='none'/%3E%3C/svg%3E");
  background-repeat:no-repeat;background-position:right 12px center;padding-right:32px}
textarea.input{resize:vertical;min-height:80px;line-height:1.5}
.label{display:block;font-size:13px;font-weight:600;color:var(--gray-600);margin-bottom:5px}
.form-group{margin-bottom:16px}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.form-error{color:var(--red);font-size:13px;margin-top:6px}
.form-hint{font-size:12px;color:var(--gray-400);margin-top:4px}

/* ── Cards ── */
.card{background:var(--white);border:1px solid var(--gray-200);border-radius:var(--rL);padding:28px 24px}
.card-hover:hover{box-shadow:var(--shadow-md);border-color:var(--green-border);transform:translateY(-2px);transition:all .2s}

/* ── Alerts / Messages ── */
.alert{padding:12px 16px;border-radius:var(--r);font-size:14px;margin-bottom:16px;display:flex;align-items:center;gap:8px}
.alert-success{background:var(--green-bg);border:1px solid var(--green-border);color:var(--green-dark)}
.alert-error{background:var(--red-bg);border:1px solid var(--red-border);color:var(--red)}
.alert-warning{background:var(--amber-bg);border:1px solid var(--amber-border);color:var(--amber)}
.alert-info{background:var(--blue-bg);border:1px solid var(--blue-border);color:var(--blue)}

/* ── Page layout: nav-top + centered card ── */
.page-nav{padding:16px 24px;border-bottom:1px solid var(--gray-200);background:var(--white);display:flex;align-items:center;justify-content:space-between}
.page-nav .logo{display:flex;align-items:center;gap:10px;font-weight:800;font-size:18px;color:var(--gray-900);letter-spacing:-.3px}
.page-nav .logo img{width:26px;height:26px}
.page-nav .back{font-size:13px;color:var(--gray-400);display:flex;align-items:center;gap:6px;transition:color .15s}
.page-nav .back:hover{color:var(--gray-700)}

.page-center{min-height:calc(100vh - 60px);display:flex;align-items:center;justify-content:center;padding:40px 24px;background:var(--bg)}
.page-card{max-width:460px;width:100%;background:var(--white);border:1px solid var(--gray-200);border-radius:var(--rL);padding:40px 36px;box-shadow:var(--shadow-md)}
.page-card h1{font-size:24px;font-weight:800;letter-spacing:-.5px;margin-bottom:6px;color:var(--gray-900)}
.page-card .subtitle{font-size:14px;color:var(--gray-500);margin-bottom:28px}

/* ── Page layout: content page (legal, CGV, etc.) ── */
.content-page{max-width:780px;margin:0 auto;padding:48px 32px 96px}
.content-page .page-tag{font-size:12px;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;color:var(--green);margin-bottom:10px}
.content-page h1{font-size:32px;font-weight:800;letter-spacing:-.5px;margin-bottom:8px;color:var(--gray-900)}
.content-page .page-subtitle{color:var(--gray-500);font-size:14px;margin-bottom:40px;padding-bottom:20px;border-bottom:1px solid var(--gray-200)}
.content-page h2{font-size:20px;font-weight:700;margin:32px 0 12px;color:var(--gray-800)}
.content-page p,.content-page li{color:var(--gray-600);margin-bottom:10px;font-size:15px;line-height:1.7}
.content-page ul{padding-left:20px}
.content-page .info-card{background:var(--gray-50);border:1px solid var(--gray-200);border-radius:var(--r);padding:18px 22px;margin:14px 0}
.content-page .info-card p{margin:4px 0}
.content-page .info-card strong{color:var(--gray-800)}
.content-page a{color:var(--green);text-decoration:underline;text-underline-offset:2px}
.content-page a:hover{color:var(--green-dark)}

/* ── Footer (simple) ── */
.page-footer{border-top:1px solid var(--gray-200);padding:20px 24px;text-align:center;font-size:12px;color:var(--gray-400)}
.page-footer a{color:var(--gray-400);margin:0 8px;transition:color .15s}
.page-footer a:hover{color:var(--gray-700)}

/* ── Responsive ── */
@media(max-width:600px){
  .page-card{padding:28px 22px}
  .form-row{grid-template-columns:1fr}
  .content-page{padding:32px 20px 64px}
  .content-page h1{font-size:26px}
}
