/* ===== CAROL LASHES DESIGNER — estilo elegante ===== */
@import url('https://fonts.googleapis.com/css2?family=Cormorant+Garamond:ital,wght@0,400;0,500;0,600;1,400&family=Jost:wght@300;400;500;600&display=swap');

:root{
  --noir:#1a1416;
  --rose:#c98b9b;
  --rose-deep:#a8576d;
  --nude:#f3e7e3;
  --nude-soft:#faf4f1;
  --gold:#c9a86a;
  --gold-light:#e3cfa3;
  --ink:#2b2226;
  --shadow:0 18px 50px -20px rgba(102,49,66,.45);
  --serif:'Cormorant Garamond',serif;
  --sans:'Jost',sans-serif;
}

*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  font-family:var(--sans);
  color:var(--ink);
  background:var(--nude-soft);
  line-height:1.6;
  font-weight:300;
}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}

/* ===== Header ===== */
header{
  position:fixed;top:0;left:0;right:0;z-index:100;
  display:flex;align-items:center;justify-content:space-between;
  padding:18px 6vw;
  background:rgba(250,244,241,.82);
  backdrop-filter:blur(14px);
  border-bottom:1px solid rgba(201,168,106,.25);
}
.logo{font-family:var(--serif);font-size:1.5rem;font-weight:600;letter-spacing:.5px;color:var(--rose-deep)}
.logo span{color:var(--gold);font-style:italic}
nav{display:flex;gap:28px;align-items:center}
nav a{font-size:.82rem;letter-spacing:1.5px;text-transform:uppercase;font-weight:400;transition:color .25s}
nav a:hover{color:var(--rose-deep)}
.btn-nav{padding:9px 22px;border:1px solid var(--rose-deep);border-radius:30px;color:var(--rose-deep)!important}
.btn-nav:hover{background:var(--rose-deep);color:#fff!important}
.menu-toggle{display:none;font-size:1.6rem;background:none;border:none;cursor:pointer;color:var(--rose-deep)}

/* ===== Hero ===== */
.hero{
  min-height:100vh;display:flex;align-items:center;
  padding:120px 6vw 60px;
  background:
    radial-gradient(circle at 75% 30%,rgba(201,139,155,.18),transparent 55%),
    linear-gradient(135deg,var(--nude-soft),var(--nude));
  position:relative;overflow:hidden;
}
.hero::after{
  content:'';position:absolute;right:-80px;top:50%;transform:translateY(-50%);
  width:520px;height:520px;border-radius:50%;
  background:radial-gradient(circle,rgba(201,168,106,.22),transparent 70%);
}
.hero-content{max-width:640px;z-index:2;animation:rise 1s ease both}
.hero .tag{font-size:.78rem;letter-spacing:4px;text-transform:uppercase;color:var(--gold);margin-bottom:18px}
.hero h1{font-family:var(--serif);font-size:clamp(2.8rem,7vw,5rem);font-weight:500;line-height:1.05;color:var(--ink)}
.hero h1 em{color:var(--rose-deep);font-style:italic}
.hero p{font-size:1.1rem;margin:24px 0 36px;color:#6a5a5e;max-width:480px}
.btn-primary{
  display:inline-block;padding:15px 40px;border-radius:34px;
  background:linear-gradient(120deg,var(--rose-deep),var(--rose));
  color:#fff;font-size:.85rem;letter-spacing:2px;text-transform:uppercase;
  box-shadow:var(--shadow);transition:transform .3s,box-shadow .3s;
}
.btn-primary:hover{transform:translateY(-3px);box-shadow:0 24px 55px -18px rgba(168,87,109,.6)}

@keyframes rise{from{opacity:0;transform:translateY(30px)}to{opacity:1;transform:none}}

/* ===== Seções ===== */
section{padding:90px 6vw}
.section-head{text-align:center;max-width:620px;margin:0 auto 56px}
.section-head .tag{font-size:.75rem;letter-spacing:4px;text-transform:uppercase;color:var(--gold)}
.section-head h2{font-family:var(--serif);font-size:clamp(2rem,5vw,3.2rem);font-weight:500;margin-top:10px;color:var(--ink)}
.section-head p{color:#7a6a6e;margin-top:14px}

/* ===== Cards ===== */
.grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:26px}
.card{
  background:#fff;border-radius:18px;padding:30px;
  border:1px solid rgba(201,168,106,.18);
  box-shadow:0 10px 30px -18px rgba(102,49,66,.3);
  transition:transform .3s,box-shadow .3s;display:flex;flex-direction:column;
}
.card:hover{transform:translateY(-6px);box-shadow:var(--shadow)}
.card h3{font-family:var(--serif);font-size:1.5rem;font-weight:600;color:var(--rose-deep)}
.card .desc{color:#7a6a6e;font-size:.92rem;margin:10px 0 18px;flex:1}
.card .meta{display:flex;justify-content:space-between;align-items:center;margin-top:auto}
.card .preco{font-family:var(--serif);font-size:1.6rem;color:var(--gold);font-weight:600}
.card .dur{font-size:.78rem;color:#9a8a8e;letter-spacing:1px}
.btn-card{
  margin-top:18px;padding:12px;border-radius:30px;text-align:center;cursor:pointer;
  background:var(--ink);color:#fff;font-size:.78rem;letter-spacing:1.5px;text-transform:uppercase;
  border:none;transition:background .25s;width:100%;font-family:var(--sans);
}
.btn-card:hover{background:var(--rose-deep)}

/* ===== Modal ===== */
.modal-bg{
  position:fixed;inset:0;background:rgba(40,20,28,.55);backdrop-filter:blur(4px);
  display:none;align-items:center;justify-content:center;z-index:200;padding:20px;
}
.modal-bg.show{display:flex}
.modal{
  background:#fff;border-radius:22px;padding:38px;width:100%;max-width:440px;
  box-shadow:var(--shadow);max-height:90vh;overflow-y:auto;animation:rise .4s ease both;
}
.modal h3{font-family:var(--serif);font-size:1.9rem;color:var(--rose-deep);margin-bottom:6px}
.modal .sub{color:#8a7a7e;font-size:.9rem;margin-bottom:22px}
.modal label{display:block;font-size:.75rem;letter-spacing:1.5px;text-transform:uppercase;color:#9a8a8e;margin:14px 0 6px}
.modal input,.modal select,.modal textarea{
  width:100%;padding:13px 16px;border:1px solid #e6d6d1;border-radius:12px;
  font-family:var(--sans);font-size:.95rem;background:var(--nude-soft);transition:border .2s;
}
.modal input:focus,.modal select:focus{outline:none;border-color:var(--rose)}
.modal .btn-primary{width:100%;margin-top:24px;border:none;cursor:pointer;font-family:var(--sans)}
.modal-close{float:right;font-size:1.5rem;cursor:pointer;color:#bbb;background:none;border:none}
.switch-link{text-align:center;margin-top:18px;font-size:.85rem;color:#8a7a7e}
.switch-link a{color:var(--rose-deep);cursor:pointer;text-decoration:underline}
.msg{padding:11px;border-radius:10px;font-size:.85rem;margin-top:14px;display:none}
.msg.erro{background:#fdeaea;color:#b3403f;display:block}
.msg.ok{background:#eafaf0;color:#2e8b57;display:block}

/* ===== Pagamento opções ===== */
.pay-opt{display:flex;gap:12px;margin-top:18px}
.pay-opt button{flex:1;padding:14px;border-radius:12px;border:1.5px solid #e6d6d1;background:#fff;cursor:pointer;font-family:var(--sans);font-size:.85rem;transition:all .2s}
.pay-opt button:hover{border-color:var(--rose-deep);color:var(--rose-deep)}
.pix-box{background:var(--nude);padding:18px;border-radius:12px;margin-top:18px;text-align:center}
.pix-box code{display:block;background:#fff;padding:12px;border-radius:8px;margin:10px 0;word-break:break-all;font-size:.9rem}

/* ===== Footer ===== */
footer{background:var(--ink);color:#d8c8cc;padding:60px 6vw;text-align:center}
footer .logo{color:#fff;margin-bottom:14px}
footer p{font-size:.85rem;opacity:.7;margin:6px 0}

/* ===== Carrinho flutuante ===== */
.cart-fab{
  position:fixed;bottom:26px;right:26px;width:60px;height:60px;border-radius:50%;
  background:linear-gradient(120deg,var(--rose-deep),var(--rose));color:#fff;
  display:flex;align-items:center;justify-content:center;font-size:1.4rem;
  box-shadow:var(--shadow);cursor:pointer;z-index:90;border:none;
}
.cart-count{position:absolute;top:-4px;right:-4px;background:var(--gold);color:var(--ink);
  font-size:.7rem;font-weight:600;width:22px;height:22px;border-radius:50%;display:flex;align-items:center;justify-content:center}
.cart-item{display:flex;justify-content:space-between;align-items:center;padding:12px 0;border-bottom:1px solid #f0e6e2}
.cart-item .qtd{display:flex;gap:8px;align-items:center}
.cart-item .qtd button{width:26px;height:26px;border-radius:50%;border:1px solid var(--rose);background:#fff;cursor:pointer;color:var(--rose-deep)}

/* ===== Responsivo ===== */
@media(max-width:768px){
  nav{position:fixed;top:62px;right:0;flex-direction:column;background:#fff;
    padding:24px 30px;gap:18px;box-shadow:var(--shadow);border-radius:0 0 0 18px;
    transform:translateX(110%);transition:transform .3s;align-items:flex-start}
  nav.open{transform:none}
  .menu-toggle{display:block}
  .hero::after{width:320px;height:320px;right:-120px}
  section{padding:60px 6vw}
}
