/*
Theme Name: Quatorze
Theme URI: https://example.com/quatorze
Author: Alexandre
Author URI: https://example.com
Description: Thème WordPress de la marque QUATORZE — vestiaire français sport/casual, palette bleu-blanc-rouge sourde. Page vitrine avec hero éditorial et collection de pièces gérables depuis le personnalisateur. Boutons d'achat redirigeables (Shopify ou autre).
Version: 1.0.0
Requires at least: 6.0
Tested up to: 6.5
Requires PHP: 7.4
License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Text Domain: quatorze
*/

  :root{
    --nuit:#10182e;
    --nuit2:#1b2542;
    --blanc:#f4f1ea;
    --blanccasse:#e7e2d6;
    --rouge:#c8102e;
    --gris:#8a8f9c;
    --encre:#39415a;
    --fil:linear-gradient(90deg,var(--nuit2) 0 33%,var(--blanc) 33% 66%,var(--rouge) 66% 100%);
  }
  *{margin:0;padding:0;box-sizing:border-box;}
  html{scroll-behavior:smooth;}
  body{
    background:var(--blanc);          /* fond clair dominant — moins de bleu */
    color:var(--nuit);
    font-family:'Archivo',sans-serif;
    -webkit-font-smoothing:antialiased;
    line-height:1.6;
    overflow-x:hidden;
  }
  a{color:inherit;text-decoration:none;}
  .wrap{max-width:1320px;margin:0 auto;padding:0 44px;}

  @keyframes rise{from{opacity:0;transform:translateY(24px);}to{opacity:1;transform:translateY(0);}}
  .rise{opacity:0;animation:rise .9s cubic-bezier(.2,.7,.2,1) forwards;}
  .d1{animation-delay:.05s;} .d2{animation-delay:.18s;} .d3{animation-delay:.31s;}
  .d4{animation-delay:.44s;} .d5{animation-delay:.57s;}

  /* ============ FIL TRICOLORE TOUT EN HAUT ============ */
  .toptricolore{height:4px;width:100%;background:var(--fil);}

  /* ============ NAV (sombre, posée sur le hero bleu) ============ */
  header.site{
    position:sticky;top:0;z-index:60;
    background:var(--nuit);
    border-bottom:1px solid rgba(244,241,234,.08);
  }
  .nav{display:flex;align-items:center;justify-content:space-between;height:64px;}
  .nav-left,.nav-right{flex:1;display:flex;gap:28px;align-items:center;}
  .nav-right{justify-content:flex-end;}
  .nav-left a,.nav-right a{font-size:11.5px;letter-spacing:.16em;text-transform:uppercase;font-weight:600;color:var(--blanccasse);position:relative;padding:4px 0;transition:color .2s;}
  .nav-left a::after,.nav-right a::after{content:"";position:absolute;left:0;bottom:-2px;width:0;height:1.5px;background:var(--rouge);transition:width .25s;}
  .nav-left a:hover,.nav-right a:hover{color:var(--blanc);}
  .nav-left a:hover::after,.nav-right a:hover::after{width:100%;}
  .brand{font-family:'Archivo Black',sans-serif;font-size:20px;letter-spacing:.1em;text-align:center;flex-shrink:0;color:var(--blanc);}
  .burger{display:none;background:none;border:none;cursor:pointer;flex-direction:column;gap:5px;padding:6px;}
  .burger span{width:24px;height:2px;background:var(--blanc);display:block;}

  /* ============ HERO (bleu nuit, compact) ============ */
  .hero{
    position:relative;overflow:hidden;
    min-height:auto;
    padding:84px 0 90px;background:var(--nuit);color:var(--blanc);
  }
  .hero::before{
    content:"";position:absolute;inset:0;z-index:0;
    background:
      radial-gradient(820px 560px at 80% 26%, rgba(27,37,66,.85), transparent 60%),
      radial-gradient(440px 360px at 92% 90%, rgba(200,16,46,.12), transparent 60%);
  }
  /* le 14 géant à droite — rempli discret sur fond bleu */
  .hero .ghost{
    position:absolute;top:50%;right:-5%;transform:translateY(-50%);
    font-family:'Archivo Black',sans-serif;font-size:clamp(260px,38vw,520px);
    line-height:.78;letter-spacing:-.02em;pointer-events:none;user-select:none;z-index:1;
    color:rgba(244,241,234,.045);
  }
  .hero .ghost .r{color:rgba(200,16,46,.09);}
  .hero-inner{position:relative;z-index:3;text-align:left;display:flex;align-items:center;gap:48px;flex-wrap:wrap;}
  .hero-text{flex:0 1 640px;}
  .hero-cta{display:flex;flex-direction:column;gap:13px;align-items:stretch;flex:0 0 auto;margin-left:auto;}
  .hero .eyebrow{
    display:inline-flex;align-items:center;gap:11px;
    font-size:10.5px;letter-spacing:.3em;text-transform:uppercase;color:var(--gris);
    font-weight:600;margin-bottom:20px;
  }
  .hero .eyebrow::before{content:"";width:30px;height:1.5px;background:var(--rouge);}
  .hero h1{
    font-family:'Archivo Black',sans-serif;color:var(--blanc);
    font-size:clamp(36px,5vw,62px);line-height:.98;letter-spacing:.005em;margin-bottom:20px;
  }
  .hero h1 .it{font-family:'Spectral',serif;font-weight:400;font-style:italic;display:block;font-size:.56em;color:var(--blanccasse);margin-top:8px;letter-spacing:0;}
  .hero .lede{font-family:'Spectral',serif;font-size:17px;color:var(--blanccasse);max-width:430px;margin-bottom:0;}
  .btn{
    font-family:inherit;font-weight:800;font-size:11.5px;letter-spacing:.14em;text-transform:uppercase;
    padding:14px 28px;border-radius:8px;cursor:pointer;border:1px solid transparent;
    transition:transform .16s,background .25s,border-color .25s,color .25s;display:inline-block;
  }
  .btn-primary{background:var(--blanc);color:var(--nuit);}
  .btn-primary:hover{transform:translateY(-2px);}
  .btn-ghost{background:transparent;border-color:rgba(244,241,234,.24);color:var(--blanc);}
  .btn-ghost:hover{border-color:var(--blanc);}
  .hero-foot{position:absolute;left:0;right:0;bottom:22px;z-index:3;}
  .hero-foot-in{display:flex;gap:28px;flex-wrap:wrap;font-size:10px;letter-spacing:.2em;text-transform:uppercase;color:var(--gris);}
  .hero-foot span{display:flex;align-items:center;gap:8px;background:transparent;color:var(--gris);}
  .hero-foot span::before{content:"";width:5px;height:5px;background:var(--rouge);border-radius:50%;}

  /* ============ TRUST BAR (statique, raffiné) ============ */
  .trust{background:var(--blanc);border-bottom:1px solid rgba(16,24,46,.08);}
  .trust-in{display:flex;align-items:stretch;}
  .trust .t{flex:1;padding:26px 28px;display:flex;flex-direction:column;gap:5px;border-left:1px solid rgba(16,24,46,.08);}
  .trust .t:first-child{border-left:none;}
  .trust .t .k{font-family:'Archivo Black',sans-serif;font-size:13px;letter-spacing:.05em;color:var(--nuit);}
  .trust .t .v{font-size:12px;letter-spacing:.04em;color:var(--gris);}
  .trust .t .k .accent{color:var(--rouge);}

  /* ============ COLLECTION ============ */
  .collection{padding:104px 0 40px;}
  .sec-head{display:flex;align-items:flex-end;justify-content:space-between;flex-wrap:wrap;gap:16px;margin-bottom:8px;}
  .sec-head .label{font-size:12px;letter-spacing:.3em;text-transform:uppercase;color:var(--rouge);font-weight:800;margin-bottom:12px;}
  .sec-head h2{font-family:'Archivo Black',sans-serif;font-size:clamp(30px,4vw,46px);line-height:1;color:var(--nuit);}
  .sec-head .sub{font-family:'Spectral',serif;font-style:italic;color:var(--gris);font-size:16px;}

  /* fiche produit (side card) — format conservé, qualité relevée */
  .piece{padding:72px 0;border-top:1px solid rgba(16,24,46,.1);}
  .piece-grid{display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:center;}
  .piece.rev .piece-grid{direction:rtl;}
  .piece.rev .piece-grid > *{direction:ltr;}
  .piece-visual{
    aspect-ratio:4/5;border-radius:16px;position:relative;overflow:hidden;
    display:flex;align-items:center;justify-content:center;
    box-shadow:0 30px 60px -28px rgba(16,24,46,.45);
    transition:transform .4s cubic-bezier(.2,.7,.2,1),box-shadow .4s;
  }
  .piece:hover .piece-visual{transform:translateY(-6px);box-shadow:0 40px 70px -26px rgba(16,24,46,.5);}
  .piece-visual.v1{background:radial-gradient(120% 120% at 25% 15%,#243056,#1b2542 45%,#0c1426);}
  .piece-visual.v2{background:radial-gradient(120% 120% at 25% 15%,#f1ece1,#e7e2d6 45%,#d0c8b6);}
  .piece-visual.v3{background:radial-gradient(130% 130% at 75% 85%,#c8102e,#7d0c1f 55%,#10182e);}
  /* texture diagonale très discrète */
  .piece-visual::before{content:"";position:absolute;inset:0;opacity:.5;
    background:repeating-linear-gradient(135deg,rgba(244,241,234,.03) 0 2px,transparent 2px 22px);}
  .piece-visual.v2::before{background:repeating-linear-gradient(135deg,rgba(16,24,46,.03) 0 2px,transparent 2px 22px);}
  .piece-visual::after{content:"";position:absolute;bottom:0;left:0;right:0;height:6px;background:var(--fil);}
  .piece-visual .mark{position:relative;font-family:'Archivo Black',sans-serif;font-size:230px;line-height:1;color:rgba(244,241,234,.08);z-index:1;}
  .piece-visual.v2 .mark{color:rgba(16,24,46,.11);}
  .piece-visual .mark .r{color:rgba(200,16,46,.18);}
  .piece-visual.v3 .mark{color:rgba(244,241,234,.13);}
  .piece-visual.v3 .mark .r{color:rgba(244,241,234,.2);}
  .piece-visual .badge{position:absolute;top:22px;left:22px;z-index:2;font-size:10px;letter-spacing:.2em;text-transform:uppercase;color:var(--blanccasse);border:1px solid rgba(244,241,234,.3);padding:6px 14px;border-radius:30px;backdrop-filter:blur(4px);}
  .piece-visual.v2 .badge{color:var(--nuit);border-color:rgba(16,24,46,.22);}
  .piece-visual .ptype{position:absolute;bottom:24px;left:22px;z-index:2;font-family:'Spectral',serif;font-style:italic;font-size:15px;color:rgba(244,241,234,.55);}
  .piece-visual.v2 .ptype{color:rgba(16,24,46,.5);}
  .piece-txt .tag{font-size:11px;letter-spacing:.28em;text-transform:uppercase;color:var(--rouge);font-weight:700;margin-bottom:18px;}
  .piece-txt h3{font-family:'Archivo Black',sans-serif;font-size:clamp(30px,3.4vw,46px);line-height:1.02;margin-bottom:20px;color:var(--nuit);letter-spacing:.005em;}
  .piece-txt p{font-family:'Spectral',serif;font-size:17px;color:var(--encre);margin-bottom:14px;max-width:460px;line-height:1.65;}
  .piece-txt .price{font-size:24px;font-weight:800;margin:26px 0 8px;color:var(--nuit);}
  .piece-txt .price .units{font-size:13px;color:var(--gris);font-weight:500;letter-spacing:.06em;margin-left:8px;}
  .specs{display:flex;gap:0;margin:26px 0 34px;border:1px solid rgba(16,24,46,.12);border-radius:11px;overflow:hidden;max-width:460px;}
  .specs .s{flex:1;padding:16px 20px;border-left:1px solid rgba(16,24,46,.1);}
  .specs .s:first-child{border-left:none;}
  .specs .s .k{font-size:10px;letter-spacing:.2em;text-transform:uppercase;color:var(--gris);margin-bottom:6px;}
  .specs .s .v{font-size:14px;font-weight:700;color:var(--nuit);}

  /* ============ DÉTAILS ============ */
  .details{padding:104px 0;border-top:1px solid rgba(16,24,46,.1);text-align:center;}
  .details .label{font-size:12px;letter-spacing:.3em;text-transform:uppercase;color:var(--rouge);font-weight:800;margin-bottom:16px;}
  .details h2{font-family:'Spectral',serif;font-style:italic;font-weight:400;font-size:clamp(26px,3.6vw,38px);max-width:680px;margin:0 auto 60px;line-height:1.25;color:var(--nuit);}
  .det-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:28px;text-align:left;}
  .det{border:1px solid rgba(16,24,46,.12);border-radius:13px;padding:34px 30px;background:#fff;}
  .det .no{font-family:'Archivo Black',sans-serif;font-size:13px;color:var(--rouge);letter-spacing:.1em;margin-bottom:18px;}
  .det h4{font-size:16px;font-weight:800;margin-bottom:10px;letter-spacing:.02em;color:var(--nuit);}
  .det p{font-size:14px;color:var(--encre);font-family:'Spectral',serif;}

  /* ============ MANIFESTO (le seul autre bloc bleu — pour respirer) ============ */
  .manifesto{padding:120px 0;text-align:center;position:relative;overflow:hidden;background:var(--nuit);color:var(--blanc);}
  .manifesto::before{content:"";position:absolute;inset:0;background:radial-gradient(700px 400px at 50% 50%,rgba(200,16,46,.1),transparent 60%);}
  .manifesto blockquote{position:relative;z-index:2;font-family:'Spectral',serif;font-style:italic;font-weight:400;font-size:clamp(24px,4vw,40px);line-height:1.3;max-width:760px;margin:0 auto;}
  .manifesto blockquote em{font-style:normal;color:var(--rouge);}
  .manifesto .sign{position:relative;z-index:2;margin-top:32px;font-size:11px;letter-spacing:.28em;text-transform:uppercase;color:var(--gris);}

  /* ============ NEWSLETTER (clair) ============ */
  .news{padding:104px 0 120px;border-top:1px solid rgba(16,24,46,.1);text-align:center;}
  .news .label{font-size:12px;letter-spacing:.3em;text-transform:uppercase;color:var(--rouge);font-weight:800;margin-bottom:16px;}
  .news h2{font-family:'Archivo Black',sans-serif;font-size:clamp(28px,5vw,46px);margin-bottom:14px;line-height:1;color:var(--nuit);}
  .news p{font-family:'Spectral',serif;font-size:18px;color:var(--encre);max-width:440px;margin:0 auto 34px;}
  .wl-form{display:flex;gap:10px;max-width:440px;margin:0 auto;}
  .wl-form input{flex:1;background:#fff;border:1px solid rgba(16,24,46,.2);color:var(--nuit);border-radius:9px;padding:16px 18px;font-family:inherit;font-size:14px;}
  .wl-form input::placeholder{color:var(--gris);}
  .wl-form input:focus{outline:none;border-color:var(--rouge);}
  .wl-form button{background:var(--rouge);color:#fff;border:none;cursor:pointer;font-family:inherit;font-weight:800;font-size:12px;letter-spacing:.12em;text-transform:uppercase;padding:0 28px;border-radius:9px;transition:transform .15s;}
  .wl-form button:hover{transform:translateY(-2px);}
  .wl-note{font-size:12px;color:var(--gris);margin-top:18px;letter-spacing:.04em;}

  /* ============ FOOTER ============ */
  footer.foot{border-top:1px solid rgba(16,24,46,.12);padding:56px 0 30px;background:var(--blanccasse);}
  .foot-grid{display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr;gap:30px;margin-bottom:42px;}
  .foot .brand{font-family:'Archivo Black',sans-serif;font-size:23px;letter-spacing:.1em;text-align:left;margin-bottom:14px;color:var(--nuit);}
  .foot .blurb{font-family:'Spectral',serif;font-size:14px;color:var(--encre);max-width:280px;}
  .foot .fil-sm{height:4px;width:60px;background:var(--fil);margin-top:18px;border-radius:2px;}
  .foot h5{color:var(--nuit);font-size:12px;letter-spacing:.16em;text-transform:uppercase;margin-bottom:16px;font-weight:800;}
  .foot ul{list-style:none;font-size:13px;display:flex;flex-direction:column;gap:9px;}
  .foot ul a{color:var(--encre);}
  .foot ul a:hover{color:var(--nuit);}
  .foot-bottom{border-top:1px solid rgba(16,24,46,.12);padding-top:22px;display:flex;justify-content:space-between;flex-wrap:wrap;gap:10px;font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--gris);}

  .mobile-menu{display:none;flex-direction:column;background:var(--blanccasse);border-top:1px solid rgba(16,24,46,.1);}
  .mobile-menu a{padding:16px 32px;border-bottom:1px solid rgba(16,24,46,.08);font-size:13px;letter-spacing:.14em;text-transform:uppercase;font-weight:600;color:var(--encre);}

  /* ============ CONTACT ============ */
  .contact{background:var(--nuit);color:var(--blanc);padding:90px 0 110px;position:relative;overflow:hidden;}
  .contact::before{content:"";position:absolute;inset:0;background:radial-gradient(820px 560px at 85% 20%,rgba(27,37,66,.8),transparent 60%),radial-gradient(440px 360px at 95% 95%,rgba(200,16,46,.1),transparent 60%);}
  .contact-wrap{position:relative;z-index:2;display:grid;grid-template-columns:0.85fr 1.15fr;gap:64px;align-items:start;}
  .contact-intro .label{font-size:12px;letter-spacing:.3em;text-transform:uppercase;color:var(--rouge);font-weight:800;margin-bottom:14px;}
  .contact-intro h1{font-family:'Archivo Black',sans-serif;font-size:clamp(40px,5vw,64px);line-height:.96;margin-bottom:20px;}
  .contact-intro .lead{font-family:'Spectral',serif;font-size:18px;color:var(--blanccasse);max-width:380px;margin-bottom:36px;}
  .contact-side{display:flex;flex-direction:column;gap:18px;border-top:1px solid rgba(244,241,234,.12);padding-top:26px;}
  .cs-item .cs-k{font-size:10px;letter-spacing:.2em;text-transform:uppercase;color:var(--gris);margin-bottom:4px;}
  .cs-item .cs-v{font-size:15px;font-weight:600;color:var(--blanc);}

  .contact-form-wrap{background:var(--blanc);color:var(--nuit);border-radius:16px;padding:40px;box-shadow:0 30px 60px -28px rgba(0,0,0,.5);}
  .cf-row{margin-bottom:20px;}
  .cf-row label{display:block;font-size:11px;letter-spacing:.16em;text-transform:uppercase;font-weight:700;color:var(--encre);margin-bottom:8px;}
  .cf-row input,.cf-row textarea{width:100%;background:#fff;border:1px solid rgba(16,24,46,.2);color:var(--nuit);border-radius:9px;padding:14px 16px;font-family:inherit;font-size:15px;transition:border-color .2s;}
  .cf-row textarea{resize:vertical;min-height:130px;}
  .cf-row input:focus,.cf-row textarea:focus{outline:none;border-color:var(--rouge);}
  .cf-submit{width:100%;margin-top:6px;cursor:pointer;border:none;}
  .cf-hp{position:absolute;left:-9999px;width:1px;height:1px;overflow:hidden;}
  .cf-errors{background:rgba(200,16,46,.08);border:1px solid rgba(200,16,46,.3);border-radius:9px;padding:14px 18px;margin-bottom:24px;}
  .cf-errors p{color:var(--rouge);font-size:14px;margin:2px 0;}
  .cf-success{text-align:center;padding:30px 10px;}
  .cf-success-mark{font-family:'Archivo Black',sans-serif;font-size:64px;color:var(--nuit);line-height:1;margin-bottom:18px;}
  .cf-success h2{font-family:'Archivo Black',sans-serif;font-size:30px;margin-bottom:10px;}
  .cf-success p{font-family:'Spectral',serif;font-size:17px;color:var(--encre);}
  .cf-success .fil-sm{height:4px;width:60px;background:var(--fil);margin:22px auto 0;border-radius:2px;}

  /* ============ RESPONSIVE ============ */
  /* Tablette large */
  @media(max-width:1024px){
    .wrap{padding:0 32px;}
    .piece-grid{gap:48px;}
  }
  /* Tablette */
  @media(max-width:900px){
    .nav-left{display:none;}
    .nav-right{display:none;}
    .nav{justify-content:space-between;}
    .brand{flex:1;text-align:left;}
    .burger{display:flex;}
    .piece-grid{grid-template-columns:1fr;gap:34px;}
    .piece.rev .piece-grid{direction:ltr;}
    /* visuel produit moins haut une fois empilé */
    .piece-visual{max-width:440px;margin:0 auto;width:100%;}
    .det-grid{grid-template-columns:1fr;}
    .contact-wrap{grid-template-columns:1fr;gap:40px;}
    .contact{padding:64px 0 80px;}
    .contact-form-wrap{padding:30px;}
    .foot-grid{grid-template-columns:1fr 1fr;}
    .hero{min-height:auto;padding:60px 0 70px;}
    .hero-inner{flex-direction:column;align-items:flex-start;gap:26px;}
    .hero-text{flex:1 1 auto;width:100%;max-width:none;}
    .hero-cta{flex-direction:column;align-items:stretch;width:100%;max-width:340px;margin-left:0;gap:12px;}
    .hero-cta .btn{text-align:center;}
    .hero-foot{position:static;margin-top:34px;}
    .hero-foot-in{flex-wrap:wrap;gap:14px 24px;}
    .hero .ghost{right:-18%;font-size:clamp(260px,60vw,420px);}
    .collection,.details,.manifesto,.news{padding:64px 0;}
    .mobile-menu.open{display:flex;}
    /* barre de réassurance : 2 colonnes */
    .trust-in{flex-wrap:wrap;}
    .trust .t{flex:1 1 50%;border-left:1px solid rgba(16,24,46,.08);border-top:1px solid rgba(16,24,46,.08);}
    .trust .t:nth-child(-n+2){border-top:none;}
    .trust .t:nth-child(odd){border-left:none;}
  }
  /* Mobile */
  @media(max-width:600px){
    .hero h1{font-size:clamp(34px,9vw,46px);}
    .hero .ghost{right:-26%;opacity:.7;}
    .sec-head{align-items:flex-start;}
    .piece{padding:48px 0;}
    /* specs : empilées proprement */
    .specs{flex-direction:column;}
    .specs .s{border-left:none;border-top:1px solid rgba(16,24,46,.1);}
    .specs .s:first-child{border-top:none;}
    .piece-visual .mark{font-size:160px;}
    /* réassurance : 1 colonne */
    .trust .t{flex:1 1 100%;border-left:none;}
    .trust .t:nth-child(-n+2){border-top:1px solid rgba(16,24,46,.08);}
    .trust .t:first-child{border-top:none;}
  }
  @media(max-width:480px){
    .wrap{padding:0 22px;}
    .wl-form{flex-direction:column;}
    .wl-form button{padding:15px;}
    .foot-grid{grid-template-columns:1fr;}
    .btn{padding:13px 22px;}
    .hero-cta{gap:10px;}
  }
