/*
Theme Name: QS Ateliê
Theme URI: https://qsatelie.com
Author: Joabe Santana
Author URI: https://qsatelie.com
Version: 1.0.0
Text Domain: qs-atelie
*/

@import url("https://fonts.googleapis.com/css2?family=Montserrat:wght@300;400;500;600&family=Playfair+Display:wght@400;500;600&family=Dancing+Script:wght@500;600&display=swap");

/* === SEU CSS (copie do <style> do HTML) === */
:root{
      /* Paleta (premium / suave) */

      --corPrimaria: #FFFFFF;
      --corSecundaria: #000000;
      --corTerciaria: #535353;
      --bordaPanel: #53535338;


      --offwhite: #F7F5F2;
      --white: #FFFFFF;
      --bege: #EFE7DF;
      --border: #E9E6E2;
      --text: var(--corSecundaria);
      --muted: var(--corTerciaria);

      --rose: #CFA3A1;
      --nude: #D8C7B6;
      --oliva: #9AA289;
      --gold: #C8B08A;

      --black: #000000;
      --grey: #535353;

      --radius: 18px;
      --shadow: 0 18px 40px rgba(0,0,0,.08);
      --shadowSoft: 0 12px 30px rgba(0,0,0,.06);
      --max: 1120px;
    }

    *{box-sizing:border-box}
    html,body{height:100%}
    body{
      margin:0;
      font-family: Montserrat, system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
      color:var(--text);
      background: var(--corPrimaria);
      line-height:1.55;
    }

    a{color:inherit}
    .wrap{max-width:var(--max); margin:0 auto; padding:0 10px;}

    /* Top bar */
    .topbar{
      position:sticky; top:0; z-index:10;
      backdrop-filter: blur(8px);
      background: transparent;
      border-bottom: 1px solid var(--corSecundaria);
    }
    .topbar-inner{
      display:flex; align-items:center; justify-content:space-between;
      padding:12px 10px;
      gap:12px;
    }
    .brand{
      display:flex; align-items:center; gap:5px;
      text-decoration:none;
    }
    .brand img{width:44px; height:44px; object-fit:contain}
    .brand .name{
      display:flex; flex-direction:column;
      line-height:1.1;
    }
    .brand .name strong{
      font-family: "Playfair Display", serif;
      font-weight:600;
      letter-spacing:.2px;
    }
    .brand .name span{
      font-size:12px; color:var(--muted);
      letter-spacing:.2em;
      text-transform:uppercase;
    }

    .nav-actions{display:flex; align-items:center; gap:10px}
    .btn{
      display:inline-flex; align-items:center; justify-content:center;
      padding:10px 14px;
      border-radius:999px;
      border:1px solid var(--black);
      background:transparent;
      text-decoration:none;
      font-size:13px;
      gap:8px;
      transition: transform .15s ease, background .15s ease, color .15s ease, border-color .15s ease;
      white-space:nowrap;
    }
    .btn:hover{transform: translateY(-1px); color: var(--corSecundaria);}
    .btn-solid{
      background: var(--corTerciaria);
      color: var(--corPrimaria);
      border-color: transparent;
    }
    .btn-solid:hover{background: var(--corSecundaria); color: var(--corPrimaria);}
    .btn-ghost{
      border-color: var(--corSecundaria);
      background: transparent;
    }

    /* Sections */
    section{padding:46px 0 0 0}
    .panel{
      background: rgba(255,255,255,.58);
      border: 1px solid var(--bordaPanel);
      border-radius: var(--radius);
      box-shadow: var(--shadowSoft);
      overflow:hidden;
    }

    /* Hero */
    .hero{
      padding-top:46px;
    }
    .hero-inner{
      padding:28px 26px 28px;
      text-align:center;
    }
    .hero-logo{
      width:86px; height:86px;
      margin:0 auto 10px;
      object-fit:contain;
    }
    .kicker{
      letter-spacing:.22em;
      text-transform:uppercase;
      font-size:12px;
      color:var(--muted);
      margin-bottom:4px;
    }
    h1{
      font-family:"Playfair Display", serif;
      font-weight:600;
      font-size:42px;
      letter-spacing:.2px;
      margin:10px 0 10px;
    }
    .subtitle{
      font-family: "Dancing Script", cursive;
      font-size:22px;
      color: var(--corTerciaria);
      margin:0 0 18px;
    }
    .hero-actions{
      display:flex; gap:10px; justify-content:center; flex-wrap:wrap;
      margin-top:14px;
    }
    .hint{
      margin-top:18px;
      font-size:13px;
      color:var(--muted);
    }

    /* Models */
    .section-title{
      text-align:center;
      margin-bottom:26px;
    }
    .section-title h2{
      font-family:"Playfair Display", serif;
      font-weight:600;
      font-size:32px;
      margin:0 0 6px;
    }
    .section-title p{
      margin:0;
      color:var(--muted);
    }

    .models{
      padding:28px 22px 28px;
    }
    .phones{
      display:grid;
      grid-template-columns: repeat(4, 1fr);
      gap:18px;
      align-items:end;
      margin-top:22px;
    }
    .phone{
      background: transparent;
      border:1px solid var(--bordaPanel);
      border-radius: 26px;
      padding:14px;
      box-shadow: 0 12px 30px rgba(0,0,0,.06);
      text-align:center;
    }
    .phone img{
      width:100%;
      max-width:220px;
      height:auto;
      border-radius: 20px;
    }
    .phone .label{
      margin-top:10px;
      font-size:12px;
      letter-spacing:.14em;
      text-transform:uppercase;
      color:var(--muted);
      min-height: 40px;
      align-content: center;
    }
    .phone .cta{
      display:flex;
      justify-content:center;
      padding: 10px 26px 0px;
    }

    /* Types (cards) */
    .types-grid{
      display:grid;
      grid-template-columns: repeat(5, 1fr);
      gap:14px;
    }
    .card{
      background: rgba(255,255,255,.72);
      border:1px solid var(--bordaPanel);
      border-radius: 16px;
      overflow:hidden;
      box-shadow: 0 10px 24px rgba(0,0,0,.05);
      display:flex;
      flex-direction:column;
      min-height: 260px;
    }
    .card-head{
      padding:14px 14px 10px;
      background: linear-gradient(180deg, rgba(0,0,0,.38), rgba(255,255,255,0));
    }
    .card h3{
      font-family:"Playfair Display", serif;
      font-weight:600;
      margin:0;
      font-size:18px;
      text-align:center;
    }
    .card-body{
      padding:12px 16px 16px;
      display:flex;
      flex-direction:column;
      gap:10px;
      flex:1;
    }
    .list{
      margin:0;
      padding:0 0 0 18px;
      color: var(--corTerciaria);
      font-size:13px;
      text-align: start;
    }
    .price{
      margin-top:auto;
      font-size:13px;
      color:var(--muted);
      text-align:center;
    }
    .price strong{color: var(--corTerciaria)}
    .card .btn{
      margin-top:8px;
      width:100%;
    }

    /* How it works */
    .steps{
      display:grid;
      grid-template-columns: repeat(4, 1fr);
      gap:12px;
    }
    .step{
      background: transparent;
      border:1px solid var(--bordaPanel);
      border-radius: 16px;
      padding:14px;
      min-height: 98px;
      display:flex;
      gap:10px;
      align-items: center;
      box-shadow: 0 10px 24px rgba(0,0,0,.04);
    }
    .badge{
      width:34px; height:34px;
      border-radius: 12px;
      display:grid; place-items:center;
      background: transparent;
      border:1px solid var(--bordaPanel);
      font-weight:600;
      color: var(--corSecundaria);
      flex: 0 0 auto;
    }
    .step p{
      margin:0;
      font-size:13px;
      color:var(--corTerciaria);
    }

    /* Differentials */
    .diffs{
      display:grid;
      grid-template-columns: 1.1fr .9fr;
      gap:16px;
      align-items:center;
      text-align: start;
    }
    .diffs ul{
      margin:0;
      padding:0 0 0 18px;
      color:var(--corTerciaria);
      font-size:14px;
    }
    .mini{
      background: transparent;
      border:1px solid var(--bordaPanel);
      border-radius: 16px;
      padding:16px;
      box-shadow: 0 10px 24px rgba(0,0,0,.04);
      color:var(--muted);
      font-size:13px;
    }
    .mini strong{color:var(--corTerciaria)}

    /* CTA */
    .cta{
      text-align:center;
      padding:28px 26px 28px;
      background: radial-gradient(900px 450px at 50% 30%, rgba(255,255,255,.8), rgba(255,255,255,.25) 70%);
    }
    .cta h2{
      font-family:"Playfair Display", serif;
      font-weight:600;
      font-size:30px;
      margin:0 0 10px;
    }
    .cta p{margin:0 0 16px; color:var(--muted)}
    .cta .hero-actions{margin-top:0}

    /* Footer */
    footer{
      padding:26px 0 40px;
      color:var(--muted);
      text-align:center;
    }
    .footer-logo{width:54px; height:54px; object-fit:contain; opacity:.9}
    .fine{font-size:12px; margin-top:8px}

    /* Responsive */
    @media (max-width: 980px){
      h1{font-size:34px}
      .phones{grid-template-columns: repeat(2, 1fr)}
      .types-grid{grid-template-columns: repeat(2, 1fr)}
      .steps{grid-template-columns: repeat(2, 1fr)}
      .diffs{grid-template-columns: 1fr}
    }
    @media (max-width: 520px){
      section{padding:42px 0px 0px 0px}
      h1{font-size:30px}
      .phones{grid-template-columns: 1fr}
      .types-grid{grid-template-columns: 1fr}
      .steps{grid-template-columns: 1fr}
      .topbar-inner{gap:8px}
      .brand .name span{line-height: 1.5; font-size: 8px;}
    }

/* ... cole aqui TODO o restante do seu CSS ... */