:root{
  --bg:#F8F7F4;
  --text:#171717;
  --muted:rgba(23,23,23,.72);
  --line:#E7E3DD;
  --glass:rgba(255,255,255,0.65);
  --violet:#7B5CFF;
  --night:#10172A;
  --cosmic:#243B80;
  --shadow:0 14px 40px rgba(16,23,42,.10);
  --shadow-soft:0 10px 26px rgba(16,23,42,.08);
  --radius:18px;
  --radius-sm:12px;
  --container:1120px;
  --holo:linear-gradient(135deg, rgba(123,92,255,.55), rgba(48,220,255,.42), rgba(255,110,199,.35));
}

*{box-sizing:border-box}
html,body{height:100%}
body{
  margin:0;
  color:var(--text);
  font-family:'Alice', serif;
  line-height:1.65;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}

img{max-width:100%; height:auto}
a{color:inherit; text-decoration:none}
a:focus-visible, button:focus-visible, input:focus-visible, textarea:focus-visible, select:focus-visible{
  outline:2px solid rgba(123,92,255,.55);
  outline-offset:3px;
  border-radius:10px;
}
.screen-reader-text{position:absolute;left:-9999px;top:auto;width:1px;height:1px;overflow:hidden}
.skip-link:focus{
  left:22px; top:18px; width:auto; height:auto;
  padding:10px 12px;
  background:rgba(255,255,255,.95);
  border:1px solid var(--line);
  border-radius:14px;
  box-shadow:var(--shadow-soft);
  z-index:100;
}
.container{max-width:var(--container); margin:0 auto; padding:0 22px}

.section{padding:92px 0}
.section--tight{padding:56px 0}
.section--alt{background:linear-gradient(180deg, rgba(255,255,255,.0), rgba(255,255,255,.55)); border-top:1px solid var(--line); border-bottom:1px solid var(--line)}
.section-header{max-width:860px}
.section-header .muted{max-width:760px}

.display{font-size:clamp(44px, 6vw, 72px); line-height:1.05; margin:10px 0 10px}
.h2{font-size:clamp(28px, 3vw, 40px); line-height:1.2; margin:0 0 10px}
.h3{font-size:clamp(22px, 2.4vw, 30px); line-height:1.25; margin:0 0 10px}
.h4{font-size:20px; line-height:1.3; margin:0 0 8px}
.h5{font-size:18px; margin:0 0 8px}
.h6{font-size:15px; letter-spacing:.04em; text-transform:uppercase; margin:0 0 10px}
.lead{font-size:clamp(18px, 2vw, 22px); margin:0 0 10px}
.muted{color:var(--muted)}
.muted-on-dark{color:rgba(255,255,255,.72)}
.small{font-size:14px}
.eyebrow{display:inline-flex; gap:10px; align-items:center; font-size:14px; letter-spacing:.04em; text-transform:uppercase; color:rgba(23,23,23,.72); margin:0}
.eyebrow::before{content:""; width:18px; height:1px; background:rgba(123,92,255,.65)}

.site-header{
  position:sticky; top:0; z-index:40;
  background:rgba(248,247,244,.75);
  backdrop-filter:saturate(160%) blur(14px);
  border-bottom:1px solid rgba(231,227,221,.8);
}
.header-inner{display:flex; align-items:center; justify-content:space-between; gap:20px; min-height:74px}
.brand{display:flex; flex-direction:column; gap:2px}
.brand-row{display:flex; align-items:center; gap:14px}
.brand-name{font-size:20px; letter-spacing:.02em; line-height:1.1; white-space:nowrap}
.brand-tagline{margin:0; font-size:12px; color:rgba(23,23,23,.64)}
.brand-logo img{display:block; max-width:var(--logo-max-width, 240px); max-height:var(--logo-max-height, 44px); width:auto; height:auto}

.site-nav{display:flex; align-items:center; gap:16px}
.site-nav ul{list-style:none; display:flex; gap:12px; margin:0; padding:0; align-items:center}
.site-nav li{margin:0}
.nav-link{display:inline-flex; padding:10px 12px; border-radius:12px}
.nav-link:hover{background:rgba(255,255,255,.6)}

.nav-toggle{
  display:none; align-items:center; gap:10px;
  border:1px solid var(--line); background:rgba(255,255,255,.55);
  padding:10px 12px; border-radius:14px; cursor:pointer;
}
.nav-toggle__icon{
  width:18px; height:12px; position:relative; display:inline-block;
}
.nav-toggle__icon::before,.nav-toggle__icon::after{
  content:""; position:absolute; left:0; right:0; height:1px; background:rgba(23,23,23,.65);
}
.nav-toggle__icon::before{top:2px}
.nav-toggle__icon::after{bottom:2px}

.hero{padding:92px 0 56px}
.hero-inner{display:grid; grid-template-columns: 1.05fr .95fr; gap:44px; align-items:center}
.hero-actions{display:flex; gap:12px; margin-top:18px; flex-wrap:wrap}
.hero-visual{display:flex; justify-content:flex-end}

.button{
  display:inline-flex; align-items:center; justify-content:center; gap:10px;
  border-radius:999px; padding:12px 18px;
  border:1px solid rgba(231,227,221,.95);
  background:rgba(255,255,255,.62);
  box-shadow:0 8px 20px rgba(16,23,42,.06);
  transition:transform .18s ease, box-shadow .18s ease, background .18s ease, border-color .18s ease;
  font-size:15px;
}
.button--primary{
  border-color:rgba(123,92,255,.35);
  background:linear-gradient(180deg, rgba(123,92,255,.16), rgba(255,255,255,.68));
}
.button--ghost{background:transparent; box-shadow:none}
.button--sm{padding:10px 14px; font-size:14px}
.button--lg{padding:14px 22px; font-size:16px}
.button:hover{transform:translateY(-1px); box-shadow:var(--shadow-soft); background:rgba(255,255,255,.78)}
.button--ghost:hover{background:rgba(255,255,255,.55)}

.badge{
  display:inline-flex; align-items:center; gap:8px;
  border-radius:999px; padding:8px 12px;
  border:1px solid rgba(231,227,221,.9);
  background:rgba(255,255,255,.55);
  font-size:13px;
}
.badge--holo{background:linear-gradient(180deg, rgba(255,255,255,.65), rgba(255,255,255,.4)); position:relative}
.badge--holo::after{
  content:""; position:absolute; inset:-1px; border-radius:999px;
  background:var(--holo); opacity:.55; filter:blur(10px); z-index:-1;
}

.card{
  border:1px solid rgba(231,227,221,.95);
  background:rgba(255,255,255,.55);
  border-radius:var(--radius);
  box-shadow:0 10px 26px rgba(16,23,42,.06);
}
.card--soft{padding:22px}
.card--hover{overflow:hidden}
.card--hover:hover{box-shadow:var(--shadow)}
.card__link{display:block}
.card__media img{display:block; width:100%; height:auto}
.card__body{padding:22px}
.card__title{margin:0 0 6px}
.card__excerpt{margin:10px 0 0}

.grid{display:grid; gap:16px}
.grid--3{grid-template-columns:repeat(3, minmax(0,1fr))}
.grid--posts{grid-template-columns:repeat(3, minmax(0,1fr))}

.split{display:grid; grid-template-columns: 1fr 1fr; gap:34px; align-items:center}
.glass-panel{
  position:relative;
  border-radius:var(--radius);
  border:1px solid rgba(231,227,221,.95);
  background:rgba(255,255,255,.55);
  box-shadow:var(--shadow-soft);
}
.glass-panel__img{
  display:block;
  width:100%;
  height:auto;
  border-radius:calc(var(--radius) - 10px);
  border:1px solid rgba(231,227,221,.85);
}
.media-watermark{
  position:absolute;
  width:50px;
  top:18px;
  right:18px;
  z-index:4;
  border:1px solid rgba(255,255,255,.42);
  border-radius:12px;
  background:rgba(255,255,255,.38);
  backdrop-filter:blur(8px);
  box-shadow:0 6px 18px rgba(16,23,42,.12);
  opacity:.8;
  pointer-events:none;
}
.media-watermark__img{
  display:block;
  height:auto;
  max-height:48px;
  object-fit:contain;
  object-position:right top;
  filter:drop-shadow(0 1px 6px rgba(16,23,42,.14));
}

.list{padding-left:18px; margin:18px 0 0}
.list li{margin:8px 0}
.actions{margin-top:18px}

.artist-section{
  border-top:1px solid rgba(231,227,221,.8);
  border-bottom:1px solid rgba(231,227,221,.8);
  background:
    radial-gradient(800px 340px at 6% 16%, rgba(123,92,255,.08), transparent 60%),
    rgba(255,255,255,.26);
}
.artist-section__head{
  display:flex;
  justify-content:space-between;
  align-items:end;
  gap:20px;
  margin-bottom:28px;
}
.artist-section__head .h2{margin-top:10px; margin-bottom:0}
.artist-controls{display:flex; gap:10px; flex:0 0 auto}
.artist-control{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  width:50px;
  height:50px;
  border:1px solid rgba(231,227,221,.95);
  border-radius:999px;
  color:var(--text);
  background:rgba(255,255,255,.68);
  box-shadow:0 8px 22px rgba(16,23,42,.06);
  font:inherit;
  font-size:23px;
  cursor:pointer;
  transition:transform .18s ease, box-shadow .18s ease, opacity .18s ease;
}
.artist-control:hover:not(:disabled){
  transform:translateY(-1px);
  box-shadow:var(--shadow-soft);
}
.artist-control:disabled{opacity:.35; cursor:default}
.artist-carousel{
  overflow:hidden;
  padding:4px 1px 10px;
}
.artist-track{
  --artist-columns:5;
  --artist-gap:16px;
  display:grid;
  grid-auto-flow:column;
  grid-auto-columns:calc((100% - (var(--artist-gap) * (var(--artist-columns) - 1))) / var(--artist-columns));
  gap:var(--artist-gap);
  overflow-x:auto;
  scroll-snap-type:x mandatory;
  scroll-behavior:smooth;
  scrollbar-width:none;
  padding:2px 0 10px;
}
.artist-track::-webkit-scrollbar{display:none}
.artist-background{
  position:relative;
  margin:0;
  aspect-ratio:4 / 5;
  scroll-snap-align:start;
  overflow:hidden;
  border-radius:var(--radius);
  border:1px solid rgba(231,227,221,.95);
  background:rgba(255,255,255,.56);
  box-shadow:var(--shadow-soft);
}
.artist-background::after{
  content:"";
  position:absolute;
  inset:0;
  background:linear-gradient(180deg, transparent 58%, rgba(16,23,42,.10));
  pointer-events:none;
}
.artist-background__img{
  display:block;
  width:100%;
  height:100%;
  object-fit:cover;
  transition:transform .45s ease;
}
.artist-background:hover .artist-background__img{transform:scale(1.035)}
.artist-empty{
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:20px;
  padding:22px;
}
.artist-empty p{margin:0}

.steps{list-style:none; padding:0; margin:24px 0 0; display:grid; gap:12px}
.step{
  display:flex; gap:14px; align-items:flex-start;
  padding:18px;
  border:1px solid rgba(231,227,221,.95);
  background:rgba(255,255,255,.55);
  border-radius:var(--radius);
}
.step__num{
  width:34px; height:34px; border-radius:999px;
  display:inline-flex; align-items:center; justify-content:center;
  border:1px solid rgba(123,92,255,.35);
  background:rgba(255,255,255,.65);
}
.step__body p{margin:0}

.section--premium{
  background:
    radial-gradient(1200px 800px at 80% 0%, rgba(123,92,255,.22), transparent 55%),
    radial-gradient(900px 700px at 10% 30%, rgba(48,220,255,.14), transparent 55%),
    linear-gradient(180deg, rgba(16,23,42,1), rgba(16,23,42,.95));
  color:#fff;
  border-top:1px solid rgba(255,255,255,.08);
  border-bottom:1px solid rgba(255,255,255,.08);
}
.premium-inner{display:grid; grid-template-columns: 1.15fr .85fr; gap:28px; align-items:center}
.holo-panel{
  position:relative;
  height:260px;
  border-radius:24px;
  background:rgba(255,255,255,.04);
  border:1px solid rgba(255,255,255,.12);
  overflow:hidden;
  box-shadow:0 22px 60px rgba(0,0,0,.35);
}
.holo-panel__glow{
  position:absolute; inset:-40px;
  background:var(--holo);
  opacity:.55;
  filter:blur(28px);
  transform:rotate(-10deg);
}
.holo-panel__grid{
  position:absolute; inset:0;
  background:
    linear-gradient(to right, rgba(255,255,255,.10) 1px, transparent 1px),
    linear-gradient(to bottom, rgba(255,255,255,.10) 1px, transparent 1px);
  background-size:34px 34px;
  opacity:.10;
}
.holo-panel__spark{
  position:absolute; inset:0;
  background:
    radial-gradient(10px 10px at 18% 30%, rgba(255,255,255,.8), transparent 70%),
    radial-gradient(8px 8px at 62% 45%, rgba(255,255,255,.7), transparent 70%),
    radial-gradient(12px 12px at 78% 62%, rgba(255,255,255,.7), transparent 70%);
  opacity:.45;
}

.section--cta{padding:72px 0}
.cta-inner{
  display:flex; justify-content:space-between; align-items:center; gap:22px;
  border-radius:24px;
  border:1px solid rgba(231,227,221,.95);
  background:
    radial-gradient(900px 500px at 0% 0%, rgba(123,92,255,.12), transparent 55%),
    radial-gradient(900px 500px at 90% 0%, rgba(48,220,255,.09), transparent 55%),
    rgba(255,255,255,.60);
  padding:28px;
  box-shadow:var(--shadow-soft);
}
.cta-actions{flex:0 0 auto}

.showroom-intro{padding-top:82px; padding-bottom:52px}
.showroom-header{max-width:780px}
.showroom-header .display{margin-top:14px}
.showroom-description{max-width:680px; margin-top:18px}
.showroom-description p:last-child{margin-bottom:0}
.showroom-gallery-section{padding:0 0 28px}
.showroom-gallery{
  display:grid;
  grid-template-columns:repeat(3, minmax(0, 1fr));
  gap:16px;
}
.showroom-item{
  position:relative;
  margin:0;
  aspect-ratio:4 / 5;
  overflow:hidden;
  border:1px solid rgba(231,227,221,.95);
  border-radius:var(--radius);
  background:rgba(255,255,255,.55);
  box-shadow:var(--shadow-soft);
}
.showroom-item:first-child{
  grid-column:span 2;
  grid-row:span 2;
  aspect-ratio:auto;
  min-height:560px;
}
.showroom-item__img{
  display:block;
  width:100%;
  height:100%;
  object-fit:cover;
  transition:transform .45s ease;
}
.showroom-item:hover .showroom-item__img{transform:scale(1.025)}
.showroom-item .media-watermark{
  top:16px;
  right:16px;
  width: 50px;
  opacity:.7;
}
.showroom-empty{
  max-width:720px;
  padding:38px;
  text-align:center;
  margin:0 auto;
}
.showroom-empty .muted{margin:0 auto 20px; max-width:420px}

.order-intro{padding-top:82px}
.order-layout{
  display:grid;
  grid-template-columns:.82fr 1.18fr;
  gap:42px;
  align-items:start;
}
.order-header{position:sticky; top:112px}
.order-header .display{font-size:clamp(40px, 5vw, 58px); margin-top:14px}
.order-preview{
  width:min(100%, 364px);
  margin:24px auto 25px;
}
.order-preview__canvas{
  position:relative;
  overflow:hidden;
  aspect-ratio:1;
  border-radius:25px;
  border:1px solid rgba(231,227,221,.9);
  background:rgba(255,255,255,.46);
  box-shadow:0 20px 42px rgba(16,23,42,.09);
}
.order-preview__canvas::after{
  content:"";
  position:absolute;
  inset:0;
  background:linear-gradient(118deg, rgba(255,255,255,.20), transparent 34%, rgba(123,92,255,.045) 70%, transparent);
  pointer-events:none;
  z-index:2;
}
.order-preview__background{
  position:absolute;
  inset:14.5% 14.5%;
  border-radius:13%;
  background:
    radial-gradient(circle at 70% 16%, rgba(255,255,255,.88), transparent 28%),
    radial-gradient(circle at 34% 34%, rgba(123,92,255,.13), transparent 38%),
    linear-gradient(140deg, #f5f0ec, #e6e3ea 52%, #eaeef4);
  background-position:center;
  background-size:cover;
  transition:background-image .3s ease, filter .28s ease, transform .3s ease;
}
.order-preview__background.has-image{
  filter:saturate(1.04) contrast(1.02);
  transform:scale(1.012);
}
.order-preview__hologram{
  position:absolute;
  inset:14.5%;
  z-index:1;
  display:block;
  width:71%;
  height:71%;
  border-radius:13%;
  object-fit:cover;
  opacity:.7;
  mix-blend-mode:screen;
  pointer-events:none;
  transition:opacity .2s ease;
}
.order-preview__hologram.is-hidden{display:none}
.order-preview__frame{
  position:relative;
  z-index:2;
  display:block;
  width:100%;
  height:100%;
  object-fit:contain;
}
.order-preview__text{
  position:absolute;
  z-index:4;
  top:20%;
  left:17%;
  right:17%;
  overflow:hidden;
  color:rgba(23,23,23,.72);
  font-family:'Alice', serif;
  font-size:clamp(10px, 1.7vw, 8px);
  line-height:1.3;
  letter-spacing:.025em;
  text-align:center;
  text-shadow:0 1px 5px rgba(255,255,255,.22);
  transition:color .2s ease, text-shadow .2s ease, opacity .2s ease;
}
.order-preview__text span{
  display:block;
  overflow:hidden;
  min-height:1.3em;
  white-space:nowrap;
  text-overflow:ellipsis;
}
.order-preview__text.is-light{
  color:rgba(255,255,255,.82);
  text-shadow:0 1px 8px rgba(16,23,42,.36);
}
.order-preview__text.is-hidden{display:none}
.order-preview figcaption{
  display:block;
  margin-top:9px;
  text-align:center;
}
.order-preview__disclaimer{
  display:block;
  margin-top:3px;
  color:rgba(23,23,23,.82);
}
.order-note{
  padding:22px;
  margin-top:30px;
  background:
    radial-gradient(430px 230px at 100% 0%, rgba(123,92,255,.10), transparent 64%),
    rgba(255,255,255,.55);
}
.order-note p{margin:0}
.order-form-panel{
  border:1px solid rgba(231,227,221,.95);
  border-radius:24px;
  background:rgba(255,255,255,.62);
  box-shadow:var(--shadow-soft);
  padding:32px;
}
.order-form{display:grid; gap:30px}
.form-fieldset{
  min-width:0;
  margin:0;
  padding:0 0 30px;
  border:0;
  border-bottom:1px solid rgba(231,227,221,.95);
}
.form-fieldset legend{display:block; float:left; width:100%; margin:0 0 20px}
.form-fieldset legend + *{clear:left}
.form-grid{display:grid; grid-template-columns:repeat(2, minmax(0, 1fr)); gap:16px}
.form-field{
  display:flex;
  flex-direction:column;
  gap:8px;
  margin:0 0 16px;
}
.form-field:last-child{margin-bottom:0}
.form-field--full{grid-column:1 / -1}
.form-label{font-size:15px; color:rgba(23,23,23,.86)}
.form-control{
  width:100%;
  min-height:50px;
  border:1px solid rgba(231,227,221,.98);
  border-radius:14px;
  padding:12px 14px;
  background:rgba(248,247,244,.75);
  color:var(--text);
  font:inherit;
  transition:border-color .18s ease, box-shadow .18s ease, background .18s ease;
}
.form-control:focus{
  outline:none;
  border-color:rgba(123,92,255,.42);
  box-shadow:0 0 0 3px rgba(123,92,255,.10);
  background:rgba(255,255,255,.9);
}
textarea.form-control{resize:vertical; min-height:132px}
.form-control--file{padding:9px; line-height:1.5}
.form-control--file::file-selector-button{
  margin-right:12px;
  border:1px solid rgba(231,227,221,.95);
  border-radius:999px;
  padding:8px 13px;
  background:rgba(255,255,255,.8);
  color:var(--text);
  font:inherit;
  cursor:pointer;
}
.form-help{font-size:13px; color:var(--muted)}
.form-counter{
  display:flex;
  justify-content:flex-end;
  gap:4px;
}
.address-validation{
  align-items:flex-start;
  margin-top:4px;
  padding:15px;
  border:1px solid rgba(231,227,221,.95);
  border-radius:16px;
  background:rgba(248,247,244,.48);
}
.address-validation__button{padding:9px 15px; cursor:pointer}
.address-validation__button:disabled{opacity:.58; cursor:progress}
.address-validation__status{margin:0}
.address-validation__status.is-success{color:#357351}
.address-validation__status.is-error{color:#973f48}
.address-validation__status.is-loading{color:var(--cosmic)}
.background-tabs{
  display:grid;
  grid-template-columns:repeat(2, minmax(0, 1fr));
  gap:6px;
  margin:18px 0 10px;
  padding:5px;
  border:1px solid rgba(231,227,221,.98);
  border-radius:16px;
  background:rgba(248,247,244,.72);
}
.background-tab{position:relative; cursor:pointer}
.background-tab input{position:absolute; opacity:0; width:1px; height:1px}
.background-tab span{
  display:flex;
  min-height:50px;
  align-items:center;
  justify-content:center;
  border-radius:11px;
  padding:9px 12px;
  text-align:center;
  color:var(--muted);
  transition:background .18s ease, box-shadow .18s ease, color .18s ease;
}
.background-tab input:checked + span{
  background:rgba(255,255,255,.9);
  color:var(--text);
  box-shadow:0 7px 22px rgba(16,23,42,.07);
}
.background-tab input:focus-visible + span{outline:2px solid rgba(123,92,255,.55); outline-offset:2px}
.background-mode-help{display:block; margin:0 0 20px}
.personal-background-panel{margin-bottom:18px}
.order-artist-picker{margin-bottom:22px}
.order-artist-grid{
  display:flex;
  gap:10px;
  margin-top:10px;
  overflow-x:auto;
  padding:2px 2px 10px;
  scrollbar-width:thin;
}
.order-artist-custom,
.order-artist-choice{
  position:relative;
  display:flex;
  flex-direction:column;
  overflow:hidden;
  min-height:104px;
  flex:0 0 112px;
  border:1px solid rgba(231,227,221,.98);
  border-radius:14px;
  background:rgba(248,247,244,.75);
  cursor:pointer;
  transition:border-color .18s ease, box-shadow .18s ease, transform .18s ease;
}
.order-artist-custom{
  align-items:center;
  justify-content:center;
  padding:10px;
  text-align:center;
  color:var(--muted);
}
.order-artist-choice__img{
  display:block;
  height:106px;
  width:100%;
  object-fit:cover;
}
.order-artist-choice span{
  position:absolute;
  left:7px;
  bottom:7px;
  padding:3px 7px;
  border-radius:999px;
  background:rgba(255,255,255,.82);
  font-size:12px;
}
.order-artist-custom input,
.order-artist-choice input{
  position:absolute;
  opacity:0;
}
.order-artist-custom:hover,
.order-artist-choice:hover{transform:translateY(-1px)}
.order-artist-custom:has(input:checked),
.order-artist-choice:has(input:checked){
  border-color:rgba(123,92,255,.52);
  box-shadow:0 0 0 2px rgba(123,92,255,.14), 0 9px 24px rgba(123,92,255,.10);
}
.order-artist-custom:has(input:focus-visible),
.order-artist-choice:has(input:focus-visible){outline:2px solid rgba(123,92,255,.55); outline-offset:2px}
.choice-pills{display:flex; gap:10px; flex-wrap:wrap}
.choice-pill{position:relative; cursor:pointer}
.choice-pill input{position:absolute; opacity:0; width:1px; height:1px}
.choice-pill span{
  display:inline-flex;
  min-width:92px;
  justify-content:center;
  padding:11px 17px;
  border:1px solid rgba(231,227,221,.98);
  border-radius:999px;
  background:rgba(248,247,244,.75);
  transition:border-color .18s ease, background .18s ease, box-shadow .18s ease;
}
.choice-pill input:checked + span{
  border-color:rgba(123,92,255,.38);
  background:rgba(123,92,255,.10);
  box-shadow:0 6px 20px rgba(123,92,255,.10);
}
.choice-pill input:focus-visible + span{outline:2px solid rgba(123,92,255,.55); outline-offset:3px}
.conditional-field.is-hidden{display:none}
.order-total{
  padding:22px;
  border:1px solid rgba(123,92,255,.18);
  border-radius:18px;
  background:
    radial-gradient(400px 200px at 100% 0%, rgba(123,92,255,.10), transparent 58%),
    rgba(248,247,244,.68);
}
.order-total .h4{margin-bottom:16px}
.order-total__line,
.order-total__final{
  display:flex;
  justify-content:space-between;
  align-items:baseline;
  gap:16px;
  padding:7px 0;
}
.order-total__line{color:var(--muted)}
.order-total__final{
  margin-top:10px;
  padding-top:14px;
  border-top:1px solid rgba(231,227,221,.95);
  font-size:19px;
}
.order-total__final strong{
  color:var(--cosmic);
  font-size:28px;
  font-weight:400;
}
.order-total .form-help{display:block; margin-top:10px}
.order-submit{width:100%; border-color:rgba(123,92,255,.4); cursor:pointer}
.order-consent{
  display:flex;
  align-items:flex-start;
  gap:11px;
  padding:17px 18px;
  border:1px solid rgba(231,227,221,.95);
  border-radius:16px;
  background:rgba(255,255,255,.4);
  color:rgba(23,23,23,.86);
}
.order-consent input{
  flex:0 0 auto;
  width:18px;
  height:18px;
  margin:4px 0 0;
  accent-color:var(--violet);
}
.order-consent a{
  color:var(--cosmic);
  text-decoration:underline;
  text-underline-offset:3px;
}
.form-notice{
  border-radius:16px;
  border:1px solid rgba(231,227,221,.95);
  padding:18px 20px;
  margin-bottom:26px;
}
.form-notice p{margin:0}
.form-notice--success{background:rgba(98,174,135,.10); border-color:rgba(98,174,135,.24)}
.form-notice--error{background:rgba(181,72,72,.06); border-color:rgba(181,72,72,.20)}

.site-footer{
  padding:46px 0 18px;
  border-top:1px solid var(--line);
  background:rgba(255,255,255,.35);
}
.footer-inner{display:grid; grid-template-columns: 1.2fr .8fr 1fr; gap:22px; align-items:start}
.footer-brand{font-size:18px; margin:0 0 6px}
.footer-bottom{padding-top:12px; margin-top:18px; border-top:1px solid rgba(231,227,221,.8)}
.site-footer ul{list-style:none; margin:0; padding:0; display:grid; gap:8px}
.site-footer a{color:rgba(23,23,23,.78)}
.site-footer a:hover{color:rgba(23,23,23,1)}

.prose{
  max-width:860px;
}
.prose .page-content > *:first-child{margin-top:0}
.prose .wpcf7{
  max-width:680px;
  margin-top:26px;
}
.prose .wpcf7 form > p:first-of-type{
  margin:0 0 24px;
  color:var(--muted);
  font-size:16px;
}
.contact-form-clean{
  padding:30px;
  border:1px solid rgba(231,227,221,.95);
  border-radius:24px;
  background:
    radial-gradient(460px 220px at 100% 0%, rgba(123,92,255,.08), transparent 64%),
    rgba(255,255,255,.62);
  box-shadow:var(--shadow-soft);
}
.contact-form-clean p{margin:0 0 18px}
.contact-form-clean p:last-child{margin:28px 0 0}
.contact-form-clean label{
  display:block;
  color:rgba(23,23,23,.86);
  font-size:15px;
  line-height:1.45;
}
.contact-form-clean .wpcf7-form-control-wrap{
  display:block;
  margin-top:8px;
}
.contact-form-clean input:not([type="submit"]),
.contact-form-clean select,
.contact-form-clean textarea{
  display:block;
  width:100%;
  min-height:50px;
  border:1px solid rgba(231,227,221,.98);
  border-radius:14px;
  padding:12px 14px;
  background:rgba(248,247,244,.75);
  color:var(--text);
  font:inherit;
  transition:border-color .18s ease, box-shadow .18s ease, background .18s ease;
}
.contact-form-clean textarea{
  min-height:152px;
  resize:vertical;
}
.contact-form-clean input::placeholder,
.contact-form-clean textarea::placeholder{color:rgba(23,23,23,.48)}
.contact-form-clean input:not([type="submit"]):focus,
.contact-form-clean select:focus,
.contact-form-clean textarea:focus{
  outline:none;
  border-color:rgba(123,92,255,.42);
  box-shadow:0 0 0 3px rgba(123,92,255,.10);
  background:rgba(255,255,255,.9);
}
.contact-form-clean .wpcf7-submit{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:50px;
  border:1px solid rgba(123,92,255,.35);
  border-radius:999px;
  padding:13px 22px;
  background:linear-gradient(180deg, rgba(123,92,255,.16), rgba(255,255,255,.68));
  box-shadow:0 8px 20px rgba(16,23,42,.06);
  color:var(--text);
  font:inherit;
  font-size:16px;
  cursor:pointer;
  transition:transform .18s ease, box-shadow .18s ease, background .18s ease;
}
.contact-form-clean .wpcf7-submit:hover{
  transform:translateY(-1px);
  box-shadow:var(--shadow-soft);
  background:rgba(255,255,255,.78);
}
.contact-form-clean .wpcf7-submit:disabled{opacity:.6; cursor:progress}
.contact-form-clean .wpcf7-spinner{margin:0 0 0 12px; vertical-align:middle}
.contact-form-clean .wpcf7-not-valid{
  border-color:rgba(151,63,72,.42);
  background:rgba(151,63,72,.04);
}
.contact-form-clean .wpcf7-not-valid-tip{
  margin-top:6px;
  color:#973f48;
  font-size:13px;
}
.prose .wpcf7 .wpcf7-response-output{
  margin:18px 0 0;
  padding:13px 15px;
  border:1px solid rgba(231,227,221,.95);
  border-radius:14px;
  font-size:14px;
}
.prose .wpcf7 form.invalid .wpcf7-response-output,
.prose .wpcf7 form.failed .wpcf7-response-output,
.prose .wpcf7 form.unaccepted .wpcf7-response-output{
  border-color:rgba(151,63,72,.28);
  background:rgba(151,63,72,.06);
  color:#973f48;
}
.prose .wpcf7 form.sent .wpcf7-response-output{
  border-color:rgba(53,115,81,.28);
  background:rgba(53,115,81,.06);
  color:#357351;
}
.featured-media{margin:18px 0 8px}
.featured-media img{border-radius:var(--radius); border:1px solid rgba(231,227,221,.95)}

.pagination{margin-top:24px}
.pagination .nav-links{display:flex; gap:10px; flex-wrap:wrap}
.pagination a, .pagination span{
  padding:10px 12px;
  border-radius:14px;
  border:1px solid rgba(231,227,221,.95);
  background:rgba(255,255,255,.55);
}

/* Mockups (CSS placeholder visuals) */
.mockup{width:min(520px, 100%); display:flex; flex-direction:column; gap:14px}
.mockup__box{
  position:relative;
  height:524px;
  border-radius:28px;
  border:1px solid rgba(231,227,221,.9);
  background:linear-gradient(180deg, rgba(255,255,255,.66), rgba(255,255,255,.30));
  box-shadow:var(--shadow);
  overflow:hidden;
}
.mockup__img{
  position:absolute;
  inset:0;
  width:100%;
  height:100%;
  object-fit:cover;
  transform:scale(1.01);
  filter:saturate(105%) contrast(102%);
}
.mockup__bg{
  position:absolute; inset:22px;
  border-radius:22px;
  background:
    radial-gradient(600px 420px at 70% 20%, rgba(123,92,255,.35), transparent 60%),
    radial-gradient(560px 380px at 20% 60%, rgba(48,220,255,.22), transparent 58%),
    radial-gradient(520px 360px at 60% 90%, rgba(255,110,199,.16), transparent 60%),
    linear-gradient(180deg, rgba(16,23,42,.90), rgba(36,59,128,.70));
  filter:saturate(115%);
}
.mockup__card{
  position:absolute;
  width:44%;
  aspect-ratio: 63 / 88;
  left:28%;
  top:22%;
  border-radius:16px;
  background:linear-gradient(180deg, rgba(255,255,255,.82), rgba(255,255,255,.55));
  border:1px solid rgba(255,255,255,.55);
  box-shadow:0 24px 56px rgba(0,0,0,.22);
}
.mockup__shine{
  position:absolute; inset:-60px -90px auto auto;
  width:260px; height:260px;
  background:radial-gradient(circle at 30% 30%, rgba(255,255,255,.7), transparent 60%);
  transform:rotate(10deg);
  opacity:.55;
}
.mockup__box .media-watermark{top:18px; right:18px}
.mockup__caption{display:flex; gap:10px; flex-wrap:wrap}

.mini-mockup{position:relative; height:320px; border-radius:22px; overflow:hidden}
.mini-mockup__bg{
  position:absolute; inset:0;
  background:
    radial-gradient(440px 320px at 72% 20%, rgba(123,92,255,.26), transparent 55%),
    radial-gradient(420px 320px at 18% 62%, rgba(48,220,255,.18), transparent 60%),
    linear-gradient(180deg, rgba(16,23,42,.92), rgba(36,59,128,.78));
}
.mini-mockup__card{
  position:absolute;
  width:46%; aspect-ratio: 63 / 88;
  left:27%; top:20%;
  border-radius:14px;
  background:linear-gradient(180deg, rgba(255,255,255,.85), rgba(255,255,255,.55));
  box-shadow:0 18px 46px rgba(0,0,0,.18);
}
.mini-mockup__frame{
  position:absolute; inset:16px;
  border-radius:18px;
  border:1px solid rgba(255,255,255,.28);
  background:linear-gradient(180deg, rgba(255,255,255,.22), rgba(255,255,255,.06));
  backdrop-filter:blur(10px);
}

/* Reveal */
.reveal{opacity:0; transform:translateY(10px); transition:opacity .45s ease, transform .45s ease}
.reveal.is-visible{opacity:1; transform:none}
.home-page .reveal{
  --reveal-delay:0ms;
  opacity:0;
  filter:blur(9px);
  transform:translateY(34px) scale(.985);
  transition:
    opacity .78s cubic-bezier(.2,.75,.24,1) var(--reveal-delay),
    transform .9s cubic-bezier(.2,.75,.24,1) var(--reveal-delay),
    filter .72s ease var(--reveal-delay);
}
.home-page .reveal.is-visible{
  opacity:1;
  filter:none;
  transform:translateY(0) scale(1);
}
.home-page .hero-copy{--reveal-delay:80ms}
.home-page .hero-visual{--reveal-delay:190ms}
.home-page .reveal--luminous{position:relative}
.home-page .reveal--luminous::after{
  content:"";
  position:absolute;
  inset:-2px;
  z-index:3;
  border-radius:inherit;
  pointer-events:none;
  background:linear-gradient(112deg, transparent 20%, rgba(255,255,255,.4) 43%, rgba(123,92,255,.12) 53%, transparent 72%);
  opacity:0;
  transform:translateX(-34%);
}
.home-page .reveal--luminous.is-visible::after{
  animation:celestial-sheen 1.05s cubic-bezier(.18,.7,.2,1) .3s both;
}
.home-page .grid--3.reveal .card,
.home-page .steps.reveal .step,
.home-page .artist-carousel.reveal .artist-background{
  opacity:0;
  transform:translateY(20px);
  transition:
    opacity .56s ease,
    transform .68s cubic-bezier(.2,.75,.24,1),
    box-shadow .2s ease;
}
.home-page .grid--3.reveal.is-visible .card,
.home-page .steps.reveal.is-visible .step,
.home-page .artist-carousel.reveal.is-visible .artist-background{
  opacity:1;
  transform:translateY(0);
}
.home-page .grid--3.reveal.is-visible .card:nth-child(1),
.home-page .steps.reveal.is-visible .step:nth-child(1),
.home-page .artist-carousel.reveal.is-visible .artist-background:nth-child(1){transition-delay:110ms}
.home-page .grid--3.reveal.is-visible .card:nth-child(2),
.home-page .steps.reveal.is-visible .step:nth-child(2),
.home-page .artist-carousel.reveal.is-visible .artist-background:nth-child(2){transition-delay:170ms}
.home-page .grid--3.reveal.is-visible .card:nth-child(3),
.home-page .steps.reveal.is-visible .step:nth-child(3),
.home-page .artist-carousel.reveal.is-visible .artist-background:nth-child(3){transition-delay:230ms}
.home-page .steps.reveal.is-visible .step:nth-child(4),
.home-page .artist-carousel.reveal.is-visible .artist-background:nth-child(4){transition-delay:290ms}
.home-page .artist-carousel.reveal.is-visible .artist-background:nth-child(5){transition-delay:350ms}
.home-page .mockup__box{
  transition:transform .9s cubic-bezier(.2,.75,.24,1), box-shadow .9s ease;
}
.home-page .hero-visual.is-visible .mockup__box{
  animation:celestial-float 6s ease-in-out 1.15s infinite;
}
.home-page .holo-panel__glow{animation:celestial-drift 8s ease-in-out infinite alternate}
@keyframes celestial-sheen{
  0%{opacity:0; transform:translateX(-38%)}
  30%{opacity:.65}
  100%{opacity:0; transform:translateX(35%)}
}
@keyframes celestial-float{
  0%,100%{transform:translateY(0); box-shadow:var(--shadow)}
  50%{transform:translateY(-7px); box-shadow:0 22px 55px rgba(16,23,42,.14)}
}
@keyframes celestial-drift{
  from{transform:rotate(-10deg) translate3d(-2%, 1%, 0)}
  to{transform:rotate(-6deg) translate3d(3%, -2%, 0)}
}
@media (prefers-reduced-motion: reduce){
  .reveal{opacity:1; transform:none; transition:none}
  .button{transition:none}
  .home-page .reveal,
  .home-page .grid--3.reveal .card,
  .home-page .steps.reveal .step,
  .home-page .artist-carousel.reveal .artist-background{
    opacity:1;
    filter:none;
    transform:none;
    transition:none;
  }
  .home-page .reveal--luminous.is-visible::after,
  .home-page .hero-visual.is-visible .mockup__box,
  .home-page .holo-panel__glow{animation:none}
}

/* Responsive */
@media (max-width: 980px){
  .grid--3{grid-template-columns:1fr}
  .grid--posts{grid-template-columns:1fr 1fr}
  .hero-inner{grid-template-columns:1fr; gap:26px}
  .hero-visual{justify-content:flex-start}
  .split{grid-template-columns:1fr; gap:22px}
  .premium-inner{grid-template-columns:1fr}
  .showroom-gallery{grid-template-columns:repeat(2, minmax(0, 1fr))}
  .showroom-item:first-child{min-height:460px}
  .artist-track{--artist-columns:3}
  .order-layout{grid-template-columns:1fr}
  .order-header{position:static}
  .footer-inner{grid-template-columns:1fr}
}
@media (max-width: 720px){
  body{background:var(--bg)}
  .home-page .section--premium{background:var(--night)}
  .home-page .section--cta .cta-inner{background:rgba(255,255,255,.60)}
  .home-page .reveal--luminous.is-visible::after{animation:none}
  .section{padding:72px 0}
  .hero{padding:76px 0 42px}
  .grid--posts{grid-template-columns:1fr}
  .cta-inner{flex-direction:column; align-items:flex-start}
  .showroom-intro{padding-top:62px; padding-bottom:38px}
  .showroom-gallery{grid-template-columns:1fr}
  .showroom-item:first-child{grid-column:auto; grid-row:auto; min-height:0; aspect-ratio:4 / 5}
  .showroom-empty{padding:28px 20px}
  .artist-section__head{align-items:start}
  .artist-track{--artist-columns:2; --artist-gap:12px}
  .artist-control{width:44px; height:44px}
  .artist-empty{flex-direction:column; align-items:flex-start}
  .order-intro{padding-top:62px}
  .order-form-panel{padding:22px 18px}
  .contact-form-clean{padding:22px 18px}
  .background-tabs{grid-template-columns:1fr}
  .form-grid{grid-template-columns:1fr}
  .brand-row{gap:10px}
  .brand-name{font-size:17px}
  .site-nav ul{
    position:absolute; right:22px; top:74px;
    display:none;
    width:min(360px, calc(100vw - 44px));
    padding:12px;
    border-radius:18px;
    border:1px solid rgba(231,227,221,.95);
    background:rgba(248,247,244,.95);
    box-shadow:var(--shadow);
    flex-direction:column;
    align-items:stretch;
  }
  .site-nav ul.is-open{display:flex}
  .nav-toggle{display:inline-flex}
}
