/* ════════════════════════════════
   SONHO LEVE — CSS
   ════════════════════════════════ */
:root {
  --sl-accent:    #d7c3a2;
  --sl-accent-dk: #c4aa84;
  --sl-accent-lt: #f2ebe0;
  --sl-text:      #1c1916;
  --sl-muted:     #6e6459;
  --sl-line:      rgba(28,18,10,.10);
  --sl-bg:        #faf8f5;
  --sl-white:     #ffffff;
  --sl-dark:      #13100d;
  --sl-max:       1200px;
  --sl-r:         18px;
  --f-display:    'Playfair Display', Georgia, serif;
  --f-body:       'Lato', system-ui, sans-serif;
  --ease:         cubic-bezier(.16,1,.3,1);
}

*,*::before,*::after { box-sizing:border-box; margin:0; padding:0; }
html { scroll-behavior:smooth; }
body {
  font-family: var(--f-body);
  font-size: 16px;
  line-height: 1.7;
  color: var(--sl-text);
  background: var(--sl-bg);
  overflow-x: hidden;
  -webkit-font-smoothing: antialiased;
}

/* Utilitários */
.sl-wrap    { max-width:var(--sl-max); margin:0 auto; padding:0 24px; }
.sl-section { padding:80px 0; }
.sl-divider { border:none; border-top:1px solid var(--sl-line); }

/* Acessibilidade — esconde H1 visualmente, mantém para SEO */
.sr-only {
  position:absolute; width:1px; height:1px;
  padding:0; margin:-1px; overflow:hidden;
  clip:rect(0,0,0,0); white-space:nowrap; border:0;
}

.sl-eyebrow {
  display:inline-block;
  font-family:var(--f-body);
  font-size:11px; font-weight:700;
  letter-spacing:3px; text-transform:uppercase;
  color:var(--sl-accent-dk); margin-bottom:12px;
}

.sl-title {
  font-family:var(--f-display);
  font-size:clamp(26px,3.6vw,38px);
  font-weight:700; line-height:1.18;
  letter-spacing:-.2px;
  color:var(--sl-text); text-align:center;
}
.sl-title em { font-style:italic; font-weight:500; color:var(--sl-muted); }

.sl-lead {
  font-size:17px; font-weight:300; line-height:1.8;
  color:var(--sl-muted);
  max-width:580px; margin:16px auto 0;
  text-align:center;
}

/* Botões */
.sl-btn {
  display:inline-flex; align-items:center; gap:8px;
  padding:13px 24px; border-radius:6px;
  font-family:var(--f-body); font-weight:700;
  font-size:14px; letter-spacing:.5px;
  text-decoration:none; border:1.5px solid transparent;
  cursor:pointer;
  transition:transform .22s var(--ease), background .18s, box-shadow .18s;
  position:relative; overflow:hidden;
}
.sl-btn:hover  { transform:translateY(-2px); }
.sl-btn:active { transform:translateY(0); }

.sl-btn-primary {
  background:var(--sl-accent); color:var(--sl-dark);
  border-color:var(--sl-accent);
  box-shadow:0 3px 14px rgba(196,170,132,.3);
}
.sl-btn-primary:hover {
  background:var(--sl-accent-dk); border-color:var(--sl-accent-dk);
  box-shadow:0 6px 22px rgba(196,170,132,.45);
}
.sl-btn-dark {
  background:var(--sl-dark); color:#fff; border-color:var(--sl-dark);
  box-shadow:0 3px 14px rgba(0,0,0,.18);
}
.sl-btn-dark:hover {
  background:#2d261f;
  box-shadow:0 6px 24px rgba(0,0,0,.3);
}
.sl-btn-ghost {
  background:transparent; color:#fff;
  border-color:rgba(255,255,255,.5);
}
.sl-btn-ghost:hover {
  background:rgba(255,255,255,.1);
  border-color:rgba(255,255,255,.8);
}
.sl-btn-outline {
  background:transparent; color:var(--sl-text);
  border-color:var(--sl-line);
}
.sl-btn-outline:hover {
  background:var(--sl-accent-lt); border-color:var(--sl-accent);
}
.sl-cta { display:flex; gap:10px; flex-wrap:wrap; }

/* Barra promo */
.sl-announcement {
  background:var(--sl-dark); color:#e0d5c8;
  text-align:center; font-family:var(--f-body);
  font-size:13px; font-weight:400; letter-spacing:.4px;
  padding:11px 20px; position:relative; overflow:hidden;
}
.sl-announcement::before {
  content:''; position:absolute; inset:0;
  background:repeating-linear-gradient(90deg,
    transparent,transparent 100px,
    rgba(215,195,162,.05) 100px,rgba(215,195,162,.05) 101px);
}
.sl-announcement strong { color:var(--sl-accent); font-weight:700; }
.sl-announcement .sep   { margin:0 14px; opacity:.35; }

/* Topbar */
.sl-topbar {
  background:rgba(250,248,245,.94);
  backdrop-filter:blur(16px); -webkit-backdrop-filter:blur(16px);
  border-bottom:1px solid var(--sl-line);
  position:sticky; top:0; z-index:200;
  transition:box-shadow .3s;
}
.sl-topbar.scrolled { box-shadow:0 4px 28px rgba(0,0,0,.07); }

.sl-topbar__inner {
  display:grid;
  grid-template-columns:260px 1fr 360px;
  align-items:center; gap:20px; padding:13px 0;
}

.sl-brand {
  display:flex; align-items:center; gap:11px; text-decoration:none;
}
.sl-brand__logo {
  width:44px; height:44px; border-radius:10px;
  object-fit:cover; border:1px solid var(--sl-line);
  transition:transform .3s var(--ease);
}
.sl-brand:hover .sl-brand__logo { transform:rotate(-5deg) scale(1.06); }
.sl-brand strong {
  font-family:var(--f-display);
  font-size:22px; font-weight:700;
  letter-spacing:2px; color:var(--sl-text); line-height:1;
}

.sl-nav {
  display:flex; justify-content:center; gap:28px; align-items:center;
}
.sl-nav a {
  text-decoration:none; color:var(--sl-muted);
  font-weight:700; font-size:13.5px; letter-spacing:.4px;
  position:relative; padding-bottom:3px; transition:color .2s;
}
.sl-nav a::after {
  content:''; position:absolute;
  bottom:0; left:0; width:0; height:1.5px;
  background:var(--sl-accent-dk);
  transition:width .3s var(--ease);
}
.sl-nav a:hover        { color:var(--sl-text); }
.sl-nav a:hover::after { width:100%; }

.sl-actions {
  display:flex; align-items:center;
  justify-content:flex-end; gap:8px;
}
.sl-search {
  display:flex; align-items:center; gap:6px;
  border:1px solid var(--sl-line); border-radius:6px;
  padding:8px 8px 8px 14px;
  background:var(--sl-white); width:200px;
  transition:border-color .2s, box-shadow .2s;
}
.sl-search:focus-within {
  border-color:var(--sl-accent);
  box-shadow:0 0 0 3px rgba(215,195,162,.2);
}
.sl-search input {
  border:0; outline:none; width:100%;
  font-family:var(--f-body); font-size:13px;
  background:transparent; color:var(--sl-text);
}
.sl-search button {
  border:0; background:var(--sl-accent);
  border-radius:4px; padding:6px 10px;
  cursor:pointer; font-size:13px;
  transition:background .2s, transform .2s;
}
.sl-search button:hover { background:var(--sl-accent-dk); transform:scale(1.05); }

.sl-icon {
  width:40px; height:40px;
  border:1px solid var(--sl-line); border-radius:8px;
  display:flex; align-items:center; justify-content:center;
  text-decoration:none; background:var(--sl-white);
  font-size:16px; position:relative;
  transition:background .2s, border-color .2s, transform .2s var(--ease);
}
.sl-icon:hover {
  background:var(--sl-accent-lt); border-color:var(--sl-accent);
  transform:translateY(-2px);
}
.sl-cart-badge {
  position:absolute; top:-5px; right:-5px;
  background:var(--sl-dark); color:#fff;
  font-size:10px; font-weight:700; line-height:1;
  padding:3px 5px; border-radius:999px;
  border:2px solid var(--sl-bg); min-width:18px; text-align:center;
}

/* Hero */
.sl-hero {
  min-height:580px; display:flex; align-items:center;
  background:
    linear-gradient(150deg,rgba(10,8,5,.65) 0%,rgba(10,8,5,.4) 55%,rgba(196,170,132,.15) 100%),
    url("https://sonholeve.pt/wp-content/uploads/2025/10/cropped-image-1.jpg");
  background-size:cover; background-position:center 38%;
  position:relative; overflow:hidden;
}
.sl-hero::after {
  content:''; position:absolute;
  bottom:0; left:0; right:0; height:90px;
  background:linear-gradient(transparent,var(--sl-bg));
  pointer-events:none;
}
.sl-hero__inner { position:relative; z-index:1; padding:70px 0 90px; }

.sl-hero__eyebrow {
  display:inline-flex; align-items:center; gap:8px;
  background:rgba(215,195,162,.16); border:1px solid rgba(215,195,162,.32);
  backdrop-filter:blur(6px); border-radius:4px;
  padding:6px 14px; font-family:var(--f-body);
  font-size:11px; font-weight:700; letter-spacing:2.5px;
  text-transform:uppercase; color:var(--sl-accent);
  margin-bottom:24px;
  opacity:0; animation:fadeUp .7s var(--ease) .1s forwards;
}
.sl-hero__logo-wrap {
  margin-bottom:20px;
  opacity:0; animation:fadeUp .8s var(--ease) .22s forwards;
}
.sl-hero__logo-wrap img {
  width:80px; height:80px; border-radius:16px;
  border:2px solid rgba(215,195,162,.35); object-fit:cover;
}
.sl-hero__headline {
  font-family:var(--f-display);
  font-size:clamp(38px,5.5vw,62px);
  font-weight:700; line-height:1.08;
  color:#fff; max-width:660px; margin-bottom:18px;
  opacity:0; animation:fadeUp .8s var(--ease) .32s forwards;
}
.sl-hero__headline em { font-style:italic; font-weight:500; color:var(--sl-accent); }
.sl-hero__desc {
  font-size:17px; font-weight:300; line-height:1.8;
  color:rgba(255,255,255,.82); max-width:500px; margin-bottom:32px;
  opacity:0; animation:fadeUp .8s var(--ease) .44s forwards;
}
.sl-hero .sl-cta {
  opacity:0; animation:fadeUp .8s var(--ease) .56s forwards;
}

/* Trust strip */
.sl-trust { background:var(--sl-white); border-bottom:1px solid var(--sl-line); }
.sl-trust__grid { display:grid; grid-template-columns:repeat(4,1fr); }
.sl-trust__item {
  display:flex; align-items:center; gap:14px;
  padding:20px 22px; border-right:1px solid var(--sl-line);
  transition:background .2s;
}
.sl-trust__item:last-child { border-right:none; }
.sl-trust__item:hover { background:var(--sl-accent-lt); }
.sl-trust__icon {
  width:38px; height:38px; background:var(--sl-accent-lt);
  border-radius:8px; display:flex; align-items:center;
  justify-content:center; font-size:17px; flex-shrink:0;
  transition:transform .3s var(--ease);
}
.sl-trust__item:hover .sl-trust__icon { transform:scale(1.12) rotate(-6deg); }
.sl-trust__text b    { display:block; font-size:14px; font-weight:700; color:var(--sl-text); }
.sl-trust__text span { font-size:12.5px; color:var(--sl-muted); }

/* Features */
.sl-features {
  display:grid; grid-template-columns:repeat(3,1fr);
  gap:20px; margin-top:44px;
}
.sl-card {
  border:1px solid var(--sl-line); border-radius:var(--sl-r);
  padding:30px; background:var(--sl-white);
  position:relative; overflow:hidden;
  transition:transform .3s var(--ease), box-shadow .3s, border-color .3s;
}
.sl-card::before {
  content:''; position:absolute;
  top:0; left:0; right:0; height:3px;
  background:linear-gradient(90deg,var(--sl-accent),var(--sl-accent-dk));
  transform:scaleX(0); transform-origin:left;
  transition:transform .4s var(--ease);
}
.sl-card:hover { transform:translateY(-5px); box-shadow:0 16px 40px rgba(0,0,0,.07); border-color:var(--sl-accent); }
.sl-card:hover::before { transform:scaleX(1); }
.sl-card__num {
  font-family:var(--f-display); font-size:48px; font-weight:700;
  color:var(--sl-accent-lt); line-height:1; margin-bottom:14px; display:block;
}
.sl-card h3 {
  font-family:var(--f-display); font-size:20px; font-weight:700;
  margin-bottom:10px; color:var(--sl-text); line-height:1.25;
}
.sl-card p { font-size:15px; color:var(--sl-muted); line-height:1.75; font-weight:300; }

/* Produtos Woo */
.sl-products ul.products {
  display:grid !important; grid-template-columns:repeat(4,1fr) !important;
  gap:20px !important; list-style:none !important;
  padding:0 !important; margin:0 !important;
}
.sl-products li.product {
  float:none !important; width:auto !important; margin:0 !important;
  border:1px solid var(--sl-line) !important; border-radius:var(--sl-r) !important;
  padding:16px !important; background:var(--sl-bg) !important;
  transition:transform .3s var(--ease), box-shadow .3s !important;
}
.sl-products li.product:hover { transform:translateY(-4px) !important; box-shadow:0 12px 32px rgba(0,0,0,.07) !important; }
.sl-products li.product img { border-radius:10px !important; width:100% !important; height:auto !important; display:block !important; }
.sl-products .woocommerce-loop-product__title {
  font-family:var(--f-display) !important; font-size:16px !important;
  font-weight:500 !important; line-height:1.4 !important;
  margin:12px 0 6px !important; color:var(--sl-text) !important;
}
.sl-section-header {
  display:flex; align-items:flex-end;
  justify-content:space-between; margin-bottom:32px; gap:20px; flex-wrap:wrap;
}
.sl-section-header .sl-title { text-align:left; }
.sl-section-header .sl-lead  { text-align:left; margin:8px 0 0; max-width:480px; }

/* Sobre */
.sl-split {
  display:grid; grid-template-columns:1.2fr 1fr;
  gap:20px; margin-top:44px;
}
.sl-box {
  border:1px solid var(--sl-line); border-radius:var(--sl-r);
  padding:34px; background:var(--sl-white);
}
.sl-box--dark {
  background:var(--sl-dark); border-color:var(--sl-dark);
  position:relative; overflow:hidden;
}
.sl-box--dark::before {
  content:''; position:absolute;
  top:-50px; right:-50px; width:180px; height:180px;
  border-radius:50%; background:rgba(215,195,162,.1); pointer-events:none;
}
.sl-box h3 {
  font-family:var(--f-display); font-size:22px; font-weight:700;
  margin-bottom:18px; line-height:1.2;
}
.sl-box--dark h3 { color:#fff; }
.sl-box--dark p  { color:rgba(255,255,255,.7); font-size:15px; font-weight:300; margin-bottom:22px; }

.sl-bullets { list-style:none; padding:0; margin:0; }
.sl-bullets li {
  display:flex; align-items:flex-start; gap:12px;
  padding:11px 0; border-bottom:1px solid var(--sl-line);
  color:var(--sl-muted); font-size:15px; font-weight:300; line-height:1.65;
}
.sl-bullets li:last-child { border-bottom:none; }
.sl-bullets li::before { content:'—'; color:var(--sl-accent-dk); font-weight:700; flex-shrink:0; margin-top:1px; }

/* FAQ */
.sl-faq {
  display:grid; grid-template-columns:repeat(2,1fr);
  gap:16px; margin-top:44px;
}
.sl-faq__item {
  border:1px solid var(--sl-line); border-radius:var(--sl-r);
  padding:24px 26px; background:var(--sl-white);
  transition:border-color .2s, box-shadow .2s;
}
.sl-faq__item:hover { border-color:var(--sl-accent); box-shadow:0 6px 20px rgba(0,0,0,.05); }
.sl-faq__q {
  font-family:var(--f-display); font-size:17px; font-weight:700;
  margin-bottom:10px; color:var(--sl-text); line-height:1.3;
}
.sl-faq__a { font-size:15px; font-weight:300; color:var(--sl-muted); line-height:1.8; }

/* CTA final */
.sl-final { background:var(--sl-dark); position:relative; overflow:hidden; }
.sl-final::before {
  content:'SONHO LEVE'; position:absolute;
  font-family:var(--f-display); font-size:130px; font-weight:700;
  letter-spacing:10px; color:rgba(215,195,162,.05);
  white-space:nowrap; top:50%; left:50%;
  transform:translate(-50%,-50%); pointer-events:none;
}
.sl-final__inner {
  display:flex; align-items:center; justify-content:space-between;
  gap:32px; flex-wrap:wrap; padding:64px 0; position:relative; z-index:1;
}
.sl-final__text h2 {
  font-family:var(--f-display); font-size:clamp(24px,3vw,36px);
  font-weight:700; line-height:1.2; color:#fff; margin-bottom:10px;
}
.sl-final__text h2 em { font-style:italic; font-weight:500; color:var(--sl-accent); }
.sl-final__text p { font-size:15px; font-weight:300; color:rgba(255,255,255,.5); }

/* Footer */
.sl-footer { background:#0f0d0a; }
.sl-footer__wrap { max-width:var(--sl-max); margin:0 auto; padding:56px 24px 28px; }
.sl-footer__grid { display:grid; grid-template-columns:1.4fr 1fr 1fr; gap:44px; }

.sl-footer__brand strong {
  font-family:var(--f-display); font-size:26px; font-weight:700;
  letter-spacing:2px; color:var(--sl-accent); display:block; margin-bottom:14px;
}
.sl-footer__brand p { font-size:14px; font-weight:300; color:#9ca3af; line-height:1.8; max-width:270px; }
.sl-footer__brand a {
  display:inline-block; margin-top:12px; color:var(--sl-accent);
  font-size:14px; text-decoration:none;
  border-bottom:1px solid rgba(215,195,162,.3); padding-bottom:1px;
  transition:border-color .2s, color .2s;
}
.sl-footer__brand a:hover { color:#fff; border-color:#fff; }

.sl-footer h4 {
  font-family:var(--f-body); font-size:10.5px; font-weight:700;
  letter-spacing:3px; text-transform:uppercase;
  color:rgba(255,255,255,.35); margin-bottom:18px;
}
.sl-footer ul { list-style:none; }
.sl-footer ul li { margin-bottom:10px; }
.sl-footer ul a {
  color:#9ca3af; text-decoration:none;
  font-size:14px; font-weight:300;
  transition:color .2s, padding-left .2s; display:inline-block;
}
.sl-footer ul a:hover { color:var(--sl-accent); padding-left:4px; }

.sl-footer__bottom {
  border-top:1px solid rgba(255,255,255,.07);
  margin-top:40px; padding-top:20px;
  display:flex; align-items:center; justify-content:space-between;
  flex-wrap:wrap; gap:10px;
  font-size:12.5px; font-weight:300; color:rgba(255,255,255,.25);
}
.sl-footer__bottom a { color:var(--sl-accent); text-decoration:none; opacity:.8; transition:opacity .2s; }
.sl-footer__bottom a:hover { opacity:1; }

/* Animações */
@keyframes fadeUp {
  from { opacity:0; transform:translateY(20px); }
  to   { opacity:1; transform:translateY(0); }
}
.sl-reveal {
  opacity:0; transform:translateY(26px);
  transition:opacity .65s var(--ease), transform .65s var(--ease);
}
.sl-reveal.visible { opacity:1; transform:translateY(0); }
.sl-reveal:nth-child(2) { transition-delay:.1s; }
.sl-reveal:nth-child(3) { transition-delay:.2s; }
.sl-reveal:nth-child(4) { transition-delay:.3s; }

/* ── Responsive: tablet ── */
@media(max-width:1024px){
  .sl-trust__grid     { grid-template-columns:repeat(2,1fr); }
  .sl-trust__item:nth-child(2) { border-right:none; }
  .sl-trust__item:nth-child(3),
  .sl-trust__item:nth-child(4) { border-top:1px solid var(--sl-line); }
  .sl-features        { grid-template-columns:1fr; }
  .sl-products ul.products { grid-template-columns:repeat(2,1fr) !important; }
  .sl-split           { grid-template-columns:1fr; }
  .sl-faq             { grid-template-columns:1fr; }
  .sl-footer__grid    { grid-template-columns:1fr 1fr; }
  .sl-final__inner    { flex-direction:column; align-items:flex-start; }
}

/* ── Responsive: mobile ── */
@media(max-width:768px){
  /* Topbar: logo + ícones na mesma linha, nav em baixo scrollável */
  .sl-topbar__inner {
    grid-template-columns: 1fr auto;
    grid-template-rows: auto auto;
    gap: 0;
    padding: 10px 0;
  }
  .sl-brand            { grid-column:1; grid-row:1; }
  .sl-brand strong     { font-size: 19px; }
  .sl-brand__logo      { width: 36px; height: 36px; }
  .sl-actions          { grid-column:2; grid-row:1; gap:6px; }
  .sl-search           { display:none; } /* pesquisa oculta no mobile */
  .sl-nav {
    grid-column: 1 / -1;
    grid-row: 2;
    justify-content: flex-start;
    gap: 20px;
    padding-top: 10px;
    margin-top: 8px;
    border-top: 1px solid var(--sl-line);
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
    scrollbar-width: none;
    white-space: nowrap;
    flex-wrap: nowrap;
  }
  .sl-nav::-webkit-scrollbar { display:none; }
  .sl-nav a            { font-size: 13px; flex-shrink:0; }

  /* Hero */
  .sl-hero             { min-height: 100svh; align-items: flex-end; }
  .sl-hero__inner      { padding: 24px 0 52px; }
  .sl-hero__logo-wrap  { display: none; } /* remove logo duplicado */
  .sl-hero__eyebrow    { font-size: 10px; padding: 5px 12px; margin-bottom: 14px; }
  .sl-hero__headline   { font-size: clamp(30px, 8vw, 40px); margin-bottom: 12px; }
  .sl-hero__desc       { font-size: 15px; margin-bottom: 24px; line-height: 1.7; }
  .sl-hero .sl-cta     { gap: 8px; }
  .sl-hero .sl-btn     { flex: 1 1 calc(50% - 4px); justify-content: center; min-width: 120px; padding: 13px 16px; }

  /* Trust */
  .sl-trust__item      { padding: 14px 14px; gap: 10px; }
  .sl-trust__icon      { width: 34px; height: 34px; font-size: 15px; }

  /* Secções */
  .sl-section          { padding: 48px 0; }
  .sl-title            { font-size: clamp(22px, 6vw, 30px); }
  .sl-lead             { font-size: 15px; margin-top: 12px; }
  .sl-section-header   { flex-direction: column; align-items: flex-start; gap: 12px; }

  /* Cards */
  .sl-card             { padding: 22px; }
  .sl-card__num        { font-size: 38px; }

  /* Produtos */
  .sl-products ul.products { grid-template-columns: repeat(2,1fr) !important; gap: 12px !important; }

  /* Split/boxes */
  .sl-split            { gap: 12px; }
  .sl-box              { padding: 24px; }

  /* FAQ */
  .sl-faq              { gap: 12px; }
  .sl-faq__item        { padding: 18px 20px; }

  /* CTA final */
  .sl-final__inner     { flex-direction:column; align-items:flex-start; padding:44px 0; gap:20px; }
  .sl-final__text h2   { font-size: clamp(20px, 6vw, 28px); }

  /* Footer */
  .sl-footer__grid     { grid-template-columns: 1fr; gap: 28px; }
  .sl-footer__bottom   { flex-direction: column; align-items: center; text-align: center; }
}

/* ── Ecrãs muito pequenos (<400px) ── */
@media(max-width:400px){
  .sl-hero .sl-btn     { flex: 1 1 100%; }
  .sl-products ul.products { grid-template-columns: 1fr !important; }
}
