*{box-sizing:border-box;margin:0;padding:0}
html{overflow-y:scroll}
@keyframes spin{to{transform:rotate(360deg)}}
:root{--sand:#F5F0E8;--stone:#E8E0D0;--ink:#1A1714;--muted:#6B6560;--subtle:#9B9490;--green:#1A6B4A;--green-light:#E8F5EE;--red:#C0392B;--red-light:#FDECEA;--amber:#B8860B;--amber-light:#FFF8E1;--blue:#1A4A7A;--blue-light:#E8F0FA;--white:#FFFFFF;--radius:6px;--radius-lg:12px}
body{font-family:'DM Sans',sans-serif;background:var(--sand);color:var(--ink);min-height:100vh}
.app{max-width:720px;margin:0 auto;padding:1.5rem 1rem 4rem}

/* LANG BAR */
.lang-bar{display:flex;justify-content:flex-end;gap:6px;margin-bottom:1.5rem}
.lang-btn{height:28px;padding:0 10px;border-radius:20px;border:1px solid var(--stone);background:var(--white);font-size:12px;font-weight:500;color:var(--muted);cursor:pointer;font-family:'DM Sans',sans-serif;transition:all .15s}
.lang-btn:hover,.lang-btn.active{background:var(--ink);color:#fff;border-color:var(--ink)}

/* HEADER */
.app-header{text-align:center;margin-bottom:2rem}
.app-title{font-family:'DM Serif Display',serif;font-size:26px;color:var(--ink);letter-spacing:-0.5px}
.app-sub{font-size:13px;color:var(--muted);margin-top:4px}

/* PROGRESS */
.steps-row{display:flex;align-items:center;margin-bottom:10px}
.step-item{flex:1;display:flex;flex-direction:column;align-items:center;gap:4px;position:relative}
.step-item:not(:last-child)::after{content:'';position:absolute;top:14px;left:50%;width:100%;height:1.5px;background:var(--stone);z-index:0}
.step-item.done::after,.step-item.active::after{background:var(--green)}
.step-circle{width:28px;height:28px;border-radius:50%;border:1.5px solid var(--stone);background:var(--white);display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:600;color:var(--muted);z-index:1;position:relative;transition:all .2s}
.step-item.done .step-circle{background:var(--green);border-color:var(--green);color:#fff}
.step-item.active .step-circle{background:var(--ink);border-color:var(--ink);color:#fff}
.step-name{font-size:10px;color:var(--subtle);font-weight:500;text-transform:uppercase;letter-spacing:.05em;text-align:center}
.step-item.active .step-name{color:var(--ink);font-weight:600}
.step-item.done .step-name{color:var(--green)}

/* CARD */
.card{background:var(--white);border-radius:var(--radius-lg);border:1px solid var(--stone);padding:1.75rem;margin-bottom:1rem}
.card-title{font-family:'DM Serif Display',serif;font-size:19px;margin-bottom:1.25rem;display:flex;align-items:center;gap:10px}
.card-title i{font-size:19px;color:var(--green)}
.card-sub{font-size:13px;color:var(--muted);margin-bottom:1.25rem;margin-top:-0.5rem}

/* FIELDS */
.field{margin-bottom:.9rem}
.field label{display:block;font-size:11px;font-weight:600;color:var(--muted);text-transform:uppercase;letter-spacing:.05em;margin-bottom:4px}
.field input,.field select,.field textarea{width:100%;border:1px solid var(--stone);border-radius:var(--radius);background:var(--white);padding:0 12px;font-family:'DM Sans',sans-serif;font-size:14px;color:var(--ink);transition:border-color .15s;height:38px}
.field input:focus,.field select:focus{outline:none;border-color:var(--ink)}
.field .hint{font-size:11px;color:var(--subtle);margin-top:3px}
.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.grid-3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:12px}

/* ALERTS */
.alert{padding:11px 13px;border-radius:var(--radius);font-size:13px;display:flex;gap:9px;align-items:flex-start;margin-bottom:.9rem}
.alert i{font-size:17px;flex-shrink:0;margin-top:1px}
.alert-warn{background:var(--amber-light);border:1px solid #E0C060;color:#7A5C00}
.alert-warn i{color:var(--amber)}
.alert-error{background:var(--red-light);border:1px solid #F0A09A;color:#8B1A10}
.alert-error i{color:var(--red)}
.alert-ok{background:var(--green-light);border:1px solid #A0D0B8;color:#0D4A2E}
.alert-ok i{color:var(--green)}
.alert-info{background:var(--blue-light);border:1px solid #A0B8D8;color:#0D2A4E}
.alert-info i{color:var(--blue)}

/* SECTION DIVIDER */
.section-head{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.07em;color:var(--subtle);margin:1.1rem 0 .6rem;padding-top:1rem;border-top:1px solid var(--stone)}

/* RATE ROWS */
.rate-row{display:flex;align-items:flex-start;gap:10px;padding:9px 0;border-bottom:1px solid var(--stone)}
.rate-row:last-child{border-bottom:none}
.rate-label{flex:1;display:flex;flex-direction:column;gap:3px}
.rate-label strong{font-size:13px;font-weight:600;color:var(--ink)}
.rate-label span{font-size:11px;color:var(--muted)}
.rate-badge{font-size:10px;font-weight:700;color:#146B3A;background:#C8EDD8;padding:2px 8px;border-radius:20px;white-space:nowrap;flex-shrink:0;align-self:flex-start}
.rate-input-wrap{padding-top:1px}
.rate-fixed{padding-top:1px}
.rate-badge-is{font-size:10px;font-weight:600;color:var(--blue);background:var(--blue-light);padding:2px 7px;border-radius:20px;white-space:nowrap;flex-shrink:0}
.rate-badge-lpp{font-size:10px;font-weight:600;color:#5A3A00;background:#FFF0C0;padding:2px 7px;border-radius:20px;white-space:nowrap;flex-shrink:0}
.rate-input-wrap{display:flex;align-items:center;gap:5px}
.rate-input-wrap input{width:70px;text-align:right;height:34px;padding:0 8px;border:1px solid var(--stone);border-radius:var(--radius);font-size:13px;font-family:'DM Sans',sans-serif;color:var(--ink)}
.rate-input-wrap input:focus{outline:none;border-color:var(--ink)}
.rate-pct{font-size:13px;color:var(--muted)}
.rate-fixed{font-size:13px;font-weight:600;color:var(--ink);min-width:70px;text-align:right}

/* CHECKBOX ROW */
.check-row{display:flex;align-items:flex-start;gap:8px;padding:4px 0;cursor:pointer}
.check-row input[type=checkbox]{width:16px;height:16px;accent-color:var(--ink);flex-shrink:0;cursor:pointer;margin-top:2px}
.check-row span{font-size:13px;color:var(--ink)}

/* BUTTONS */
.btn-row{display:flex;gap:10px;margin-top:1.4rem}
.btn{height:40px;padding:0 18px;border-radius:var(--radius);border:1.5px solid var(--stone);background:var(--white);font-family:'DM Sans',sans-serif;font-size:13px;font-weight:500;color:var(--ink);cursor:pointer;display:inline-flex;align-items:center;justify-content:center;gap:6px;transition:all .15s;flex:1}
.btn:hover{background:var(--sand);border-color:var(--ink)}
.btn-primary{background:var(--ink);border-color:var(--ink);color:#fff}
.btn-primary:hover{background:#2D2926}
.btn-stripe{background:#5469D4;border-color:#5469D4;color:#fff;font-size:14px;height:46px}
.btn-stripe:hover{background:#4458C0}
.btn-ghost{background:transparent;border-color:transparent;color:var(--muted)}
.btn-ghost:hover{background:var(--sand);border-color:var(--stone)}

/* PAYSLIP PREVIEW */
.payslip-preview{background:var(--white);border-radius:var(--radius-lg);border:1px solid var(--stone);overflow:hidden;margin-bottom:1.5rem}
.ps-top-bar{height:5px;background:var(--ink)}
.payslip-watermark-wrap{position:relative}
.payslip-watermark{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;pointer-events:none;z-index:2}
.payslip-watermark span{font-family:'DM Serif Display',serif;font-size:68px;color:rgba(0,0,0,0.055);transform:rotate(-30deg);letter-spacing:6px;white-space:nowrap}
.ps-inner{padding:1.75rem}
.ps-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:1.25rem}
.ps-employer-name{font-family:'DM Serif Display',serif;font-size:17px;color:var(--ink)}
.ps-employer-detail{font-size:11px;color:var(--muted);margin-top:2px}
.ps-doc-badge{text-align:right}
.ps-doc-title{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:var(--muted)}
.ps-doc-month{font-family:'DM Serif Display',serif;font-size:18px;color:var(--ink);margin-top:2px}
.ps-doc-year{font-size:11px;color:var(--muted)}
.ps-divider{height:1px;background:var(--stone);margin:.9rem 0}
.ps-parties{display:grid;grid-template-columns:1fr 1fr;gap:.9rem;margin-bottom:1.25rem}
.ps-party-label{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--subtle);margin-bottom:4px}
.ps-party-name{font-size:13px;font-weight:600;color:var(--ink)}
.ps-party-detail{font-size:11px;color:var(--muted);margin-top:2px}
.ps-table{width:100%;border-collapse:collapse;font-size:12.5px;margin-bottom:.9rem}
.ps-table-head th{text-align:left;font-size:9px;font-weight:700;text-transform:uppercase;letter-spacing:.07em;color:var(--subtle);padding:0 0 7px;border-bottom:1.5px solid var(--ink)}
.ps-table-head th:last-child{text-align:right}
.ps-table td{padding:6px 0;border-bottom:1px solid var(--stone)}
.ps-table tr:last-child td{border-bottom:none}
.ps-table .td-label{color:var(--ink)}
.ps-table .td-note{font-size:10px;color:var(--muted);padding-left:10px}
.ps-table .td-amount{text-align:right;font-variant-numeric:tabular-nums;color:var(--ink);font-weight:500}
.ps-table .td-deduct{text-align:right;font-variant-numeric:tabular-nums;color:var(--red);font-weight:500}
.ps-table .td-deduct-is{text-align:right;font-variant-numeric:tabular-nums;color:var(--blue);font-weight:500}
.ps-table .td-deduct-lpp{text-align:right;font-variant-numeric:tabular-nums;color:#7A5C00;font-weight:500}
.ps-table .td-base{text-align:right;font-variant-numeric:tabular-nums;color:var(--muted);font-size:11px;padding-right:6px}
.rate-input-wrap input:disabled{background:var(--stone-light,#f5f5f5);color:var(--muted);cursor:not-allowed;opacity:.7}
.ps-table .row-section-head td{padding-top:12px;padding-bottom:3px;font-size:9px;font-weight:700;text-transform:uppercase;letter-spacing:.07em;color:var(--subtle)}
.ps-table .row-section-head td:last-child{text-align:right}
.ps-total-box{background:var(--ink);border-radius:var(--radius);padding:13px 15px;display:flex;justify-content:space-between;align-items:center;margin-top:.9rem}
.ps-total-label{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:rgba(255,255,255,.7)}
.ps-total-amount{font-family:'DM Serif Display',serif;font-size:24px;color:#fff}
.ps-total-chf{font-size:12px;color:rgba(255,255,255,.7);margin-right:4px}
.ps-footer{border-top:1px solid var(--stone);padding-top:.9rem;margin-top:.9rem;display:flex;justify-content:space-between;align-items:center}
.ps-footer-note{font-size:9px;color:var(--subtle)}
.ps-footer-seal{display:flex;align-items:center;gap:5px;font-size:9px;color:var(--subtle)}
.ps-footer-seal i{font-size:13px;color:var(--green)}
.paywall{background:var(--sand);border:1.5px dashed var(--stone);border-radius:var(--radius-lg);padding:1.4rem;text-align:center}
.paywall-price{font-family:'DM Serif Display',serif;font-size:30px;color:var(--ink);margin:5px 0 2px}
.paywall-note{font-size:12px;color:var(--muted);margin-bottom:.9rem}
.paywall-features{display:flex;justify-content:center;gap:14px;margin-bottom:1.1rem;flex-wrap:wrap}
.paywall-feature{font-size:12px;color:var(--muted);display:flex;align-items:center;gap:4px}
.paywall-feature i{color:var(--green);font-size:13px}

/* EMPLOYER BANNER */
.employer-banner{display:flex;align-items:center;justify-content:space-between;gap:10px;background:var(--ink);color:#fff;border-radius:var(--radius);padding:10px 14px;margin-bottom:1rem;font-size:13px}
.employer-banner-name{font-weight:600;flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.employer-banner-btn{height:28px;padding:0 12px;border-radius:20px;border:1px solid rgba(255,255,255,.3);background:transparent;color:#fff;font-size:12px;font-weight:500;cursor:pointer;font-family:'DM Sans',sans-serif;white-space:nowrap;transition:all .15s}
.employer-banner-btn:hover{background:rgba(255,255,255,.15)}

/* MODAL */
.modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,.45);z-index:100;display:flex;align-items:center;justify-content:center;padding:1rem}
.modal-box{background:var(--white);border-radius:var(--radius-lg);padding:1.75rem;width:100%;max-width:440px;box-shadow:0 20px 60px rgba(0,0,0,.2)}
.modal-title{font-family:'DM Serif Display',serif;font-size:18px;margin-bottom:1.25rem}
.modal-actions{display:flex;gap:10px;margin-top:1.25rem}

/* BLUR PAYWALL */
.blur-numbers{filter:none}

/* ── CGV MODAL ── */
.cgv-overlay{position:fixed;inset:0;background:rgba(0,0,0,.6);z-index:500;display:flex;align-items:center;justify-content:center;padding:1rem;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px)}
.cgv-box{background:var(--white);border-radius:var(--radius-lg);width:100%;max-width:520px;max-height:90vh;display:flex;flex-direction:column;box-shadow:0 24px 80px rgba(0,0,0,.3);overflow:hidden}
.cgv-header{padding:1.4rem 1.5rem 1rem;border-bottom:1px solid var(--stone);flex-shrink:0}
.cgv-header-title{font-family:'DM Serif Display',serif;font-size:19px;color:var(--ink);display:flex;align-items:center;gap:10px}
.cgv-header-sub{font-size:12px;color:var(--muted);margin-top:4px}
.cgv-body{flex:1;overflow-y:auto;padding:1.25rem 1.5rem;font-size:13px;color:var(--muted);line-height:1.7}
.cgv-body h3{font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--ink);margin:1rem 0 .4rem}
.cgv-body h3:first-child{margin-top:0}
.cgv-body p{margin-bottom:.6rem}
.cgv-body ol{padding-left:1.2rem;margin-bottom:.6rem}
.cgv-body ol li{margin-bottom:.3rem}
.cgv-footer{padding:1rem 1.5rem 1.25rem;border-top:1px solid var(--stone);flex-shrink:0}
.cgv-check-row{display:flex;align-items:flex-start;gap:10px;margin-bottom:1rem;padding:10px 12px;border-radius:var(--radius);border:1.5px solid var(--stone);background:var(--sand);cursor:pointer;transition:border-color .15s}
.cgv-check-row.checked{border-color:var(--green);background:var(--green-light)}
.cgv-check-row input[type=checkbox]{width:17px;height:17px;accent-color:var(--green);flex-shrink:0;cursor:pointer;margin-top:2px}
.cgv-check-row span{font-size:13px;color:var(--ink);font-weight:500}
.cgv-btn{width:100%;height:44px;border-radius:var(--radius);border:none;font-family:'DM Sans',sans-serif;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center;gap:8px}
.cgv-btn:disabled{background:var(--stone);color:var(--subtle);cursor:not-allowed}
.cgv-btn:not(:disabled){background:var(--green);color:#fff}
.cgv-btn:not(:disabled):hover{background:#145a3d}
.cgv-scroll-hint{font-size:11px;color:var(--subtle);text-align:center;margin-bottom:.6rem;display:flex;align-items:center;justify-content:center;gap:5px}

/* ── SIDEBAR LAYOUT ── */
:root{--sb-w:260px}

/* Layout de base : le contenu prend toute la largeur */
.layout{display:block;min-height:100vh;background:var(--sand)}
.main-content{width:100%;min-height:100vh;padding-bottom:2rem;padding-top:52px}
.app{max-width:720px;margin:0 auto;padding:1.5rem 1rem 4rem}

/* Sidebar — hors écran par défaut sur mobile */
.sidebar{
  position:fixed;top:0;left:0;
  height:100%;height:100dvh;width:var(--sb-w);
  background:var(--ink);
  display:flex;flex-direction:column;
  z-index:200;
  transform:translateX(-100%);
  transition:transform .28s cubic-bezier(.4,0,.2,1);
  box-shadow:none;
  overflow:hidden;
}
.sidebar.open{
  transform:translateX(0);
  box-shadow:4px 0 24px rgba(0,0,0,.25);
}

/* Overlay semi-transparent (comme Claude.ai) */
.sidebar-overlay{
  display:none;
  position:fixed;inset:0;
  background:rgba(0,0,0,.45);
  z-index:199;
  opacity:0;
  transition:opacity .28s;
}
.sidebar-overlay.visible{
  display:block;
  opacity:1;
}

/* Bouton hamburger fixe en haut à gauche */
/* Topbar fixe — fond sable semi-opaque avec blur, comme une vraie app */
.topbar{
  position:fixed;top:0;left:0;right:0;
  height:52px;
  background:rgba(245,240,232,.88);
  backdrop-filter:blur(10px);
  -webkit-backdrop-filter:blur(10px);
  border-bottom:1px solid rgba(232,224,208,.6);
  display:flex;align-items:center;
  padding:0 1rem;
  z-index:197;
}
/* Bouton hamburger — intégré dans la topbar, design discret */
.sidebar-fab{
  width:36px;height:36px;
  background:var(--sand);
  border:1.5px solid var(--stone);
  border-radius:10px;
  color:var(--ink);
  font-size:18px;
  display:flex;align-items:center;justify-content:center;
  cursor:pointer;
  box-shadow:0 1px 3px rgba(0,0,0,.1),0 0 0 1px rgba(0,0,0,.04);
  transition:background .15s,box-shadow .15s;
  flex-shrink:0;
}
.sidebar-fab:hover{background:var(--stone);box-shadow:0 2px 6px rgba(0,0,0,.14)}
.sidebar-fab:active{background:var(--stone);box-shadow:none}
/* Titre dans la topbar */
.topbar-title{
  font-family:'DM Serif Display',serif;
  font-size:16px;color:var(--ink);
  margin-left:10px;
  flex:1;
}
/* Décale le contenu sous la topbar */
.app{padding-top:1.5rem}
.lang-bar{justify-content:flex-end}

/* Header dans la sidebar */
.sidebar-header{
  display:flex;align-items:center;justify-content:space-between;
  padding:14px 16px;
  border-bottom:1px solid rgba(255,255,255,.1);
  flex-shrink:0;
}
.sidebar-logo-title{font-family:'DM Serif Display',serif;font-size:17px;color:#fff}
.sidebar-logo-sub{font-size:10px;color:rgba(255,255,255,.35);margin-top:2px}
.sidebar-close{
  background:none;border:none;
  color:rgba(255,255,255,.5);font-size:22px;
  cursor:pointer;padding:4px;
  display:flex;align-items:center;
  transition:color .15s;
  flex-shrink:0;
}
.sidebar-close:hover{color:#fff}

/* Nav */
.sidebar-nav{padding:.5rem 0;flex:1;overflow-y:auto;min-height:0}
.sidebar-section{
  font-size:9px;font-weight:700;text-transform:uppercase;letter-spacing:.1em;
  color:rgba(255,255,255,.22);
  padding:10px 16px 3px;
}
.sidebar-item{
  display:flex;align-items:center;gap:12px;
  padding:10px 16px;
  cursor:pointer;
  color:rgba(255,255,255,.6);
  font-size:13px;font-weight:500;
  border-left:3px solid transparent;
  transition:background .15s,color .15s;
}
.sidebar-item:hover{background:rgba(255,255,255,.07);color:#fff}
.sidebar-item.active{background:rgba(255,255,255,.1);color:#fff;border-left-color:rgba(255,255,255,.8)}
.sidebar-item i{font-size:19px;flex-shrink:0}
.badge-soon{
  font-size:9px;font-weight:700;
  background:rgba(255,255,255,.12);color:rgba(255,255,255,.45);
  padding:1px 6px;border-radius:10px;
  margin-left:auto;
}

/* Placeholder modules vides */
.module-placeholder{
  display:flex;flex-direction:column;align-items:center;
  justify-content:center;min-height:70vh;
  color:var(--muted);text-align:center;padding:2rem;
}
.module-placeholder i{font-size:52px;margin-bottom:1rem;opacity:.2}
.module-placeholder h2{font-family:'DM Serif Display',serif;font-size:22px;color:var(--ink);margin-bottom:.5rem}
.module-placeholder p{font-size:13px;max-width:300px;line-height:1.6}

@media print{
  /* Format A4 et marges propres */
  @page{size:A4 portrait;margin:1.5cm 1.2cm}
  /* Cacher l'interface complète */
  .topbar,.sidebar,.sidebar-overlay,.sidebar-fab,
  #stepsRow,.employer-banner,#empBanner,
  .btn-row,.btn-stripe,.paywall,
  #module-placeholder>*:not(.ps-wrap){display:none!important}
  /* Affichage net */
  body{background:#fff!important;margin:0!important;padding:0!important;font-size:11pt}
  .layout{display:block!important}
  .main-content{padding:0!important;margin:0!important}
  .app{display:block!important;padding:0!important}
  #stepContent{padding:0!important}
  /* Supprimer ombres et arrondis */
  .card,.ps-wrap{box-shadow:none!important;border-radius:0!important}
  /* Éviter coupures au mauvais endroit */
  .card,table,tr,thead,tbody,.ps-total-box{page-break-inside:avoid!important}
  thead{display:table-header-group}
  /* Forcer la fiche sur une seule page */
  .ps-wrap{page-break-inside:avoid!important;break-inside:avoid!important}
  @page{size:A4;margin:10mm 12mm}
  body{font-size:11px!important}
  .ps-total-box{margin-top:4px!important}
  .ps-table td,.ps-table th{padding:2px 4px!important;font-size:10px!important}
  /* Conserver couleurs */
  *{-webkit-print-color-adjust:exact!important;print-color-adjust:exact!important}
  /* Masquer URL et en-têtes navigateur */
  html{overflow:visible}
}

/* ── Auth screen (landing page connexion) ─────────────────────────────────── */
#auth-screen .lp-section{max-width:680px;margin:0 auto;padding:0 1.25rem}
#auth-screen .lp-feat{display:flex;align-items:flex-start;gap:14px;margin-bottom:1.25rem}
#auth-screen .lp-feat-icon{width:40px;height:40px;border-radius:10px;background:#1A1714;display:flex;align-items:center;justify-content:center;flex-shrink:0}
#auth-screen .lp-pill{display:inline-flex;align-items:center;gap:6px;background:#E8F5EE;color:#1A6B4A;border-radius:20px;padding:4px 12px;font-size:12px;font-weight:600;margin-bottom:1rem}
@media(min-width:560px){#auth-screen .lp-grid{display:grid;grid-template-columns:1fr 1fr;gap:0}}

/* ── Landing page — nouvelles sections (v104) ─────────────────────────────── */

/* Scroll fluide sur la landing */
#auth-screen { scroll-behavior: smooth; }

/* Apparition douce au chargement */
#auth-screen { animation: lp-fade-in .25s ease; }
@keyframes lp-fade-in { from { opacity:0 } to { opacity:1 } }

/* Trust bar — retour à la ligne propre sur mobile */
#auth-screen .lp-trust-bar {
  display:flex;flex-wrap:wrap;justify-content:center;
  gap:.4rem 1.25rem;
  font-size:11px;color:#6B6560;font-weight:500;
}

/* PDF mockup — responsive sur petits écrans */
#auth-screen .lp-pdf-mockup {
  background:#fff;border-radius:12px;border:1px solid #E8E0D0;
  max-width:400px;margin:0 auto;overflow:hidden;
  box-shadow:0 8px 32px rgba(0,0,0,.1);
}
@media(max-width:400px){
  #auth-screen .lp-pdf-mockup table { font-size:10px }
  #auth-screen .lp-pdf-mockup { margin:0 .25rem }
}

/* Pricing card */
#auth-screen .lp-pricing-card {
  border:2px solid #1A1714;border-radius:16px;
  padding:2rem 1.75rem;position:relative;
  max-width:440px;margin:0 auto;
}
#auth-screen .lp-pricing-badge {
  position:absolute;top:-13px;left:50%;transform:translateX(-50%);
  background:#1A1714;color:#fff;
  font-size:11px;font-weight:700;padding:3px 14px;
  border-radius:20px;white-space:nowrap;
}
#auth-screen .lp-pricing-btn {
  width:100%;height:48px;
  background:#1A1714;color:#fff;
  border:none;border-radius:10px;
  font-family:'DM Sans',sans-serif;font-size:15px;font-weight:600;
  cursor:pointer;transition:background .15s;
}
#auth-screen .lp-pricing-btn:hover { background:#2D2926 }

/* FAQ items */
#auth-screen .lp-faq-item {
  border:1px solid #E8E0D0;border-radius:10px;
  padding:1rem 1.25rem;margin-bottom:.75rem;background:#fff;
}
#auth-screen .lp-faq-q {
  font-size:13px;font-weight:700;color:#1A1714;margin-bottom:.4rem;
}
#auth-screen .lp-faq-a {
  font-size:12px;color:#6B6560;line-height:1.6;
}

/* Footer liens */
#auth-screen .lp-footer-link {
  background:none;border:none;cursor:pointer;
  font-size:11px;color:#6B6560;
  font-family:'DM Sans',sans-serif;text-decoration:underline;
}
#auth-screen .lp-footer-link:hover { color:#1A1714 }

/* Responsive général landing — centrage sur grands écrans */
@media(min-width:720px){
  #auth-screen .lp-faq-wrap { max-width:600px;margin:0 auto;padding:3rem 0 }
  #auth-screen .lp-pricing-wrap { max-width:480px;margin:0 auto }
}
