/* ============================================================
   demo.css — styles for the Demos feature (loaded only on demo pages)
   Brand colours come from --demo-* vars set inline on .demo-root.
   Builds on theme.css (reset, Inter, tokens).
   ============================================================ */

.demo-root {
  --demo-primary:#1E88C4;
  --demo-dark:#0C2233;
  --demo-accent:#FFD25A;
  font-family:'Inter',system-ui,sans-serif;
  color:#3a4753;
}
.demo-wrap { max-width:1080px; margin:0 auto; padding:0 24px; }
@media(max-width:560px){ .demo-wrap { padding:0 18px; } }

/* ----- Demo bar ----- */
.demo-bar {
  background:#16202A; color:#fff;
  display:flex; align-items:center; justify-content:center; gap:18px; flex-wrap:wrap;
  padding:9px 16px; font-size:.8rem;
}
.demo-bar__label { color:#cfd6dd; }
.demo-bar__cta { color:#FEB913; font-weight:700; }

/* ----- Demo nav ----- */
.demo-nav { background:var(--demo-dark); }
.demo-nav__inner {
  display:flex; align-items:center; justify-content:space-between;
  gap:16px; padding:15px 0;
}
.demo-brand { display:flex; align-items:center; gap:10px; }
.demo-brand__mark {
  width:36px; height:36px; border-radius:9px;
  background:rgba(255,255,255,.12);
  display:flex; align-items:center; justify-content:center; font-size:1.1rem;
}
.demo-brand__name { color:#fff; font-weight:800; font-size:1.1rem; letter-spacing:-.02em; }
.demo-nav__links { display:flex; gap:22px; }
.demo-nav__links a { color:rgba(255,255,255,.72); font-size:.88rem; font-weight:500; }
.demo-nav__links a:hover { color:#fff; }
.demo-nav__phone {
  color:#fff; font-size:.84rem; font-weight:600;
  background:rgba(255,255,255,.1); padding:9px 14px; border-radius:8px; white-space:nowrap;
}
@media(max-width:620px){ .demo-nav__links { display:none; } }

/* ----- Demo hero ----- */
.demo-hero {
  background:linear-gradient(158deg, var(--demo-dark) 32%, var(--demo-primary));
  padding:56px 0;
}
.demo-hero__inner {
  display:grid; grid-template-columns:1.1fr .9fr; gap:32px; align-items:center;
}
.demo-hero__eyebrow {
  font-size:.72rem; font-weight:800; letter-spacing:.09em; text-transform:uppercase;
  color:var(--demo-accent);
}
.demo-hero__title {
  font-size:clamp(2rem,1.4rem + 2.4vw,2.85rem); font-weight:900; color:#fff;
  letter-spacing:-.03em; line-height:1.12; margin:11px 0 11px;
}
.demo-hero__sub { font-size:1rem; color:rgba(255,255,255,.82); max-width:390px; line-height:1.6; }
.demo-hero__art {
  font-size:5.5rem; text-align:center; line-height:1;
  background:rgba(255,255,255,.06); border:1px solid rgba(255,255,255,.1);
  border-radius:16px; padding:36px 0;
}
@media(max-width:720px){
  .demo-hero__inner { grid-template-columns:1fr; gap:24px; }
  .demo-hero__sub { max-width:none; }
}

/* ----- Demo buttons ----- */
.demo-btn {
  display:inline-block; font-weight:800; font-size:.9rem;
  padding:13px 22px; border-radius:9px; cursor:pointer;
  background:var(--demo-accent); color:var(--demo-dark);
  transition:transform .12s;
}
.demo-btn:hover { transform:translateY(-2px); }
.demo-btn--lg { font-size:.95rem; padding:14px 26px; }
.demo-btn--primary { background:var(--demo-primary); color:#fff; }
.demo-btn--block { display:block; width:100%; text-align:center; border:none; }

/* ----- Widgets section ----- */
.demo-section { padding:54px 0; background:#F6F8FA; }
.demo-section__head { text-align:center; max-width:560px; margin:0 auto 28px; }
.demo-section__head h2 {
  font-size:1.5rem; font-weight:800; color:var(--demo-dark); letter-spacing:-.02em;
}
.demo-section__head p { font-size:.95rem; color:#5C6B7A; margin-top:7px; }
.demo-widgets { display:flex; flex-direction:column; align-items:center; gap:22px; }
.demo-widget {
  width:100%; max-width:680px;
  background:#fff; border:1px solid #E7ECF0; border-radius:14px;
  box-shadow:0 14px 38px -22px rgba(20,30,45,.3);
  padding:24px;
}
.demo-widget__eyebrow {
  font-size:.7rem; font-weight:800; letter-spacing:.09em; text-transform:uppercase;
  color:var(--demo-primary);
}
.demo-widget__title {
  font-size:1.2rem; font-weight:800; color:var(--demo-dark);
  letter-spacing:-.02em; margin:4px 0 16px;
}
.demo-widget__text { font-size:.9rem; color:#5C6B7A; margin:-10px 0 16px; line-height:1.55; }

/* ----- Demo footer ----- */
.demo-footer { background:var(--demo-dark); padding:24px 0; }
.demo-footer__inner {
  display:flex; justify-content:space-between; align-items:center;
  gap:14px; flex-wrap:wrap; font-size:.83rem; color:rgba(255,255,255,.6);
}
.demo-footer__brand { color:#fff; font-weight:700; display:flex; gap:7px; align-items:center; }
.demo-footer__by a { color:var(--demo-accent); font-weight:600; }

/* ============================================================
   Widgets
   ============================================================ */
.demo-input {
  font-family:inherit; font-size:.9rem; color:var(--demo-dark);
  background:#F6F8FA; border:1px solid #E2E7EC; border-radius:8px;
  padding:11px 12px; width:100%;
}
.demo-input:focus { outline:2px solid var(--demo-primary); outline-offset:1px; background:#fff; }

/* ----- Calculator ----- */
.calc__services { display:flex; gap:9px; flex-wrap:wrap; margin-bottom:16px; }
.calc__svc {
  flex:1; min-width:100px; padding:11px 8px; text-align:center;
  border:1.5px solid #E2E7EC; border-radius:9px; background:#fff;
  font-size:.84rem; font-weight:700; color:#5C6B7A; cursor:pointer; transition:.12s;
}
.calc__svc:hover { border-color:var(--demo-primary); }
.calc__svc.is-on {
  border-color:var(--demo-primary); color:var(--demo-dark);
  box-shadow:inset 0 0 0 1px var(--demo-primary);
}
.calc__qty {
  display:flex; align-items:center; justify-content:space-between;
  gap:12px; margin-bottom:16px; flex-wrap:wrap;
}
.calc__qty-label { font-size:.85rem; font-weight:600; color:#5C6B7A; }
.calc__stepper { display:flex; align-items:center; gap:12px; }
.calc__step {
  width:36px; height:36px; border-radius:8px; border:1.5px solid #E2E7EC;
  background:#fff; font-size:1.2rem; font-weight:700; color:var(--demo-primary);
  cursor:pointer; display:flex; align-items:center; justify-content:center;
}
.calc__step:hover { border-color:var(--demo-primary); }
.calc__q { font-size:1.1rem; font-weight:800; color:var(--demo-dark); min-width:34px; text-align:center; }
.calc__result {
  background:var(--demo-dark); border-radius:11px; padding:16px 18px;
  display:flex; align-items:center; justify-content:space-between; gap:12px; flex-wrap:wrap;
}
.calc__result-label { font-size:.68rem; text-transform:uppercase; letter-spacing:.06em; color:rgba(255,255,255,.6); }
.calc__out { font-size:1.4rem; font-weight:900; color:#fff; letter-spacing:-.02em; }

/* ----- Photo-upload ----- */
.pu__drop {
  display:block; text-align:center; cursor:pointer;
  border:2px dashed #D5DCE3; border-radius:11px; padding:22px;
  transition:.12s; margin-bottom:12px;
}
.pu__drop:hover { border-color:var(--demo-primary); background:rgba(0,0,0,.015); }
.pu__icon { font-size:1.8rem; display:block; }
.pu__droptext { font-size:.85rem; color:#5C6B7A; font-weight:600; display:block; margin-top:6px; word-break:break-word; }
.pu__thumb {
  display:none; width:76px; height:76px; margin:10px auto 0;
  border-radius:9px; background-size:cover; background-position:center;
  border:2px solid var(--demo-primary);
}
.pu__thumb.is-shown { display:block; }
.pu__row { display:grid; grid-template-columns:1fr 1fr; gap:10px; margin-bottom:11px; }
.pu__done, .bk__done { text-align:center; padding:18px 8px; }
.pu__done-icon { font-size:2.4rem; }
.pu__done-title { font-size:1.05rem; font-weight:800; color:var(--demo-dark); margin:6px 0 3px; }
.pu__done-text { font-size:.85rem; color:#5C6B7A; }

/* ----- Booking ----- */
.bk__group { margin-bottom:15px; }
.bk__label { font-size:.78rem; font-weight:700; color:#5C6B7A; display:block; margin-bottom:8px; }
.bk__chips { display:flex; gap:8px; flex-wrap:wrap; }
.bk__chip {
  padding:9px 14px; border:1.5px solid #E2E7EC; border-radius:8px; background:#fff;
  font-size:.82rem; font-weight:600; color:#5C6B7A; cursor:pointer; transition:.12s;
}
.bk__chip:hover { border-color:var(--demo-primary); }
.bk__chip.is-on { border-color:var(--demo-primary); background:var(--demo-primary); color:#fff; }
.bk__row { display:grid; grid-template-columns:1fr 1fr; gap:10px; margin-bottom:13px; }
.bk__submit:disabled { opacity:.5; cursor:not-allowed; }

/* ----- Selector ----- */
.sel__grid { display:grid; grid-template-columns:1fr 1fr; gap:10px; margin-bottom:14px; }
.sel__opt {
  padding:16px 12px; border:1.5px solid #E2E7EC; border-radius:10px; background:#fff;
  font-size:.9rem; font-weight:700; color:#5C6B7A; cursor:pointer; transition:.12s; text-align:center;
}
.sel__opt:hover { border-color:var(--demo-primary); }
.sel__opt.is-on { border-color:var(--demo-primary); background:var(--demo-primary); color:#fff; }
.sel__summary { font-size:.9rem; color:#5C6B7A; text-align:center; margin-bottom:14px; }
.sel__summary strong { color:var(--demo-dark); }

/* ----- Before/after ----- */
.ba__viewer {
  position:relative; height:248px; border-radius:11px; overflow:hidden;
  margin-bottom:12px; user-select:none;
}
.ba__layer { position:absolute; inset:0; display:flex; align-items:flex-start; }
.ba__after { background:linear-gradient(135deg, var(--demo-primary), var(--demo-accent)); }
.ba__before { background:linear-gradient(135deg,#9aa6b0,#6b7885); }
.ba__tag {
  margin:12px; font-size:.66rem; font-weight:800; text-transform:uppercase; letter-spacing:.06em;
  background:rgba(0,0,0,.34); color:#fff; padding:5px 10px; border-radius:6px;
}
.ba__after .ba__tag { margin-left:auto; }
.ba__divider {
  position:absolute; top:0; bottom:0; left:50%; width:3px; background:#fff;
  pointer-events:none; z-index:2;
}
.ba__grip {
  position:absolute; top:50%; left:50%; transform:translate(-50%,-50%);
  width:40px; height:40px; border-radius:50%; background:#fff;
  box-shadow:0 2px 8px rgba(0,0,0,.3);
  display:flex; align-items:center; justify-content:center;
  color:var(--demo-primary); font-size:.85rem; font-weight:900;
}
.ba__grip::before { content:"\2039\00A0\203A"; }
.ba__viewer:focus-within .ba__grip { outline:3px solid var(--demo-primary); outline-offset:3px; }
/* Invisible range input overlaying the whole viewer — drag anywhere on the image. */
.ba__range {
  position:absolute; inset:0; width:100%; height:100%; margin:0;
  -webkit-appearance:none; appearance:none;
  background:transparent; cursor:ew-resize; z-index:3;
}
.ba__range:focus { outline:none; }
.ba__range::-webkit-slider-thumb {
  -webkit-appearance:none; appearance:none;
  width:44px; height:248px; background:transparent; border:0; cursor:ew-resize;
}
.ba__range::-moz-range-thumb {
  width:44px; height:248px; background:transparent; border:0; cursor:ew-resize;
}
.ba__range::-moz-range-track { background:transparent; border:0; }

@media(max-width:460px){
  .pu__row, .bk__row, .sel__grid { grid-template-columns:1fr; }
}
