/* Driftwell — ruhiges, nächtliches Premium-Design für eine Schlaf-Marke. */
:root{
  --bg:#0b0d1a;            /* tiefe Nacht */
  --bg-2:#11142a;
  --panel:#151931;
  --panel-2:#1b2040;
  --ink:#eef0ff;           /* fast-weiß, leicht blau */
  --muted:#9aa0c7;
  --line:rgba(255,255,255,.08);
  --accent:#8a7bff;
  --accent-soft:#b9adff;
  --radius:18px;
  --maxw:1120px;
  --shadow:0 24px 60px rgba(0,0,0,.45);
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:'Inter',system-ui,-apple-system,Segoe UI,Roboto,sans-serif;
  color:var(--ink);
  background:
    radial-gradient(1200px 600px at 80% -10%, rgba(138,123,255,.18), transparent 60%),
    radial-gradient(900px 500px at 10% 0%, rgba(86,120,255,.12), transparent 55%),
    linear-gradient(180deg,#0b0d1a 0%, #0a0c17 100%);
  background-attachment:fixed;
  line-height:1.55;
  -webkit-font-smoothing:antialiased;
}
a{color:inherit;text-decoration:none}
.muted{color:var(--muted)}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 24px}

h1,h2,h3{font-family:'Fraunces',Georgia,serif;font-weight:500;letter-spacing:-.01em;line-height:1.08;margin:0}
h1{font-size:clamp(2.3rem,5vw,4rem)}
h2{font-size:clamp(1.8rem,3.4vw,2.7rem)}
p{margin:.6em 0}

/* ---------- Nav ---------- */
.nav{
  position:sticky;top:0;z-index:50;
  display:flex;align-items:center;justify-content:space-between;
  max-width:var(--maxw);margin:0 auto;padding:18px 24px;
  backdrop-filter:saturate(140%) blur(8px);
}
.brand{font-family:'Fraunces',serif;font-size:1.4rem;font-weight:600;letter-spacing:-.02em}
.brand.small{font-size:1.15rem}
.nav nav{display:flex;align-items:center;gap:26px;font-size:.95rem}
.nav nav a{color:var(--muted);transition:color .2s}
.nav nav a:hover{color:var(--ink)}
.nav-cta{
  color:var(--ink)!important;border:1px solid var(--line);
  padding:8px 16px;border-radius:999px;background:rgba(255,255,255,.03);
}
.nav-cta:hover{border-color:var(--accent);background:rgba(138,123,255,.12)}

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:.5em;
  font:inherit;font-weight:600;cursor:pointer;border:0;
  padding:15px 28px;border-radius:999px;
  color:#0b0d1a;background:linear-gradient(180deg,var(--accent-soft),var(--accent));
  box-shadow:0 10px 30px rgba(138,123,255,.35);
  transition:transform .15s ease, box-shadow .2s ease, opacity .2s;
}
.btn:hover{transform:translateY(-2px);box-shadow:0 16px 40px rgba(138,123,255,.5)}
.btn:disabled{opacity:.6;cursor:default;transform:none}
.btn.ghost{
  color:var(--ink);background:transparent;border:1px solid var(--line);box-shadow:none;
}
.btn.ghost:hover{border-color:var(--accent);background:rgba(138,123,255,.1)}
.btn.block{width:100%}

/* ---------- Hero ---------- */
.hero{padding:48px 0 30px;max-width:var(--maxw);margin:0 auto}
.hero.with-bg{background-image:linear-gradient(rgba(11,13,26,.72),rgba(11,13,26,.95)),var(--herobg);background-size:cover;background-position:center;border-radius:0 0 30px 30px;padding:64px 30px 44px}
.hero-inner{max-width:760px}
.eyebrow{
  display:inline-block;font-size:.82rem;letter-spacing:.14em;text-transform:uppercase;
  color:var(--accent-soft);border:1px solid var(--line);border-radius:999px;
  padding:6px 14px;margin-bottom:22px;background:rgba(138,123,255,.08);
}
.hero h1{margin-bottom:18px}
.hero .lead{font-size:1.2rem;color:var(--muted);max-width:620px}
.hero-cta{display:flex;align-items:center;gap:18px;flex-wrap:wrap;margin-top:30px}
.hero .note{font-size:.9rem;color:var(--muted)}
.moon{
  position:absolute;right:6%;top:90px;width:120px;height:120px;border-radius:50%;
  background:radial-gradient(circle at 35% 35%, #fff, var(--accent-soft) 55%, var(--accent) 100%);
  box-shadow:0 0 80px 20px rgba(138,123,255,.35);opacity:.9;
}
@media(max-width:760px){.moon{display:none}}

/* ---------- Value props ---------- */
.values{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin:54px auto;max-width:var(--maxw);padding:0 24px}
.value{
  background:linear-gradient(180deg,var(--panel),var(--bg-2));
  border:1px solid var(--line);border-radius:var(--radius);padding:26px;
}
.value .ic{font-size:1.7rem}
.value h3{font-size:1.18rem;margin:12px 0 8px}
.value p{color:var(--muted);font-size:.96rem;margin:0}
@media(max-width:780px){.values{grid-template-columns:1fr}}

/* ---------- Section heading ---------- */
.section{max-width:var(--maxw);margin:0 auto;padding:60px 24px}
.section-head{max-width:600px;margin-bottom:34px}
.section-head p{color:var(--muted)}

/* ---------- Product grid ---------- */
.grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px}
.grid.feat{grid-template-columns:1.3fr 1fr 1fr}
@media(max-width:980px){.grid,.grid.feat{grid-template-columns:repeat(2,1fr)}}
@media(max-width:560px){.grid,.grid.feat{grid-template-columns:1fr}}
.card{
  display:flex;flex-direction:column;
  background:linear-gradient(180deg,var(--panel),var(--bg-2));
  border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;
  transition:transform .18s ease, border-color .2s;
}
.card:hover{transform:translateY(-4px);border-color:rgba(138,123,255,.45)}
.thumb{
  aspect-ratio:4/3;display:flex;align-items:center;justify-content:center;
  font-size:3.4rem;position:relative;
  background-image:var(--thumb,linear-gradient(135deg,#26305e,#161a33));
  background-size:cover;background-position:center;
}
.thumb .badge{
  position:absolute;top:12px;left:12px;font-size:.74rem;font-weight:600;
  background:var(--accent);color:#0b0d1a;padding:5px 11px;border-radius:999px;
}
.card-body{padding:18px 18px 20px;display:flex;flex-direction:column;gap:8px;flex:1}
.card-body h3{font-size:1.16rem}
.card-body .desc{color:var(--muted);font-size:.92rem;flex:1}
.price{display:flex;align-items:baseline;gap:10px;margin-top:6px}
.price .now{font-size:1.3rem;font-weight:600;font-family:'Fraunces',serif}
.price .was{color:var(--muted);text-decoration:line-through;font-size:.95rem}
.card .btn{margin-top:12px}
.card-actions{margin-top:12px;display:flex;flex-direction:column;gap:8px}
.card-actions .btn{margin-top:0}

/* ---------- Trust bar ---------- */
.trust{
  display:flex;flex-wrap:wrap;justify-content:center;gap:34px;
  border-top:1px solid var(--line);border-bottom:1px solid var(--line);
  padding:22px 24px;margin:10px 0;color:var(--muted);font-size:.95rem;
}

/* ---------- Testimonials ---------- */
.quotes{display:grid;grid-template-columns:repeat(2,1fr);gap:18px}
@media(max-width:680px){.quotes{grid-template-columns:1fr}}
.quote{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);padding:24px}
.stars{color:var(--accent-soft);letter-spacing:2px;margin-bottom:8px}
.quote .who{color:var(--muted);font-size:.9rem;margin-top:10px}

/* ---------- FAQ ---------- */
.faq{max-width:760px}
.faq details{border:1px solid var(--line);border-radius:14px;padding:4px 20px;margin-bottom:12px;background:var(--panel)}
.faq summary{cursor:pointer;list-style:none;padding:16px 0;font-weight:600;display:flex;justify-content:space-between;align-items:center}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:'+';color:var(--accent-soft);font-size:1.4rem;transition:transform .2s}
.faq details[open] summary::after{transform:rotate(45deg)}
.faq details p{color:var(--muted);margin:0 0 18px}

/* ---------- Final CTA ---------- */
.cta-band{
  max-width:var(--maxw);margin:40px auto;padding:56px 24px;text-align:center;
  background:radial-gradient(600px 300px at 50% 0%, rgba(138,123,255,.22), transparent 70%),linear-gradient(180deg,var(--panel),var(--bg-2));
  border:1px solid var(--line);border-radius:26px;
}
.cta-band p{color:var(--muted);max-width:520px;margin:14px auto 26px}

/* ---------- Product detail ---------- */
.pdp{max-width:var(--maxw);margin:0 auto;padding:40px 24px;display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:start}
@media(max-width:860px){.pdp{grid-template-columns:1fr;gap:28px}}
.pdp .hero-img{aspect-ratio:1/1;border-radius:24px;display:flex;align-items:center;justify-content:center;font-size:6rem;border:1px solid var(--line);background-image:var(--thumb,linear-gradient(135deg,#26305e,#161a33))}
.pdp h1{font-size:clamp(1.9rem,3.4vw,2.6rem);margin-bottom:10px}
.pdp .sub{color:var(--muted);font-size:1.05rem}
.pdp .price{margin:22px 0}
.pdp .price .now{font-size:1.7rem}
.pdp ul{list-style:none;padding:0;margin:24px 0;display:grid;gap:12px}
.pdp li{padding-left:30px;position:relative;color:var(--ink)}
.pdp li::before{content:'✓';position:absolute;left:0;color:var(--accent-soft);font-weight:700}
.back{color:var(--muted);font-size:.9rem;display:inline-block;margin-bottom:18px}

/* ---------- Centered message pages ---------- */
.msg{max-width:560px;margin:0 auto;padding:90px 24px;text-align:center}
.msg .big{font-size:3rem;margin-bottom:8px}
.msg p{color:var(--muted)}

/* ---------- Navi-Warenkorb ---------- */
.nav-cart{color:var(--ink)!important;border:1px solid var(--line);padding:8px 15px;border-radius:999px;background:rgba(255,255,255,.03);font-weight:600}
.nav-cart:hover{border-color:var(--accent);background:rgba(138,123,255,.12)}
#cart-count{display:inline-block;min-width:18px;text-align:center;color:var(--accent-soft)}

/* ---------- Toast ---------- */
.toast{position:fixed;left:50%;bottom:28px;transform:translateX(-50%) translateY(20px);
  background:linear-gradient(180deg,var(--panel-2),var(--panel));border:1px solid var(--line);
  color:var(--ink);padding:13px 22px;border-radius:999px;box-shadow:var(--shadow);
  opacity:0;pointer-events:none;transition:opacity .25s,transform .25s;z-index:120;font-weight:500}
.toast.show{opacity:1;transform:translateX(-50%) translateY(0)}

/* ---------- Produkt-Detail Buttons ---------- */
.pdp-actions{display:flex;flex-direction:column;gap:10px}

/* ---------- Warenkorb-Seite ---------- */
.cart-layout{display:grid;grid-template-columns:1fr 320px;gap:30px;align-items:start}
@media(max-width:780px){.cart-layout{grid-template-columns:1fr}}
.cart-empty{font-size:1.1rem;padding:30px 0}
.cart-empty a{color:var(--accent-soft)}
.cart-row{display:grid;grid-template-columns:72px 1fr auto auto auto;gap:16px;align-items:center;
  background:var(--panel);border:1px solid var(--line);border-radius:14px;padding:12px 16px;margin-bottom:12px}
.cart-thumb{display:block;width:72px;height:72px;border-radius:10px;background-size:cover;background-position:center;background-color:#1a1f3a}
.cart-name{display:block;font-weight:600;margin-bottom:3px;color:var(--ink)}
.cart-name:hover{color:var(--accent-soft)}
.qty{display:flex;align-items:center;gap:6px}
.qty button{width:30px;height:30px;border-radius:8px;border:1px solid var(--line);background:rgba(255,255,255,.04);
  color:var(--ink);font-size:1.1rem;cursor:pointer;line-height:1}
.qty button:hover{border-color:var(--accent);background:rgba(138,123,255,.12)}
.qty span{min-width:22px;text-align:center}
.cart-line{font-weight:600;font-family:'Fraunces',serif;min-width:74px;text-align:right}
.cart-x{background:none;border:0;color:var(--muted);cursor:pointer;font-size:1rem;padding:6px}
.cart-x:hover{color:#e5534b}
.cart-summary{background:linear-gradient(180deg,var(--panel),var(--bg-2));border:1px solid var(--line);
  border-radius:18px;padding:24px;position:sticky;top:90px}
.cart-total{display:flex;justify-content:space-between;align-items:baseline;font-size:1.2rem;font-weight:600;
  font-family:'Fraunces',serif;margin-bottom:4px}
.cart-continue{display:block;text-align:center;margin-top:14px;font-size:.9rem}
.cart-continue:hover{color:var(--ink)}
@media(max-width:560px){.cart-row{grid-template-columns:56px 1fr auto;row-gap:8px}
  .cart-thumb{width:56px;height:56px}.cart-line{grid-column:2/4;text-align:left;min-width:0}.cart-x{position:absolute}}

/* ---------- Sterne / Produkt-Detail ---------- */
.card-stars{color:var(--accent-soft);font-size:.9rem;letter-spacing:1px;margin:-2px 0 2px}
.rating-line{display:flex;align-items:center;gap:10px;margin:6px 0 2px}
.rating-line .stars{color:var(--accent-soft);letter-spacing:2px}
.rating-line .muted{font-size:.9rem}
.pdp-desc{margin-top:22px}
.pdp-desc p{color:var(--muted)}
.info-block{margin-top:26px;border-top:1px solid var(--line);padding-top:18px}
.info-block h3{font-size:1.05rem;margin-bottom:6px}

/* ---------- Rechtstexte ---------- */
.legal{max-width:760px}
.legal h3{font-size:1.12rem;margin:26px 0 6px}
.legal p{color:var(--muted);word-break:break-word}

/* ---------- Footer ---------- */
.footer{border-top:1px solid var(--line);margin-top:50px;padding:40px 24px 30px}
.footer-inner{max-width:var(--maxw);margin:0 auto;display:flex;justify-content:space-between;gap:30px;flex-wrap:wrap}
.foot-links{display:flex;gap:22px;align-items:center;color:var(--muted);flex-wrap:wrap}
.foot-links a:hover{color:var(--ink)}
.foot-legal{max-width:var(--maxw);margin:26px auto 0;font-size:.82rem;text-align:center}

/* ---------- 'Bald' Modal ---------- */
.modal{position:fixed;inset:0;background:rgba(5,6,15,.7);backdrop-filter:blur(4px);display:none;align-items:center;justify-content:center;z-index:100;padding:24px}
.modal.open{display:flex}
.modal-card{background:linear-gradient(180deg,var(--panel-2),var(--panel));border:1px solid var(--line);border-radius:22px;padding:34px;max-width:420px;text-align:center;box-shadow:var(--shadow)}
.modal-card h3{font-size:1.5rem;margin-bottom:6px}
.modal-card p{color:var(--muted);margin-bottom:22px}
