/* style.css — Stefani konfigurátor (scoped) */
.stefani-conf{
  --bg:#f7f7f7;
  --card:#ffffff;
  --line:#e6e6e6;
  --text:#111;
  --muted:#666;
  --cta:#0aa3a6;
  --shadow:0 12px 30px rgba(0,0,0,.06);
  --radius:4px;
  --pad:16px;
  --gap:12px;
  font-family: system-ui, -apple-system, Segoe UI, Roboto, Helvetica, Arial, "Noto Sans", "Apple Color Emoji","Segoe UI Emoji";
  color:var(--text);
  width:100%;
  max-width:650px;
}

.stefani-conf *{ box-sizing:border-box; }

.stefani-conf .page{
  width:100%;
}

.stefani-conf .stack{
  display:flex;
  flex-direction:column;
  gap:16px;
}

.stefani-conf .card{
  background:var(--card);
  border:1px solid var(--line);
  border-radius:var(--radius);
  box-shadow:var(--shadow);
  padding:var(--pad);
}

.stefani-conf .card__head{
  display:flex;
  flex-direction:column;
  gap:8px;
  margin-bottom:12px;
}

.stefani-conf .card__title{
  font-size:20px;
  letter-spacing:.02em;
  margin:0;
}

.stefani-conf .card__rule{
  height:2px;
  width:48px;
  background:var(--text);
  opacity:.9;
}

.stefani-conf .card__grid{
  display:grid;
  grid-template-columns: 1fr 1fr;
  gap:14px 18px;
  align-items:start;
}

.stefani-conf .col{
  display:flex;
  flex-direction:column;
  gap:12px;
}

.stefani-conf .field{
  display:flex;
  flex-direction:column;
  gap:8px;
}

.stefani-conf .label{
  font-size:13px;
  font-weight:600;
}

.stefani-conf .select, 
.stefani-conf select,
.stefani-conf input[type="text"],
.stefani-conf textarea{
  width:100%;
  border:1px solid var(--line);
  border-radius:4px;
  padding:10px 12px;
  font-size:14px;
  background:#fff;
}

.stefani-conf textarea{ min-height:44px; resize:vertical; }

.stefani-conf .swatches{
  display:flex;
  gap:10px;
  flex-wrap:wrap;
}

.stefani-conf .swatch{
  width:30px;
  height:30px;
  border-radius:4px;
  border:1px solid var(--line);
  cursor:pointer;
  position:relative;
}

.stefani-conf .swatch[aria-checked="true"]::after{
  content:"";
  position:absolute;
  inset:-3px;
  border:2px solid var(--cta);
  border-radius:6px;
}

.stefani-conf .priceRow{
  display:flex;
  align-items:baseline;
  justify-content:space-between;
  gap:12px;
  margin-top:12px;
}

.stefani-conf .priceLabel{ color:var(--muted); font-size:13px; }
.stefani-conf .priceValue{ font-weight:700; font-size:20px; }

.stefani-conf .pairTotal{
  background:var(--card);
  border:1px solid var(--line);
  border-radius:var(--radius);
  box-shadow:var(--shadow);
  padding:14px 16px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
}

.stefani-conf .pairTotal__left{
  display:flex;
  flex-direction:column;
  gap:4px;
}

.stefani-conf .pairTotal__title{
  font-size:13px;
  color:var(--muted);
}

.stefani-conf .pairTotal__value{
  font-size:22px;
  font-weight:800;
}

.stefani-conf .btn{
  background:var(--cta);
  color:#fff;
  border:0;
  border-radius:4px;
  padding:12px 14px;
  font-size:14px;
  font-weight:700;
  cursor:pointer;
  white-space:nowrap;
}

.stefani-conf .btn[disabled]{
  opacity:.55;
  cursor:not-allowed;
}

.stefani-conf .hint{
  font-size:12px;
  color:var(--muted);
  margin-top:6px;
}

/* Mobile */
@media (max-width: 768px){
  .stefani-conf{ max-width:100%; }
  .stefani-conf .card__grid{ grid-template-columns: 1fr; }
}
