@font-face{font-family:"Manrope";font-style:normal;font-display:swap;font-weight:400 800;src:url("../fonts/manrope/manrope-cyrillic-ext-wght-normal.woff2") format("woff2-variations");unicode-range:U+0460-052F,U+1C80-1C8A,U+20B4,U+2DE0-2DFF,U+A640-A69F,U+FE2E-FE2F}@font-face{font-family:"Manrope";font-style:normal;font-display:swap;font-weight:400 800;src:url("../fonts/manrope/manrope-cyrillic-wght-normal.woff2") format("woff2-variations");unicode-range:U+0301,U+0400-045F,U+0490-0491,U+04B0-04B1,U+2116}@font-face{font-family:"Manrope";font-style:normal;font-display:swap;font-weight:400 800;src:url("../fonts/manrope/manrope-latin-ext-wght-normal.woff2") format("woff2-variations");unicode-range:U+0100-02BA,U+02BD-02C5,U+02C7-02CC,U+02CE-02D7,U+02DD-02FF,U+0304,U+0308,U+0329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:"Manrope";font-style:normal;font-display:swap;font-weight:400 800;src:url("../fonts/manrope/manrope-latin-wght-normal.woff2") format("woff2-variations");unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}:root{--font-sans:"Manrope",system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;--font-serif:Georgia,"Times New Roman",serif;--color-canvas:#FFF6E8;--color-surface:#FFFCF6;--color-ink:#1F2421;--color-muted:#665D53;--color-primary:#B6533A;--color-primary-hover:#8F3C28;--color-sage:#3F7467;--color-sage-dark:#173C35;--color-sand:#F4DFC3;--color-line:#E6D4BE;--color-gold:#D6A24C;--color-success:#2F8F5B;--color-warning:#9A6A00;--color-danger:#B42318;--bg:var(--color-canvas);--card:var(--color-surface);--ink:var(--color-ink);--muted:var(--color-muted);--accent:var(--color-primary);--accent-hover:var(--color-primary-hover);--sage:var(--color-sage);--sage-dark:var(--color-sage-dark);--cream:var(--color-sand);--border:var(--color-line);--ok:var(--color-success);--line:var(--color-line)}*{box-sizing:border-box}html,body{min-height:100%;overflow-x:hidden;overflow-x:clip}body{margin:0;min-height:100vh;display:flex;flex-direction:column;font-family:var(--font-sans);background:var(--bg);color:var(--ink)}button,input,textarea,select{font-family:inherit}a{color:var(--accent);text-decoration:none}main{flex:1 0 auto;width:100%;max-width:1180px;margin:0 auto;padding:28px 18px}.site-header{position:sticky;top:0;z-index:20;background:#fffcf6f0;backdrop-filter:blur(12px);display:flex;align-items:center;justify-content:space-between;padding:14px 28px;border-bottom:1px solid var(--line)}.brand{font-weight:800;color:var(--ink);font-size:1.35rem}.site-header nav,.admin-nav{display:flex;gap:14px;align-items:center;flex-wrap:wrap}.menu-toggle,.site-nav-backdrop{display:none}.menu-toggle{position:relative;align-items:center;justify-content:center;flex-direction:column;width:46px;height:46px;margin-left:auto;padding:0;border:0;border-radius:0;background:transparent;box-shadow:none;color:var(--accent);cursor:pointer;appearance:none}.menu-toggle__line{display:block;width:20px;height:2px;border-radius:999px;background:currentColor;transition:transform .22s ease,opacity .22s ease}.menu-toggle__line+.menu-toggle__line{margin-top:5px}.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}.inline{display:inline}.inline button{background:transparent;border:0;color:var(--accent);cursor:pointer}

.eyebrow {
  color: var(--accent);
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .12em;
}


.photo-to-3d-section {
  width: 100%;
  margin: 46px 0 34px;
}

.photo-to-3d-card {
  position: relative;
  isolation: isolate;
  overflow: hidden;
  display: grid;
  grid-template-columns: minmax(400px, .47fr) minmax(500px, .53fr);
  align-items: stretch;
  min-height: 460px;
  padding: clamp(40px, 3.8vw, 54px) clamp(38px, 4vw, 56px);
  border: 1px solid rgba(210, 231, 242, .92);
  border-radius: 34px;
  background:
    radial-gradient(ellipse at 86% 78%, rgba(180, 234, 255, .30), rgba(180, 234, 255, 0) 48%),
    radial-gradient(ellipse at 60% 76%, rgba(234, 250, 255, .50), rgba(234, 250, 255, 0) 36%),
    linear-gradient(135deg, #ffffff 0%, #ffffff 54%, #f3fcff 100%);
  box-shadow: 0 24px 70px rgba(20, 33, 61, .10), 0 1px 0 rgba(255, 255, 255, .9) inset;
}

.photo-to-3d-card::before {
  content: "";
  position: absolute;
  right: 42px;
  top: -2px;
  z-index: -1;
  width: min(38vw, 360px);
  height: 245px;
  opacity: .38;
  background-image: radial-gradient(circle, rgba(74,48,24,.16) 1.8px, transparent 2px);
  background-size: 18px 18px;
  mask-image: linear-gradient(90deg, transparent 0%, #000 28%, #000 74%, transparent 100%);
}

.photo-to-3d-card::after {
  content: "";
  position: absolute;
  left: -24px;
  bottom: 18px;
  z-index: -1;
  width: 285px;
  height: 175px;
  opacity: .18;
  background-image: radial-gradient(circle, rgba(74,48,24,.16) 1.4px, transparent 2px);
  background-size: 18px 18px;
  mask-image: linear-gradient(90deg, transparent 0%, #000 30%, #000 76%, transparent 100%);
}

.photo-to-3d-copy {
  position: relative;
  z-index: 4;
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  min-width: 0;
  max-width: 600px;
}

.photo-to-3d-kicker {
  margin: 0 0 24px;
  color: var(--accent);
  font-size: .98rem;
  font-weight: 700;
  letter-spacing: .18em;
  line-height: 1;
  text-transform: uppercase;
}

.photo-to-3d-title {
  max-width: 520px;
  margin: 0;
  color: var(--ink);
  font-size: clamp(38px, 3.15vw, 50px);
  font-weight: 800;
  line-height: .98;
  letter-spacing: -.025em;
}

.photo-to-3d-title-line {
  white-space: nowrap;
}

.photo-to-3d-text {
  max-width: 520px;
  margin: 24px 0 0;
  color: #263654;
  font-size: clamp(1.08rem, 1.65vw, 1.28rem);
  line-height: 1.55;
}

.photo-to-3d-button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 54px;
  margin-top: 28px;
  padding: 0 31px;
  border-radius: 999px;
  background: linear-gradient(135deg, #3F7467 0%, var(--accent) 100%);
  box-shadow: 0 15px 28px rgba(74,48,24,.2);
  color: #fff;
  font-size: 1.04rem;
  font-weight: 700;
  transition: transform .2s ease, box-shadow .2s ease, background .2s ease;
}

.photo-to-3d-button:hover {
  transform: translateY(-2px);
  box-shadow: 0 19px 34px rgba(74,48,24,.24);
  color: #fff;
}

.photo-to-3d-button:focus-visible {
  outline: 3px solid rgba(74,48,24,.2);
  outline-offset: 4px;
}

.photo-to-3d-features {
  display: grid;
  grid-template-columns: repeat(3, max-content);
  gap: clamp(18px, 1.7vw, 28px);
  align-items: center;
  max-width: 560px;
  margin-top: auto;
  padding-top: 44px;
}

.photo-to-3d-feature {
  display: inline-flex;
  align-items: center;
  gap: 12px;
  min-width: 0;
  color: var(--ink);
  font-size: .93rem;
  font-weight: 650;
  line-height: 1.24;
}

.photo-to-3d-feature svg {
  width: clamp(34px, 3.2vw, 42px);
  height: clamp(34px, 3.2vw, 42px);
  flex: 0 0 auto;
  fill: none;
  stroke: var(--accent);
  stroke-width: 2.35;
  stroke-linecap: round;
  stroke-linejoin: round;
}

.photo-to-3d-visual {
  position: relative;
  z-index: 1;
  display: grid;
  grid-template-columns: minmax(118px, 150px) minmax(36px, 60px) minmax(210px, 280px);
  justify-content: end;
  align-items: end;
  column-gap: clamp(8px, 1.4vw, 16px);
  min-width: 0;
  min-height: 365px;
  padding: 18px 0 40px;
}

.photo-to-3d-visual::before {
  content: "";
  position: absolute;
  right: -3%;
  bottom: -8px;
  width: 80%;
  height: 52%;
  border-radius: 999px;
  background: radial-gradient(ellipse, rgba(167, 226, 255, .24), rgba(167, 226, 255, .09) 38%, rgba(167, 226, 255, 0) 72%);
  filter: blur(22px);
  pointer-events: none;
}

.photo-to-3d-phone-wrap,
.photo-to-3d-result-wrap,
.photo-to-3d-arrow {
  position: relative;
}

.photo-to-3d-phone-wrap {
  left: auto;
  bottom: auto;
  z-index: 3;
  align-self: end;
  justify-self: start;
  transform: translateY(-30px);
  height: clamp(280px, 24vw, 350px);
  width: auto;
  filter: drop-shadow(0 18px 24px rgba(20, 33, 61, .14));
}

.photo-to-3d-phone {
  display: block;
  width: auto;
  height: 100%;
  max-height: none;
  object-fit: contain;
}

.photo-to-3d-camera {
  position: absolute;
  right: -22px;
  bottom: 18px;
  z-index: 4;
  display: grid;
  place-items: center;
  width: clamp(54px, 5.2vw, 70px);
  height: clamp(54px, 5.2vw, 70px);
  border: 7px solid rgba(218, 237, 255, .92);
  border-radius: 50%;
  background: linear-gradient(135deg, #B6533A 0%, #8F3C28 100%);
  box-shadow: 0 16px 28px rgba(28, 105, 220, .28);
}

.photo-to-3d-camera svg {
  width: 58%;
  height: 58%;
  fill: none;
  stroke: #fff;
  stroke-width: 3;
  stroke-linecap: round;
  stroke-linejoin: round;
}

.photo-to-3d-arrow {
  left: auto;
  top: auto;
  z-index: 2;
  align-self: center;
  justify-self: center;
  width: 100%;
  max-width: 68px;
  transform: translateY(18px);
  opacity: .58;
  color: #3F7467;
  filter: drop-shadow(0 8px 12px rgba(86, 181, 218, .14));
}

.photo-to-3d-arrow svg {
  display: block;
  width: 100%;
  height: auto;
  fill: currentColor;
  stroke: currentColor;
  stroke-width: 8;
  stroke-linecap: round;
  stroke-linejoin: round;
}

.photo-to-3d-result-wrap {
  inset: auto;
  z-index: 3;
  align-self: end;
  justify-self: end;
  display: flex;
  align-items: flex-end;
  justify-content: center;
  width: min(100%, 280px);
  min-height: clamp(260px, 24vw, 370px);
  pointer-events: none;
  filter: drop-shadow(0 20px 26px rgba(20, 33, 61, .10));
}

.photo-to-3d-platform {
  position: absolute;
  left: 50%;
  right: auto;
  bottom: 24px;
  z-index: 1;
  width: 290px;
  height: 56px;
  border-radius: 50%;
  background: rgba(210, 246, 255, .58);
  box-shadow: 0 0 32px rgba(70, 190, 220, .22);
  transform: translateX(-50%);
}

.photo-to-3d-result {
  position: relative;
  right: auto;
  bottom: auto;
  z-index: 3;
  display: block;
  width: auto;
  height: clamp(260px, 24vw, 370px);
  max-height: none;
  object-fit: contain;
  object-position: center bottom;
  transform: translateY(-24px);
}

@media (max-width: 1024px) {
  .photo-to-3d-card {
    grid-template-columns: minmax(340px, .46fr) minmax(390px, .54fr);
    min-height: 460px;
    padding: 42px 38px;
  }

  .photo-to-3d-text {
    max-width: 430px;
  }

  .photo-to-3d-features {
    grid-template-columns: repeat(2, max-content);
    gap: 16px 22px;
  }

  .photo-to-3d-feature {
    font-size: .94rem;
  }

  .photo-to-3d-visual {
    grid-template-columns: minmax(100px, 132px) minmax(30px, 52px) minmax(180px, 240px);
    column-gap: 10px;
    min-height: 320px;
    padding: 16px 0 32px;
  }

  .photo-to-3d-phone-wrap {
    left: auto;
    bottom: auto;
    transform: translateY(-24px);
    height: clamp(245px, 25vw, 300px);
  }

  .photo-to-3d-arrow {
    left: auto;
    top: auto;
    max-width: 58px;
    transform: translateY(14px);
  }

  .photo-to-3d-result-wrap {
    width: min(100%, 240px);
    min-height: clamp(235px, 26vw, 300px);
  }

  .photo-to-3d-platform {
    left: 50%;
    bottom: 20px;
    width: 220px;
    height: 46px;
  }

  .photo-to-3d-result {
    height: clamp(235px, 26vw, 300px);
    transform: translateY(-18px);
  }
}

@media (max-width: 860px) {
  .photo-to-3d-section {
    margin: 34px 0 26px;
  }

  .photo-to-3d-card {
    grid-template-columns: 1fr;
    min-height: 0;
    padding: 28px 24px 24px;
    border-radius: 28px;
  }

  .photo-to-3d-card::before {
    opacity: .18;
    right: -40px;
    width: 260px;
  }

  .photo-to-3d-card::after {
    opacity: .12;
  }

  .photo-to-3d-kicker {
    margin-bottom: 18px;
    font-size: .78rem;
  }

  .photo-to-3d-title {
    font-size: clamp(1.8rem, 10.5vw, 2.6rem);
    letter-spacing: -.045em;
  }

  .photo-to-3d-text {
    margin-top: 18px;
    font-size: 1rem;
  }

  .photo-to-3d-button {
    min-height: 50px;
    margin-top: 22px;
    padding: 0 24px;
    font-size: .98rem;
  }

  .photo-to-3d-features {
    grid-template-columns: 1fr;
    align-items: flex-start;
    gap: 14px;
    margin-top: 0;
    padding-top: 28px;
  }

  .photo-to-3d-feature br {
    display: none;
  }

  .photo-to-3d-visual {
    display: block;
    min-height: clamp(250px, 74vw, 360px);
    margin-top: 20px;
    padding: 0;
  }

  .photo-to-3d-visual::before {
    right: -14%;
    bottom: -14%;
    width: 104%;
    height: 70%;
    opacity: .7;
  }

  .photo-to-3d-phone-wrap,
  .photo-to-3d-result-wrap,
  .photo-to-3d-arrow {
    position: absolute;
  }

  .photo-to-3d-phone-wrap {
    left: 0;
    bottom: 10px;
    justify-self: auto;
    align-self: auto;
    height: clamp(220px, 58vw, 300px);
  }

  .photo-to-3d-camera {
    right: -11px;
    bottom: -8px;
    border-width: 5px;
  }

  .photo-to-3d-arrow {
    left: 43%;
    top: 55%;
    width: clamp(50px, 15vw, 70px);
    max-width: none;
    transform: translate(-50%, -50%);
  }

  .photo-to-3d-result-wrap {
    inset: 0;
    display: block;
    width: auto;
    min-height: 0;
    justify-self: auto;
    align-self: auto;
  }

  .photo-to-3d-platform {
    left: auto;
    right: -2%;
    bottom: 4px;
    width: clamp(150px, 48vw, 220px);
    height: clamp(38px, 12vw, 54px);
    transform: none;
  }

  .photo-to-3d-result {
    position: absolute;
    right: -2%;
    bottom: 28px;
    height: clamp(220px, 60vw, 300px);
    transform: none;
  }
}

@media (max-width: 430px) {
  .photo-to-3d-card {
    padding: 26px 20px 22px;
  }

  .photo-to-3d-visual {
    min-height: 246px;
  }

  .photo-to-3d-phone-wrap {
    height: 218px;
  }

  .photo-to-3d-platform {
    width: 168px;
  }

  .photo-to-3d-result {
    height: 235px;
  }

  .photo-to-3d-arrow {
    left: 44%;
    width: 52px;
  }
}






@media(max-width:760px){.site-header{align-items:flex-start;gap:12px;flex-direction:column}.layout{grid-template-columns:1fr}table{display:block;overflow-x:auto}}
.btn{display:inline-flex;align-items:center;justify-content:center;border:0;border-radius:999px;background:var(--accent);color:white;padding:12px 20px;font-weight:700;cursor:pointer;box-shadow:0 10px 24px var(--accent)33}.btn.ghost{background:white;color:var(--ink);border:1px solid var(--line);box-shadow:none}.btn.small{padding:7px 12px;font-size:.9rem}.actions{display:flex;gap:12px;flex-wrap:wrap}.grid{display:grid;gap:18px}.cards{grid-template-columns:repeat(auto-fit,minmax(220px,1fr))}.cards article,.panel,.auth,.page,.dashboard,.admin{background:var(--card);border:1px solid var(--line);border-radius:24px;padding:24px;box-shadow:0 10px 30px #1F24210a}.panel{margin:20px 0}.steps{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:12px;padding:0;counter-reset:s}.steps li{list-style:none;background:#eef8fa;border-radius:18px;padding:18px}.form{display:grid;gap:14px;max-width:560px}.form.wide{max-width:920px}.form label{display:grid;gap:6px;font-weight:650}.form label.check{display:flex;align-items:center;gap:8px;font-weight:650}.form label.check input[type="checkbox"]{width:auto;margin:0}.form input,.form textarea,.form select,.filters select{width:100%;border:1px solid var(--line);border-radius:14px;padding:12px;background:white;color:var(--ink)}textarea{min-height:110px}.two{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:14px}fieldset{border:1px solid var(--line);border-radius:18px;padding:16px}.layout{display:grid;grid-template-columns:220px 1fr;gap:20px}.layout aside,.admin-nav{background:#F4DFC3;border-radius:18px;padding:14px}.layout aside a,.admin-nav a{display:block;padding:9px 10px;border-radius:12px;color:var(--ink)}.layout aside a:hover,.admin-nav a:hover{background:white}table{width:100%;border-collapse:collapse;background:white;border-radius:18px;overflow:hidden}th,td{text-align:left;padding:12px;border-bottom:1px solid var(--line);vertical-align:top}th{background:#F4DFC3}.badge{display:inline-block;padding:5px 10px;border-radius:999px;background:#EAF6F1;color:#2F8F5B;font-weight:700}.client-toast{position:fixed;right:18px;bottom:18px;z-index:1200;max-width:min(360px,calc(100vw - 36px));padding:12px 16px;border-radius:14px;background:#1F2421;color:white;box-shadow:0 18px 44px rgba(72,45,25,.18);opacity:0;transform:translateY(10px);transition:opacity .2s ease,transform .2s ease}.client-toast.is-visible{opacity:1;transform:translateY(0)}.client-toast--error{background:#991b1b}
.flash{max-width:1180px;margin:14px auto 0;padding:12px 18px;border-radius:14px}.flash.ok{background:#EAF6F1}.flash.err{background:#ffe2e2}.two-col{display:grid;grid-template-columns:repeat(auto-fit,minmax(320px,1fr));gap:18px}.message{border-left:4px solid var(--accent);padding:8px 12px;background:#FFFCF6;margin:10px 0}.num{font-size:2rem;font-weight:800}footer{display:flex;justify-content:center;gap:18px;flex-wrap:wrap;padding:32px;color:var(--muted)}.site-footer{flex-shrink:0}

@media(prefers-reduced-motion:reduce){*,*:before,*:after{animation:none!important;transition:none!important;scroll-behavior:auto!important}}
.upload-progress{margin-top:16px;padding:14px;border:1px solid #E6D4BE;border-radius:14px;background:#FFFCF6}.upload-progress__text{font-weight:650;margin-bottom:10px}.upload-progress__bar{height:12px;background:#F4DFC3;border-radius:999px;overflow:hidden}.upload-progress__fill{height:100%;width:0%;background:#3F7467;border-radius:999px;transition:width .2s ease}.upload-progress__percent{margin-top:8px;font-size:14px;opacity:.8}.upload-progress.is-indeterminate .upload-progress__fill{width:40%;animation:uploadProgressMove 1s infinite ease-in-out}.upload-progress.is-error{border-color:#ffc6c6;background:#fff1f1}.upload-progress.is-error .upload-progress__fill{background:#d94343}@keyframes uploadProgressMove{0%{transform:translateX(-100%)}50%{transform:translateX(120%)}100%{transform:translateX(300%)}}

.upload-overlay{position:fixed;inset:0;z-index:9999;display:grid;place-items:center;padding:24px;background:radial-gradient(circle at 20% 20%,rgba(34,211,238,.32),transparent 32%),radial-gradient(circle at 85% 15%,rgba(14,165,233,.22),transparent 34%),rgba(15,23,42,.72);backdrop-filter:blur(10px);animation:uploadOverlayFade .18s ease-out}.upload-overlay__card{position:relative;width:min(92vw,520px);overflow:hidden;border:1px solid rgba(255,255,255,.7);border-radius:30px;padding:34px;background:linear-gradient(180deg,rgba(255,255,255,.98),rgba(240,249,255,.96));box-shadow:0 28px 80px rgba(15,23,42,.38);text-align:center}.upload-overlay__card:before{content:"";position:absolute;inset:-90px -120px auto auto;width:260px;height:260px;border-radius:999px;background:rgba(34,211,238,.16)}.upload-overlay__scene{position:relative;width:180px;height:122px;margin:0 auto 18px}.upload-overlay__platform{position:absolute;left:18px;right:18px;bottom:12px;height:16px;border-radius:999px;background:linear-gradient(90deg,var(--accent-dark),var(--sage),var(--accent-dark));box-shadow:0 14px 26px rgba(8,145,178,.26)}.upload-overlay__platform:before{content:"";position:absolute;left:8px;right:8px;top:-48px;height:48px;border:5px solid rgba(8,145,178,.18);border-bottom:0;border-radius:18px 18px 0 0}.upload-overlay__nozzle{position:absolute;top:18px;left:50%;width:30px;height:30px;border-radius:8px 8px 14px 14px;background:linear-gradient(180deg,#0f172a,var(--accent-dark));box-shadow:0 12px 26px rgba(8,145,178,.28);animation:uploadNozzle 1.55s ease-in-out infinite}.upload-overlay__nozzle:after{content:"";position:absolute;left:50%;top:28px;width:4px;height:44px;border-radius:999px;background:linear-gradient(180deg,var(--sage),transparent);transform:translateX(-50%)}.upload-overlay__cube{position:absolute;bottom:28px;width:42px;height:42px;border-radius:12px;background:linear-gradient(135deg,var(--sage),#0284c7);box-shadow:0 12px 22px rgba(8,145,178,.24);animation:uploadCube 1.8s ease-in-out infinite}.upload-overlay__cube:before{content:"";position:absolute;inset:8px;border:2px solid rgba(255,255,255,.55);border-radius:8px}.upload-overlay__cube--one{left:48px}.upload-overlay__cube--two{right:48px;animation-delay:.22s;transform:scale(.76)}.upload-overlay__eyebrow{margin:0 0 6px;color:var(--accent-dark);font-size:.78rem;font-weight:800;letter-spacing:.08em;text-transform:uppercase}.upload-overlay h2{margin:0;color:#1F2421;font-size:clamp(1.55rem,4vw,2.2rem)}.upload-overlay__text{margin:10px auto 8px;max-width:360px;color:#334155;font-weight:700;line-height:1.45}.upload-overlay__file{display:inline-flex;max-width:100%;margin:0 0 18px;padding:7px 12px;border-radius:999px;background:#e0f2fe;color:#0f4c81;font-size:.9rem;font-weight:700;word-break:break-word}.upload-overlay__file:empty{display:none}.upload-overlay__bar{height:16px;overflow:hidden;border-radius:999px;background:#dbeafe;box-shadow:inset 0 0 0 1px rgba(14,165,233,.08)}.upload-overlay__fill{height:100%;width:0%;border-radius:inherit;background:linear-gradient(90deg,var(--accent-dark),var(--sage),#3F7467);background-size:180% 100%;box-shadow:0 10px 24px rgba(14,165,233,.3);transition:width .22s ease;animation:uploadShimmer 1.1s linear infinite}.upload-overlay__footer{display:flex;align-items:center;justify-content:space-between;gap:14px;margin-top:14px;color:#665D53;text-align:left}.upload-overlay__percent{color:var(--accent-dark);font-size:1.55rem}.upload-overlay__close{margin:20px auto 0}.upload-overlay.is-indeterminate .upload-overlay__fill{width:48%;animation:uploadIndeterminate 1s ease-in-out infinite,uploadShimmer 1.1s linear infinite}.upload-overlay.is-error{background:rgba(127,29,29,.68)}.upload-overlay.is-error .upload-overlay__card{border-color:#fecaca;background:#fff7f7}.upload-overlay.is-error .upload-overlay__fill{width:100%;background:#ef4444}.upload-overlay.is-error .upload-overlay__eyebrow,.upload-overlay.is-error .upload-overlay__percent{color:#dc2626}@keyframes uploadOverlayFade{from{opacity:0}to{opacity:1}}@keyframes uploadNozzle{0%,100%{transform:translateX(-58px)}50%{transform:translateX(28px)}}@keyframes uploadCube{0%,100%{transform:translateY(0) rotate(-2deg)}50%{transform:translateY(-7px) rotate(3deg)}}@keyframes uploadShimmer{0%{background-position:0% 50%}100%{background-position:180% 50%}}@keyframes uploadIndeterminate{0%{transform:translateX(-115%)}50%{transform:translateX(50%)}100%{transform:translateX(210%)}}@media(max-width:520px){.upload-overlay{padding:14px}.upload-overlay__card{padding:26px 18px;border-radius:24px}.upload-overlay__footer{align-items:flex-start;flex-direction:column;gap:6px}.upload-overlay__scene{transform:scale(.9);margin-bottom:8px}}@media(prefers-reduced-motion:reduce){.upload-overlay,.upload-overlay *{animation:none!important;transition:none!important}}
/* Account dashboard layout */
.account-dashboard{
  width:100%;
  padding:24px clamp(24px,3vw,54px) 32px;
  background:transparent;
  border:0;
  border-radius:0;
  box-shadow:none;
  overflow:visible;
}
.account-shell{
  display:grid;
  grid-template-columns:220px minmax(0,1fr);
  gap:28px;
  align-items:start;
  width:min(100%,1640px);
  margin:0 auto;
  overflow:visible;
}
.account-nav{
  position:static;
  top:auto;
  align-self:start;
  z-index:2;
  background:#fffdf8;
  border:1px solid var(--line);
  border-radius:18px;
  padding:14px;
  box-shadow:0 16px 38px rgba(74,48,24,.045);
}
.account-shell--order-detail .account-nav{
  position:static;
  top:auto;
}
.account-nav a{
  position:relative;
  display:flex;
  align-items:center;
  gap:12px;
  min-height:48px;
  padding:10px 14px;
  border-radius:12px;
  color:var(--ink);
  font-weight:700;
  overflow:hidden;
}
.account-nav a::before{
  content:"";
  position:absolute;
  left:0;
  top:9px;
  bottom:9px;
  width:3px;
  border-radius:0 999px 999px 0;
  background:transparent;
}
.account-nav a:hover,
.account-nav a.active{
  background:#fff7ed;
  color:var(--accent-dark);
  box-shadow:none;
}
.account-nav a.active::before{background:var(--accent)}
.account-nav__icon{
  display:grid;
  place-items:center;
  width:22px;
  height:22px;
  flex:0 0 22px;
  color:var(--ink);
}
.account-nav__icon svg{
  display:block;
  width:22px;
  height:22px;
}
.account-nav a.active .account-nav__icon,
.account-nav a:hover .account-nav__icon{color:var(--accent)}
.account-content{
  min-width:0;
  overflow:visible;
}
.account-content .order-page{margin-top:0}
.account-addresses{margin-bottom:24px}
.table-scroll{
  width:100%;
  overflow-x:auto;
}
@media(max-width:760px){
  .account-dashboard{
    padding:20px clamp(14px,4vw,24px) 28px;
  }
  .account-shell{
    grid-template-columns:1fr;
    gap:14px;
    overflow:visible;
  }
  .account-nav{
    position:static;
    top:auto;
    z-index:1;
    display:flex;
    gap:8px;
    max-width:100%;
    overflow-x:auto;
    padding:8px;
    border-radius:14px;
    scroll-snap-type:x proximity;
    -webkit-overflow-scrolling:touch;
  }
  .account-nav a{
    flex:0 0 auto;
    white-space:nowrap;
    scroll-snap-align:start;
  }
  .account-nav a::before{
    top:auto;
    right:10px;
    left:10px;
    bottom:0;
    width:auto;
    height:3px;
    border-radius:999px 999px 0 0;
  }
  .table-scroll table{
    display:table;
    min-width:720px;
    overflow:visible;
  }
}

/* Responsive hardening for the public header and account pages. */
.site-header{gap:18px;max-width:100%;overflow:visible}.site-header .brand{flex:0 0 auto;position:relative;z-index:22}.site-header nav{min-width:0;justify-content:flex-end}.site-header nav a,.site-header nav button{white-space:nowrap}.upload-hint{margin:0;color:var(--muted);font-size:.95rem}.payment-callout{border-color:#bfeadf;background:#f2fffb}.payment-callout .num{margin:.25rem 0;color:#2F8F5B}.table-scroll{-webkit-overflow-scrolling:touch}.table-scroll table{min-width:720px}.account-content .actions,.account-content form.inline{min-width:0}.account-content .btn{max-width:100%;white-space:normal;text-align:center}
@media(min-width:1101px){.site-header nav{flex-wrap:nowrap}.site-header{padding-left:clamp(18px,3vw,42px);padding-right:clamp(18px,3vw,42px)}}
@media(max-width:1100px){.site-header{align-items:flex-start}.site-header nav{justify-content:flex-start;row-gap:8px}.site-header nav a,.site-header nav button{font-size:.95rem}}
@media(max-width:760px){body{overflow-x:hidden}body.mobile-menu-open{overflow:hidden}.site-header{position:sticky;top:0;align-items:center;justify-content:space-between;gap:12px;flex-direction:row;padding:12px 16px}.site-header .brand{position:relative;z-index:19}.js .site-header .menu-toggle{display:inline-flex;position:relative;z-index:25}.js .site-header .site-nav-backdrop{position:fixed;inset:0;z-index:23;display:block;border:0;background:rgba(72,45,25,.32);backdrop-filter:blur(5px);opacity:0;pointer-events:none;transition:opacity .22s ease}.js .site-header .site-nav{position:fixed;top:0;right:0;z-index:24;display:flex;flex-direction:column;align-items:stretch;gap:0;width:min(86vw,340px);height:100dvh;padding:88px 22px 24px;background:#fff;border-left:0;box-shadow:-18px 0 40px rgba(72,45,25,.14);transform:translateX(100%);transition:transform .24s ease}.js .site-header .site-nav a,.js .site-header .site-nav button{display:flex;align-items:center;justify-content:flex-start;min-height:46px;padding:14px 0;border:0;border-radius:0;background:transparent;color:var(--ink);font-size:1rem;font-weight:700;box-shadow:none}.js .site-header .site-nav form.inline{display:block}.js .site-header .site-nav form.inline button{width:100%;color:var(--accent)}.js .site-header.is-menu-open .brand{opacity:0;pointer-events:none}.js .site-header.is-menu-open .site-nav{transform:translateX(0)}.js .site-header.is-menu-open .site-nav-backdrop{opacity:1;pointer-events:auto}.js .site-header.is-menu-open .menu-toggle__line:nth-child(1){transform:translateY(7px) rotate(45deg)}.js .site-header.is-menu-open .menu-toggle__line:nth-child(2){opacity:0}.js .site-header.is-menu-open .menu-toggle__line:nth-child(3){transform:translateY(-7px) rotate(-45deg)}.cards article,.panel,.auth,.page,.dashboard,.admin{padding:18px}.actions{gap:8px}.actions .btn,.actions button{flex:1 1 140px}.form{max-width:100%}main{padding:20px 14px}.two{grid-template-columns:1fr}}
@media(max-width:430px){.js .site-header .site-nav{width:min(90vw,320px);padding:82px 18px 18px}.js .site-header .site-nav a,.js .site-header .site-nav button{font-size:.95rem;padding:12px 0}.btn{width:auto;padding:11px 16px}.btn.small{padding:8px 10px}.account-content .form .btn,.account-content .form button{width:100%}.table-scroll{margin-left:-6px;margin-right:-6px;padding-bottom:4px}.upload-hint{font-size:.9rem}}

.model-wizard-open{overflow:hidden}.model-wizard-overlay{position:fixed;inset:0;z-index:10000;display:flex;align-items:center;justify-content:center;padding:24px;background:rgba(74,48,24,.44);backdrop-filter:blur(14px);animation:uploadOverlayFade .22s ease}.model-wizard-overlay[hidden]{display:none}.model-wizard-card{width:min(980px,100%);max-height:min(92vh,920px);overflow:auto;border:1px solid rgba(217,120,86,.28);border-radius:30px;background:linear-gradient(180deg,#FFFDF8,#FFF7EC);box-shadow:0 30px 90px rgba(74,48,24,.18);padding:26px;position:relative}.model-wizard-close{position:absolute;right:18px;top:14px;width:38px;height:38px;border:0;border-radius:50%;background:#FDF0DF;color:#4F7F70;font-size:28px;line-height:1;cursor:pointer}.model-wizard-top{display:flex;justify-content:space-between;gap:18px;align-items:flex-start;padding-right:42px}.model-wizard-eyebrow{margin:0 0 5px;color:#D97856;font-weight:800;font-size:.78rem;letter-spacing:.1em;text-transform:uppercase}.model-wizard-title{margin:0;color:#202124;font-size:clamp(1.5rem,4vw,2.25rem)}.model-wizard-counter{white-space:nowrap;color:#D97856;font-weight:800;background:#FDF0DF;border-radius:999px;padding:8px 12px}.model-wizard-steps{display:grid;grid-template-columns:repeat(8,1fr);gap:7px;margin:20px 0}.model-wizard-steps span{height:8px;border-radius:999px;background:#E8D8C6;overflow:hidden}.model-wizard-steps span.is-active{background:linear-gradient(90deg,#D97856,#F2B39B);box-shadow:0 7px 18px rgba(217,120,86,.22)}.model-wizard-error{margin:0 0 16px;padding:12px 14px;border:1px solid #fecaca;border-radius:16px;background:#fff7f7;color:#b91c1c;font-weight:700}.model-wizard-error.is-status{border-color:#D9C8B6;background:#FFF7EC;color:#4F7F70}.model-wizard-body{min-height:340px}.model-wizard-body p{color:#5F5A52;line-height:1.55}.model-wizard-actions{display:flex;justify-content:space-between;gap:12px;margin-top:18px}.model-wizard-upload p{max-width:660px}.model-wizard-drop{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;min-height:220px;border:2px dashed #E1A083;border-radius:26px;background:rgba(253,240,223,.72);cursor:pointer;text-align:center;transition:.18s ease}.model-wizard-drop:hover{transform:translateY(-2px);box-shadow:0 18px 36px rgba(217,120,86,.14)}.model-wizard-drop input{position:absolute;opacity:0;pointer-events:none}.model-wizard-drop-icon{display:grid;place-items:center;width:64px;height:64px;border-radius:22px;background:linear-gradient(135deg,#D97856,#F2B39B);color:#fff;font-size:34px;box-shadow:0 12px 28px rgba(217,120,86,.24)}.model-wizard-file{margin:12px 0;color:#4F7F70;font-weight:800}.model-wizard-upload-progress{margin-top:14px;padding:16px;border-radius:22px;background:#fff;border:1px solid #E8D8C6}.model-wizard-progress{height:15px;overflow:hidden;border-radius:999px;background:#E8D8C6}.model-wizard-progress span{display:block;height:100%;width:0;border-radius:inherit;background:linear-gradient(90deg,#D97856,#F2B39B,#F8D979);transition:width .2s ease;animation:uploadShimmer 1.1s linear infinite}.model-wizard-percent{display:block;margin-top:8px;color:#D97856;text-align:right;font-size:1.3rem}.model-wizard-mini{display:flex;align-items:center;justify-content:space-between;gap:10px;margin:0 0 14px;padding:12px 14px;border-radius:18px;background:#FDF0DF;color:#4F7F70}.model-wizard-mini small{color:#5F5A52;font-weight:700}.model-wizard-viewer{min-height:360px;border:1px solid #E8D8C6;border-radius:24px;background:#FFFDF8;overflow:hidden;box-shadow:inset 0 0 0 1px rgba(255,253,248,.78)}.model-wizard-viewer canvas{display:block;width:100%!important;height:360px!important}.model-wizard-fallback{min-height:320px;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;gap:10px;padding:24px;color:#4F7F70;font-size:1.15rem}.model-wizard-note{padding:12px 14px;border-radius:16px;background:#FDF0DF;color:#8A4A2F!important}.model-wizard-options{display:grid;grid-template-columns:repeat(auto-fit,minmax(210px,1fr));gap:14px}.model-wizard-option-card{border:1px solid #E8D8C6;border-radius:22px;background:#fff;padding:18px;text-align:left;cursor:pointer;color:#202124;transition:.18s ease}.model-wizard-option-card:hover,.model-wizard-option-card.is-selected{border-color:#D97856;box-shadow:0 18px 34px rgba(217,120,86,.16);transform:translateY(-2px)}.model-wizard-option-card.is-selected{background:linear-gradient(180deg,#FDF0DF,#FFFDF8)}.model-wizard-option-card strong{display:block;margin-bottom:6px;color:#4F7F70}.model-wizard-option-card p{margin:0}.model-wizard-colors{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:12px}.model-wizard-color{display:flex;align-items:center;gap:10px;border:1px solid #E8D8C6;border-radius:18px;background:#fff;padding:12px;cursor:pointer;font-weight:800;color:#202124}.model-wizard-color span{width:30px;height:30px;border-radius:50%;border:2px solid rgba(74,48,24,.16);box-shadow:inset 0 0 0 1px rgba(255,255,255,.65)}.model-wizard-color.is-selected{border-color:#D97856;box-shadow:0 12px 24px rgba(217,120,86,.14)}.model-wizard-form{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px}.model-wizard-form label,.model-wizard-auth-form label{display:flex;flex-direction:column;gap:6px;color:#202124;font-weight:800}.model-wizard-form input,.model-wizard-form select,.model-wizard-form textarea,.model-wizard-auth-form input{width:100%;border:1px solid #D9C8B6;border-radius:14px;padding:11px 12px;background:#fff;font:inherit}.model-wizard-form textarea{min-height:110px}.model-wizard-form .check{flex-direction:row;align-items:center;justify-content:flex-start}.model-wizard-form .check input{width:auto}.model-wizard-form .model-wizard-note{grid-column:1/-1}.model-wizard-estimate{padding:18px;border-radius:24px;background:#fff;border:1px solid #E8D8C6}.model-wizard-estimate h3{font-size:clamp(1.6rem,4vw,2.4rem);color:#D97856;margin:12px 0}.model-wizard-breakdown{display:grid;gap:8px;margin-top:16px}.model-wizard-breakdown div{display:flex;justify-content:space-between;gap:14px;padding:10px 12px;border-radius:14px;background:#FFFDF8}.model-wizard-breakdown span{color:#5F5A52;font-weight:700}.model-wizard-breakdown strong{text-align:right;color:#202124}.model-wizard-auth{max-width:500px;margin:0 auto;padding:20px;border:1px solid #E8D8C6;border-radius:24px;background:#fff}.model-wizard-tabs{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin:16px 0}.model-wizard-tabs button{border:1px solid #E8D8C6;border-radius:999px;background:#FFFDF8;padding:10px;font-weight:800;color:#4F7F70;cursor:pointer}.model-wizard-tabs button.is-active{background:#D97856;color:#fff}.model-wizard-auth-form{display:grid;gap:12px}.model-upload-page{background:linear-gradient(135deg,#fff,#FFF7EC)}
@media(max-width:720px){.model-wizard-overlay{padding:10px;align-items:stretch}.model-wizard-card{max-height:calc(100vh - 20px);border-radius:24px;padding:18px}.model-wizard-top{display:block;padding-right:40px}.model-wizard-counter{display:inline-flex;margin-top:10px}.model-wizard-steps{gap:4px}.model-wizard-body{min-height:260px}.model-wizard-viewer,.model-wizard-viewer canvas{height:290px!important;min-height:290px}.model-wizard-form{grid-template-columns:1fr}.model-wizard-actions{position:sticky;bottom:-18px;margin-left:-18px;margin-right:-18px;padding:12px 18px;background:linear-gradient(180deg,rgba(255,247,236,.76),#FFF7EC);border-top:1px solid #E8D8C6}.model-wizard-actions .btn{flex:1}.model-wizard-breakdown div{display:block}.model-wizard-breakdown strong{text-align:left;display:block;margin-top:3px}}
.model-wizard-drop.is-dragover{border-color:#D97856;background:#FFF1DF;box-shadow:0 18px 36px rgba(217,120,86,.18);transform:translateY(-2px)}.model-wizard-upload-card{margin-top:14px;padding:18px;border-radius:24px;background:#fff;border:1px solid #E8D8C6;box-shadow:0 18px 42px rgba(217,120,86,.12)}.model-wizard-upload-head{display:flex;align-items:center;gap:14px;margin-bottom:16px}.model-wizard-upload-head strong{display:block;color:#202124;font-size:1.1rem}.model-wizard-upload-head small{display:block;color:#5F5A52;font-weight:800;margin-top:3px}.model-wizard-upload-icon{display:grid;place-items:center;width:54px;height:54px;flex:0 0 54px;border-radius:18px;background:linear-gradient(135deg,#D97856,#F2B39B);color:#fff;font-weight:800;font-size:1.6rem;box-shadow:0 12px 28px rgba(217,120,86,.22)}.model-wizard-upload-status{display:grid;gap:4px;margin-bottom:12px;color:#4F7F70}.model-wizard-upload-status strong{font-size:1.05rem}.model-wizard-upload-status small{color:#5F5A52;font-weight:700}.model-wizard-change-file{margin-top:12px;border:0;background:transparent;color:#D97856;font-weight:800;cursor:pointer;padding:0}.model-wizard-upload-success{border-color:#BFD8CA;background:linear-gradient(180deg,#F3F8F1,#FFFDF8)}.model-wizard-upload-success .model-wizard-upload-icon{background:linear-gradient(135deg,#6F9E89,#8FB9A3)}.model-wizard-upload-error{border-color:#fecaca;background:#fff7f7}.model-wizard-upload-error .model-wizard-upload-icon{background:linear-gradient(135deg,#dc2626,#f87171)}.model-wizard-upload-controls{display:flex;flex-wrap:wrap;gap:10px;margin-top:14px}.wizard-upload-progress[hidden],.wizard-upload-success[hidden],.wizard-upload-error[hidden],.wizard-upload-dropzone[hidden]{display:none!important}
.model-wizard-estimate--simple h3{margin-top:0;font-size:1.45rem}.model-wizard-size-note{margin:16px 0;padding:14px 16px;border:1px solid var(--line);border-radius:16px;background:#FFFDF8}.model-wizard-size-note p{margin:.45rem 0 0;color:var(--muted);font-size:.95rem}.model-wizard-breakdown--public{margin-top:8px}.model-wizard-breakdown--public div{align-items:center}.admin-pricing-breakdown .model-wizard-breakdown{margin-top:12px}.muted{color:var(--muted)}
.model-wizard-upload-progress.is-processing .model-wizard-progress span{width:95%!important;background:linear-gradient(90deg,#D97856 0%,#F2B39B 28%,#FDF0DF 50%,#F2B39B 72%,#D97856 100%);background-size:220% 100%;animation:modelWizardProcessingShimmer 1.05s linear infinite;transition:none}.model-wizard-upload-progress.is-processing .model-wizard-progress{position:relative}.model-wizard-upload-progress.is-processing .model-wizard-progress:after{content:"";position:absolute;inset:0;background:linear-gradient(90deg,transparent,rgba(255,255,255,.72),transparent);transform:translateX(-100%);animation:modelWizardProcessingSweep 1.2s ease-in-out infinite}.model-wizard-upload-progress.is-processing .model-wizard-percent{font-size:1rem;letter-spacing:.02em}.model-wizard-upload-progress.is-success{border-color:#BFD8CA;background:linear-gradient(180deg,#F3F8F1,#FFFDF8)}.model-wizard-upload-progress.is-success .model-wizard-upload-icon{background:linear-gradient(135deg,#6F9E89,#8FB9A3)}.model-wizard-upload-progress.is-success .model-wizard-progress span{background:linear-gradient(90deg,#6F9E89,#8FB9A3)}@keyframes modelWizardProcessingShimmer{0%{background-position:0% 50%}100%{background-position:220% 50%}}@keyframes modelWizardProcessingSweep{0%{transform:translateX(-100%)}100%{transform:translateX(100%)}}@media(prefers-reduced-motion:reduce){.model-wizard-upload-progress.is-processing .model-wizard-progress span,.model-wizard-upload-progress.is-processing .model-wizard-progress:after{animation:none!important}}
.model-wizard-next[hidden],.model-wizard-back[hidden]{display:none!important}

.hero-upload-btn{position:relative;gap:10px;overflow:hidden;isolation:isolate;background:linear-gradient(135deg,#12aeca 0%,#19bfd2 46%,#0f9fb8 100%);color:#fff;box-shadow:0 12px 26px rgba(18,174,202,.28),0 0 30px rgba(18,174,202,.16),0 0 0 1px rgba(255,255,255,.18) inset;transition:transform 220ms ease,box-shadow 220ms ease,background 220ms ease;animation:uploadCtaPulse 2.8s ease-in-out infinite}.hero-upload-btn:before{content:"";position:absolute;inset:-45% auto -45% -70%;z-index:0;width:45%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.34),transparent);transform:skewX(-18deg);animation:uploadCtaShine 4s ease-in-out infinite;pointer-events:none}.hero-upload-btn svg,.hero-upload-btn span{position:relative;z-index:1}.hero-upload-btn svg{width:20px;height:20px;flex:0 0 auto;color:#fff}.hero-upload-btn:hover{cursor:pointer;transform:translateY(-2px);background:linear-gradient(135deg,#16bdd9 0%,#22cfe0 46%,#10abc7 100%);box-shadow:0 16px 34px rgba(18,174,202,.36),0 0 38px rgba(18,174,202,.22),0 0 0 1px rgba(255,255,255,.22) inset}.hero-upload-btn:active{transform:translateY(0) scale(.98)}@keyframes uploadCtaPulse{0%,100%{transform:scale(1);box-shadow:0 12px 26px rgba(18,174,202,.28),0 0 30px rgba(18,174,202,.16),0 0 0 1px rgba(255,255,255,.18) inset}50%{transform:scale(1.018);box-shadow:0 16px 34px rgba(18,174,202,.36),0 0 42px rgba(18,174,202,.22),0 0 0 1px rgba(255,255,255,.24) inset}}@keyframes uploadCtaShine{0%{left:-70%;opacity:0}12%{opacity:.75}42%{left:125%;opacity:0}100%{left:125%;opacity:0}}@media(prefers-reduced-motion:reduce){.hero-upload-btn,.hero-upload-btn:before{animation:none!important}}

.admin-notifications h2{margin:.2rem 0 1rem}.notification-status-panel{border-width:2px;background:linear-gradient(180deg,#fff,#FFFCF6)}.notification-status-panel--ok{border-color:#bbf7d0}.notification-status-panel--warn{border-color:#fde68a}.notification-status-panel--danger{border-color:#fecaca}.notification-status-head{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;margin-bottom:18px}.notification-status-head .eyebrow{margin:0 0 4px}.status-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(170px,1fr));gap:12px}.status-card{display:grid;gap:6px;min-height:98px;padding:16px;border:1px solid var(--line);border-radius:18px;background:#fff}.status-card span,.saved-secret span{color:var(--muted);font-size:.9rem;font-weight:600}.status-card strong{font-size:1.08rem}.status-card small,.saved-secret small,.toggle-row p,.event-item p,.test-message-form span{margin:0;color:var(--muted);font-weight:600}.status-card--ok{border-color:#bbf7d0;background:#f0fdf4}.status-card--warn{border-color:#fde68a;background:#fffbeb}.status-card--danger{border-color:#fecaca;background:#fff1f2}.notice{margin-top:16px;padding:14px 16px;border-radius:16px;font-weight:800}.notice--warn{background:#fffbeb;border:1px solid #fde68a;color:#92400e}.notice--danger{background:#fff1f2;border:1px solid #fecaca;color:#991b1b}.status-badge{display:inline-flex;align-items:center;justify-content:center;width:max-content;padding:6px 11px;border-radius:999px;font-size:.88rem;font-weight:700}.status-badge--ok{background:#dcfce7;color:#166534}.status-badge--warn{background:#fef3c7;color:#92400e}.status-badge--danger{background:#fee2e2;color:#991b1b}.status-badge--muted{background:#eef2f7;color:#665D53}.toggle-row{display:flex;align-items:center;gap:14px}.toggle-row--main{padding:14px;border:1px solid var(--line);border-radius:18px;background:#FFFCF6}.switch{position:relative;display:inline-flex;width:62px;height:34px;flex:0 0 62px}.switch--small{width:50px;height:28px;flex-basis:50px}.switch input{position:absolute;opacity:0;pointer-events:none}.switch-slider{position:absolute;inset:0;border-radius:999px;background:#D9C8B6;box-shadow:inset 0 1px 3px rgba(72,45,25,.18);cursor:pointer;transition:background .18s ease}.switch-slider:before{content:"";position:absolute;top:4px;left:4px;width:26px;height:26px;border-radius:50%;background:#fff;box-shadow:0 4px 10px rgba(72,45,25,.22);transition:transform .18s ease}.switch--small .switch-slider:before{width:20px;height:20px} .switch input:checked+.switch-slider{background:var(--ok)}.switch input:checked+.switch-slider:before{transform:translateX(28px)}.switch--small input:checked+.switch-slider:before{transform:translateX(22px)}.saved-secret{display:grid;gap:5px;padding:13px 14px;border:1px solid var(--line);border-radius:16px;background:#fff}.events-list{display:grid;gap:12px}.event-item{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:14px;align-items:center;padding:14px;border:1px solid var(--line);border-radius:18px;background:#fff}.event-item strong{display:block;margin-bottom:4px}.event-actions{display:flex;align-items:center;gap:10px;justify-content:flex-end;flex-wrap:wrap}.test-message-form{display:flex;align-items:center;gap:12px;flex-wrap:wrap;margin-top:1rem}.btn-test{background:linear-gradient(135deg,var(--accent),#2F8F5B);box-shadow:0 12px 28px rgba(63,116,103,.28)}.empty-state{padding:24px;border:1px dashed #D9C8B6;border-radius:18px;background:#FFFCF6;color:var(--muted);font-weight:600;text-align:center}@media(max-width:640px){.notification-status-head,.event-item{grid-template-columns:1fr;display:grid}.event-actions{justify-content:flex-start}.status-badge{width:auto}.toggle-row--main{align-items:flex-start}.admin-notifications .table{display:block;overflow-x:auto}}
.language-dropdown{position:relative;display:inline-flex;flex:0 0 auto;margin-left:8px}.language-dropdown__button{display:inline-flex;align-items:center;justify-content:center;gap:8px;min-height:32px;padding:4px 0;color:var(--ink);font-size:.8rem;font-weight:700;line-height:1;border:0;background:transparent;box-shadow:none;cursor:pointer;transition:color .18s ease,opacity .18s ease}.language-dropdown__button:hover{color:var(--accent)}.language-dropdown__button:focus-visible{outline:2px solid rgba(74,48,24,.22);outline-offset:3px;border-radius:8px}.language-dropdown__current{letter-spacing:.08em}.language-dropdown__chevron{font-size:.72rem;transition:transform .18s ease}.language-dropdown__menu{position:absolute;top:calc(100% + 10px);right:0;z-index:40;display:grid;gap:4px;min-width:240px;padding:8px;border:1px solid rgba(20,33,61,.1);border-radius:18px;background:rgba(255,255,255,.98);box-shadow:0 22px 50px rgba(20,33,61,.16);backdrop-filter:blur(10px);opacity:0;visibility:hidden;pointer-events:none;transform:translateY(8px);transition:opacity .18s ease,visibility .18s ease,transform .18s ease}.language-dropdown.is-open .language-dropdown__menu,.language-dropdown:focus-within .language-dropdown__menu{opacity:1;visibility:visible;pointer-events:auto;transform:translateY(0)}.language-dropdown.is-open .language-dropdown__chevron,.language-dropdown:focus-within .language-dropdown__chevron{transform:rotate(180deg)}.language-dropdown__option{display:grid;grid-template-columns:auto 1fr auto;align-items:center;gap:10px;padding:10px 12px;border-radius:14px;color:var(--ink);font-size:.92rem;font-weight:700;transition:background .18s ease,color .18s ease}.language-dropdown__option:hover,.language-dropdown__option:focus-visible{background:#f3fbfe;color:var(--accent);outline:none}.language-dropdown__option.is-active{background:#e7f7fc;color:var(--accent);font-weight:700}.language-dropdown__option-code{font-size:.78rem;letter-spacing:.08em}.language-dropdown__option-name{min-width:0;color:inherit}.language-dropdown__option-check{color:var(--accent);font-size:.95rem;font-weight:800}.language-dropdown__button[aria-expanded="true"]{color:var(--accent)}
@media(max-width:760px){.language-dropdown{display:flex;width:100%;margin-left:0;margin-top:8px}.js .site-header .site-nav .language-dropdown__button{width:100%;justify-content:space-between;min-height:46px;padding:12px 0;border:0;border-radius:0;background:transparent;color:var(--ink);box-shadow:none}.js .site-header .site-nav .language-dropdown__menu{left:0;right:0;min-width:0;width:100%;max-width:100%;top:calc(100% + 8px);z-index:45;padding:8px}.js .site-header .site-nav .language-dropdown__option{display:grid;grid-template-columns:auto 1fr auto;justify-content:stretch;min-height:0;padding:12px 14px;border-radius:14px;background:transparent;color:var(--ink);font-size:.95rem;line-height:1.2}.js .site-header .site-nav .language-dropdown__option:hover,.js .site-header .site-nav .language-dropdown__option:focus-visible{background:#f3fbfe;color:var(--accent)}.js .site-header .site-nav .language-dropdown__option.is-active{background:#e7f7fc;color:var(--accent)}}
.unread-badge{display:inline-flex;align-items:center;justify-content:center;width:max-content;padding:5px 10px;border-radius:999px;background:#ffedd5;color:#9a3412;font-weight:700;font-size:.88rem;box-shadow:0 4px 12px rgba(249,115,22,.14)}.has-unread-messages{background:#fff7ed!important}.has-unread-messages td{background:#fff7ed}.cards article.has-unread-messages{border-color:#fdba74;box-shadow:0 14px 34px rgba(249,115,22,.12)}

.orders-mobile-list{display:none}
@media(max-width:760px){
  .orders-desktop{display:none}
  .orders-mobile-list{display:grid;gap:12px}
  .order-card{background:#fff;border:1px solid var(--line);border-radius:18px;padding:14px;box-shadow:0 8px 22px rgba(20,33,61,.06)}
  .order-card__top{display:flex;justify-content:space-between;gap:10px;align-items:flex-start}
  .order-card__number{font-weight:800;color:var(--ink);word-break:break-word;line-height:1.25;min-width:0}
  .order-card__status{flex:0 1 auto;max-width:52%;text-align:center;white-space:normal;word-break:break-word}
  .order-card__date{color:var(--muted);margin-top:6px;line-height:1.45}
  .order-card__rows{display:grid;gap:7px;margin:12px 0}
  .order-card__row{display:flex;justify-content:space-between;gap:12px;border-top:1px solid var(--line);padding-top:7px}
  .order-card__row span:first-child{color:var(--muted)}
  .order-card__row strong{text-align:right;word-break:break-word}
  .order-card__messages{border-top:1px solid var(--line);padding-top:7px}
  .order-card .btn{width:100%;margin-top:8px}
  .order-card.has-unread-messages{border-color:#fdba74;background:#fff7ed}
}

.cards article img{max-width:100%;height:auto;display:block}.cards article h3{margin:1rem 0 .6rem}.cards article p{margin:.75rem 0}.cards article .btn{margin-top:.35rem}.catalog-card .btn{display:inline-flex;align-items:center;justify-content:center;text-align:center;white-space:nowrap;line-height:1.1;min-height:42px;padding:10px 16px;width:100%;box-sizing:border-box}.product-facts{display:grid;gap:9px;margin:0}.product-facts div{display:flex;justify-content:space-between;gap:12px;border-top:1px solid var(--line);padding-top:9px}.product-facts dt{color:var(--muted);font-weight:700}.product-facts dd{margin:0;text-align:right;font-weight:700}.product-facts--large{margin:18px 0}.catalog-empty{display:grid;gap:12px;place-items:center}.catalog-empty h2,.catalog-empty p{margin:0}.breadcrumbs{margin-bottom:18px;color:var(--muted);font-weight:700}.product-layout{display:grid;grid-template-columns:minmax(280px,.95fr) minmax(320px,1.05fr);gap:28px;align-items:start}.product-gallery{display:grid;gap:14px}.product-gallery__main{display:block;border:1px solid var(--line);border-radius:26px;background:#fff;overflow:visible}.product-gallery__main img{display:block;max-width:100%;height:auto;margin:0 auto;border-radius:24px}.product-gallery__thumbs{display:grid;grid-template-columns:repeat(auto-fill,minmax(86px,1fr));gap:10px}.product-gallery__thumbs img{width:100%;aspect-ratio:1;border:1px solid var(--line);border-radius:14px;object-fit:cover;background:#fff}.product-summary{border:1px solid var(--line);border-radius:26px;padding:24px;background:#fff;box-shadow:0 12px 32px rgba(72,45,25,.08)}.product-summary h1{margin:.15rem 0 .5rem}.lead{color:var(--muted);line-height:1.65}.product-order-form{max-width:none}.product-auth-panel{margin:0;background:#FFFCF6}.delivery-details{border:1px solid var(--line);border-radius:18px;padding:14px;background:#FFFCF6}.delivery-details summary{cursor:pointer;font-weight:700}.delivery-details fieldset{margin-top:12px;background:#fff}.product-description{line-height:1.7}.muted{color:var(--muted)}.admin-product-thumb{width:76px;aspect-ratio:4/3;object-fit:cover;border-radius:12px;border:1px solid var(--line);background:#fff}.product-row--inactive{opacity:.68;background:#FFFCF6}.admin-product-images{display:grid;grid-template-columns:repeat(auto-fit,minmax(190px,1fr));gap:14px}.admin-product-images article{display:grid;gap:10px;padding:12px;border:1px solid var(--line);border-radius:18px;background:#fff}.admin-product-images img{width:100%;aspect-ratio:4/3;object-fit:cover;border-radius:14px;background:#eef8fa}.admin small{color:var(--muted);font-weight:600}.admin-products-table .inline{display:inline-flex;margin-left:10px}
@media(max-width:760px){.product-layout{grid-template-columns:1fr}.product-summary{padding:18px}.product-facts div{display:grid;gap:4px}.product-facts dd{text-align:left}.admin-products-table .inline{display:block;margin:8px 0 0}.admin-product-thumb{width:64px}}
.catalog-card{position:relative}.catalog-card__meta{display:flex;align-items:center;justify-content:space-between;gap:12px;margin:8px 0 14px}.catalog-card__price{margin:0;font-weight:700}.product-like{position:static;display:inline-flex;align-items:center;justify-content:center;gap:5px;min-width:auto;min-height:auto;padding:0;border:0;border-radius:0;background:transparent;color:var(--ink);font-weight:700;cursor:pointer;box-shadow:none;transition:transform .16s ease,color .16s ease}.product-like:hover{transform:scale(1.06)}.product-like:disabled{cursor:default;opacity:.75}.product-like.is-liked{color:#B42318;border:0;background:transparent;box-shadow:none}.product-like__icon{font-size:1.05rem;line-height:1}.product-like__count{font-size:.85rem;line-height:1}.product-like.is-popping{animation:productLikePop .32s ease}@keyframes productLikePop{0%{transform:scale(1)}45%{transform:scale(1.18)}100%{transform:scale(1)}}.like-burst{position:absolute;pointer-events:none;inset:0;overflow:hidden;z-index:3}.like-burst span{position:absolute;left:var(--like-burst-x,calc(100% - 36px));top:var(--like-burst-y,20px);color:#B42318;font-size:14px;opacity:0;animation:likeHeartFloat .85s ease-out forwards}@keyframes likeHeartFloat{0%{transform:translate(-50%,-50%) scale(.7);opacity:0}20%{opacity:1}100%{transform:translate(calc(var(--x) - 50%),calc(var(--y) - 50%)) scale(1.25);opacity:0}}

/* Warm handmade workshop public landing */
:root{--font-sans:"Manrope",system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;--font-serif:Georgia,"Times New Roman",serif;--bg:#FFF7EC;--card:#FFFDF8;--ink:#202124;--muted:#5F5A52;--accent:#B6533A;--accent-dark:#8F3C28;--sage:#4F7F70;--sage-dark:#386457;--cream:#FDF0DF;--line:#E8D8C6}html{overflow-x:hidden;scroll-padding-top:88px}body{overflow-x:hidden;background:var(--bg);color:var(--ink)}.body-public{padding-top:72px}a{color:var(--sage-dark)}main{max-width:none;padding:0}.site-header{height:72px;padding:10px clamp(18px,4vw,42px);background:rgba(255,247,236,.92);border-bottom:0;box-shadow:0 10px 35px rgba(74,48,24,.05);backdrop-filter:blur(16px)}.body-public .site-header{position:fixed;top:0;left:0;right:0;width:100%;z-index:1000}.site-header--admin{height:auto;background:#fffcf6f0;border-bottom:1px solid var(--line)}.brand{display:flex;flex-direction:column;align-items:flex-start;gap:0;color:#111;line-height:.82;text-transform:uppercase}.brand__stack{display:grid;font-weight:800;font-size:1.28rem;letter-spacing:-.025em}.brand__script,.site-footer__brand em{font-family:var(--font-serif);font-style:italic;text-transform:none;color:var(--accent);font-weight:700;letter-spacing:.04em}.site-nav{display:flex;align-items:center;gap:22px;flex:1;justify-content:flex-end}.site-nav__links,.site-nav__actions{display:flex;align-items:center;gap:clamp(12px,2.1vw,30px)}.site-nav__actions{gap:18px}.site-nav__links a{color:#1f1f1f;font-weight:600;font-size:.94rem}.header-cta,.btn--warm{background:var(--accent);color:#fff!important;border-radius:16px;box-shadow:0 14px 24px rgba(201,95,67,.2)}.header-cta{padding:14px 22px;font-weight:700}.header-cta:hover,.btn--warm:hover{background:var(--accent-dark);transform:translateY(-1px)}.account-icon{display:grid;place-items:center;color:#111}.account-icon svg{width:28px;height:28px}.nav-logout button{color:var(--muted);font-weight:700}.language-dropdown__button{border:0;background:transparent;color:#111;font-weight:700}.language-dropdown__menu{background:#fffdf8;border-color:var(--line);box-shadow:0 20px 50px rgba(74,48,24,.14)}

.home-hero {
    position: relative;
    isolation: isolate;
    overflow: hidden;
    min-height: clamp(720px, 78vh, 920px);
    padding: clamp(82px, 9vh, 128px) 24px 120px;
    background:
        radial-gradient(circle at 80% 30%, rgba(234, 170, 116, 0.24), transparent 38%),
        linear-gradient(180deg, #fff7ec 0%, #fff1df 100%);
}
.home-hero__inner {
    position: relative;
    z-index: 3;
    max-width: 1180px;
    margin: 0 auto;
    min-height: 560px;
    display: flex;
    align-items: center;
}
.home-hero__content {
    position: relative;
    z-index: 3;
    width: min(48vw, 660px);
    max-width: 660px;
    padding: 34px 36px 32px;
    border-radius: 38px;
    isolation: isolate;
}
.home-hero__content::before {
    content: "";
    position: absolute;
    z-index: -1;
    inset: -18px -34px -20px -30px;
    border-radius: 46px;
    background:
        radial-gradient(circle at 18% 18%, rgba(255, 255, 255, 0.96), rgba(255, 253, 248, 0.74) 38%, rgba(255, 247, 236, 0.28) 72%, transparent 100%),
        linear-gradient(115deg, rgba(255, 247, 236, 0.96) 0%, rgba(255, 247, 236, 0.72) 58%, rgba(255, 247, 236, 0) 100%);
    box-shadow: 0 28px 90px rgba(74, 48, 24, 0.12);
    backdrop-filter: blur(10px) saturate(1.04);
}
.hand-note{position:relative;display:inline-block;margin:0 0 22px;color:var(--accent);font-family:var(--font-serif);font-style:italic;font-size:1.25rem;letter-spacing:.06em}.scribble-rays:after{content:"";position:absolute;width:44px;height:24px;right:-58px;top:50%;transform:translateY(-50%);background:linear-gradient(75deg,transparent 45%,var(--accent) 46% 52%,transparent 53%),linear-gradient(105deg,transparent 45%,var(--accent) 46% 52%,transparent 53%),linear-gradient(0deg,transparent 45%,var(--accent) 46% 52%,transparent 53%);opacity:.75}
.home-hero h1,
.home-hero__title {
    margin: 0 0 22px;
    font-family: var(--font-sans);
    font-size: clamp(48px, 3vw, 56px);
    line-height: 1.04;
    letter-spacing: -0.025em;
    font-weight: 800;
    color: #202124;
    max-width: 660px;
}

.home-hero__title-line {
    display: block;
}
.home-hero__text {
    max-width: 500px;
    margin: 0;
    color: #302b27;
    font-size: 1.03rem;
    line-height: 1.58;
}
.home-hero__actions {
    margin-top: 28px;
    display: flex;
    flex-wrap: wrap;
    gap: 14px;
}
.home-hero__bg {
    position: absolute;
    z-index: 1;
    inset: 0;
    pointer-events: none;
}
.home-hero__bg::before {
    content: "";
    position: absolute;
    z-index: 2;
    inset: 0;
    background:
        linear-gradient(180deg,
            rgba(255, 247, 236, 0.90) 0%,
            rgba(255, 247, 236, 0) 18%,
            rgba(255, 247, 236, 0) 68%,
            #fff1df 100%
        ),
        radial-gradient(circle at 82% 34%, rgba(217, 120, 86, 0.18), transparent 34%);
    pointer-events: none;
}
.home-hero__bg picture {
    display: block;
    width: 100%;
    height: 100%;
}

.home-hero__bg img {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center right;
    display: block;
    filter: saturate(1.04) contrast(1.03);
}
.btn{gap:10px;transition:.2s ease}.btn svg{width:24px;height:24px;flex:0 0 auto}.btn--milk,.btn--light{background:#fffdf8;color:var(--ink)!important;border:1.5px solid var(--accent);box-shadow:0 10px 24px rgba(74,48,24,.06)}.btn--sage{background:var(--sage);color:#fff!important}.btn--dark{background:#173C35;color:#fff!important}.trust-mini{display:flex;align-items:center;gap:0;margin-top:36px}.trust-mini span{width:38px;height:38px;border:3px solid #fff;border-radius:50%;margin-right:-8px;background:linear-gradient(135deg,#f6c8a8,#6f9e89);box-shadow:0 8px 18px rgba(74,48,24,.12)}.trust-mini span:nth-child(2){background:linear-gradient(135deg,#f3c85f,#fff6ea)}.trust-mini span:nth-child(3){background:linear-gradient(135deg,#c8a9be,#f2b39b)}.trust-mini span:nth-child(4){background:linear-gradient(135deg,#a9c6c9,#d4b995);margin-right:14px}.trust-mini p{margin:0;color:var(--muted);line-height:1.3}.trust-mini strong{color:var(--accent)}
.trust-strip {
    position: relative;
    z-index: 5;
    max-width: 1180px;
    margin: -76px auto 58px;
    padding: 28px 34px;
    border-radius: 30px;
    background: rgba(255, 253, 248, 0.94);
    box-shadow: 0 24px 70px rgba(74, 48, 24, 0.10);
    backdrop-filter: blur(12px);
    display: grid;
    grid-template-columns: repeat(4, 1fr);
}
.trust-strip article {
    display: flex;
    gap: 18px;
    align-items: flex-start;
    padding: 0 24px;
    border-right: 1px solid rgba(74, 48, 24, 0.12);
}
.trust-strip article:first-child {
    padding-left: 0;
}
.trust-strip article:last-child {
    border-right: 0;
    padding-right: 0;
}
.trust-icon{display:grid;place-items:center;flex:0 0 58px;height:58px;border-radius:50%;background:#fff1df;color:var(--accent);font-size:2rem}.trust-icon--2,.trust-icon--3{color:var(--sage-dark)}.trust-strip h3{margin:.3rem 0 .45rem;font-size:1rem}.trust-strip p{margin:0;color:var(--muted);font-size:.9rem;line-height:1.45}

.section-block{
    max-width:1180px;
    margin:0 auto 54px;
    padding:0 24px;
}
.section-heading{
    display:flex;
    align-items:center;
    justify-content:space-between;
    gap:16px;
    margin-bottom:14px;
}
.section-heading h2,
.process h2,
.photo-workshop h2,
.workshop-cta h2{
    font-family:var(--font-sans);
    font-size:clamp(1.85rem,1.05rem + 1.5vw,2rem);
    font-weight:700;
    line-height:1.08;
    letter-spacing:-.015em;
    margin:0;
}
.scribble-underline{
    position:relative;
    display:inline-block;
}
.scribble-underline:after{
    content:"";
    position:absolute;
    left:0;
    bottom:-8px;
    width:88px;
    height:8px;
    background:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 90 8'%3E%3Cpath d='M2 5c12-6 18 4 30-1s18 5 31 0 17 2 25 0' fill='none' stroke='%23D97856' stroke-width='2' stroke-linecap='round'/%3E%3C/svg%3E") center/contain no-repeat;
}
.category-grid,
.works-grid{
    display:grid;
    grid-template-columns:repeat(6,1fr);
    gap:20px;
}
.category-card{position:relative;min-height:205px;border-radius:20px;padding:20px 16px 18px;text-align:center;box-shadow:0 14px 28px rgba(74,48,24,.1);transition:.2s ease;overflow:hidden}.category-card:hover,.work-card:hover{transform:translateY(-3px);box-shadow:0 20px 36px rgba(74,48,24,.14)}.category-card--1{background:#F8D979}.category-card--2{background:#8FB9A3}.category-card--3{background:#F2B39B}.category-card--4{background:#A9C6C9}.category-card--5{background:#C8A9BE}.category-card--6{background:#D4B995}.category-card picture{display:inline-block;width:120px;height:120px}.category-card img{width:120px;height:120px;object-fit:contain;filter:drop-shadow(0 12px 12px rgba(0,0,0,.16))}.category-card h3{margin:8px 0 0;font-family:var(--font-sans);font-weight:700;font-size:1.16rem;line-height:1.2;white-space:pre-line}
.process-steps{
    position:relative;
    display:grid;
    grid-template-columns:repeat(5,1fr);
    gap:24px;
    margin-top:18px;
}
.process-steps:before{content:"";position:absolute;left:7%;right:7%;top:28px;height:18px;background:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 760 30'%3E%3Cpath d='M0 14c60-20 100 20 160 0s105 19 170 0 110 20 175 0 115 18 255 0' fill='none' stroke='%238FB9A3' stroke-width='2' stroke-dasharray='6 7' stroke-linecap='round'/%3E%3C/svg%3E") center/100% 100% no-repeat}.process-step{position:relative;z-index:1}.process-step span{display:grid;place-items:center;width:58px;height:58px;border-radius:50%;color:#fff;font-weight:800;font-size:1.5rem;box-shadow:0 10px 20px rgba(74,48,24,.12)}.process-step--1 span{background:#F3C85F}.process-step--2 span{background:#6F9E89}.process-step--3 span{background:#D97856}.process-step--4 span{background:#A9C6C9}.process-step--5 span{background:#C8A9BE}.process-step h3{font-size:1rem;margin:16px 0 8px}.process-step p,.work-card p{color:var(--muted);line-height:1.45;margin:0}.work-card__image{position:relative;display:grid;place-items:center;height:148px;border-radius:14px;background:linear-gradient(135deg,#e9c59d,#6a4b34);overflow:hidden}.work-card__image img{max-width:78%;max-height:130px;object-fit:contain;filter:drop-shadow(0 14px 14px rgba(0,0,0,.18))}.work-card__image span{position:absolute;right:10px;bottom:9px;color:#fff;background:rgba(32,33,36,.55);border-radius:999px;padding:5px 9px;font-weight:700}.work-card h3{margin:12px 0 4px;font-size:.98rem}.work-card h3 a{color:inherit;text-decoration:none}.work-card__image{text-decoration:none}.photo-workshop{max-width:1180px;margin:0 auto 58px;padding:34px 44px;border-radius:26px;background:radial-gradient(circle at 55% 20%,rgba(255,255,255,.55),transparent 34%),#F9E7D3;display:grid;grid-template-columns:.9fr 1.35fr .9fr;gap:28px;align-items:center}.photo-workshop__copy p{color:#3b352f;line-height:1.55}.photo-workshop__visual{display:flex;align-items:center;justify-content:center;gap:18px;min-height:210px}.taped-photo{position:relative;padding:12px;background:#fff;box-shadow:0 14px 25px rgba(74,48,24,.13);transform:rotate(-3deg)}.taped-photo picture{display:block}.taped-photo img{width:130px;height:150px;object-fit:cover}.hand-arrow{width:120px;fill:none;stroke:var(--sage-dark);stroke-width:3;stroke-linecap:round;stroke-linejoin:round}.figure-ready picture{display:block}.figure-ready img{height:180px;object-fit:contain;filter:drop-shadow(0 16px 16px rgba(74,48,24,.16))}.photo-workshop__list{display:grid;gap:20px;margin:0;padding:0;list-style:none}.photo-workshop__list li{position:relative;padding-left:34px}.photo-workshop__list li:before{content:"✓";position:absolute;left:0;top:-2px;display:grid;place-items:center;width:22px;height:22px;border:1.5px solid var(--sage-dark);border-radius:50%;color:var(--sage-dark);font-weight:800}.workshop-cta{max-width:1180px;margin:0 auto 24px;display:grid;grid-template-columns:1.2fr 1fr 1.18fr;border-radius:22px;overflow:hidden}.workshop-cta__image{min-height:245px;background:radial-gradient(circle at 30% 45%,#e7aa6e,transparent 18%),linear-gradient(135deg,#2b1f16,#765032 60%,#1b231f)}.mini-printer{width:150px;height:125px;margin:74px auto;border:12px solid #141414;border-bottom-width:24px;border-radius:8px}.workshop-cta__about{background:#173C35;color:#fff;padding:34px 38px}.workshop-cta__about p{color:#fff4e6;line-height:1.6}.workshop-cta__about div{display:flex;gap:18px;flex-wrap:wrap;margin-top:22px}.workshop-cta__about span{color:#fffdf8;font-weight:800}.workshop-cta__idea{position:relative;background:#F2A78E;padding:34px 38px}.idea-title:after{content:"💡";font-family:var(--font-sans);position:absolute;right:28px;top:28px;font-size:2rem}.workshop-cta__idea p{line-height:1.6;color:#3a2822}.site-footer{max-width:1180px;margin:0 auto;padding:22px 24px 26px;background:transparent;color:var(--muted);display:grid;grid-template-columns:auto 1fr auto auto;gap:18px;align-items:center;border-top:0}.site-footer__brand strong{display:grid;color:#111;line-height:.82;font-size:1.15rem}.site-footer__brand{display:grid}.site-footer__links{display:flex;gap:18px;flex-wrap:wrap;justify-content:center}.site-footer__links a{color:#202124;font-size:.9rem}.site-footer__social{display:flex;gap:10px}.site-footer__social a{display:grid;place-items:center;width:36px;height:36px;border-radius:50%;background:#fff6ea;color:#173C35}.site-footer small{grid-column:2/3;color:#6f655b}

@media(max-width:1120px){.site-nav__links{gap:14px}.category-grid,.works-grid{grid-template-columns:repeat(3,1fr)}.photo-workshop{margin-left:24px;margin-right:24px;grid-template-columns:1fr}.workshop-cta{margin-left:24px;margin-right:24px;grid-template-columns:1fr 1fr}.workshop-cta__idea{grid-column:1/-1}}
@media (max-width: 960px) {
    .home-hero {
        min-height: auto;
        padding: 44px 20px 64px;
    }

    .home-hero__inner {
        min-height: auto;
        display: block;
    }

    .home-hero__content {
        width: 100%;
        max-width: 680px;
        padding: 24px 22px;
    }

    .home-hero__content::before {
        inset: 0;
        border-radius: 28px;
    }

    .home-hero__bg {
        display: none;
    }

    .home-hero__bg::before {
        background: none;
    }

    .home-hero__bg picture {
    display: block;
    width: 100%;
    height: 100%;
}

.home-hero__bg img {
        position: relative;
        width: 100%;
        height: auto;
        object-fit: contain;
    }


    .trust-strip {
        margin: -44px 20px 48px;
        grid-template-columns: 1fr 1fr;
    }

    .trust-strip article,
    .trust-strip article:first-child,
    .trust-strip article:last-child {
        padding: 20px;
    }

    .trust-strip article:nth-child(2n) {
        border-right: 0;
    }

    .trust-strip article:nth-last-child(-n+2) {
        border-bottom: 0;
    }

    .trust-strip article {
        border-bottom: 1px solid rgba(74, 48, 24, 0.12);
    }
}

@media (min-width: 861px) {
    .home-hero__title-line {
        white-space: nowrap;
    }
}

@media(max-width:860px){.site-header{height:auto;min-height:72px;align-items:center;flex-direction:row}.menu-toggle{display:flex;color:var(--accent);z-index:42}.site-nav{position:fixed;inset:0 0 auto auto;top:0;width:min(360px,88vw);height:100vh;padding:94px 24px 28px;background:#fff7ec;box-shadow:-20px 0 50px rgba(74,48,24,.16);transform:translateX(100%);transition:transform .22s ease,visibility .22s ease;z-index:40;display:block;overflow:auto;visibility:hidden;pointer-events:none}.site-header.is-menu-open .site-nav{transform:translateX(0);visibility:visible;pointer-events:auto}.site-nav__links,.site-nav__actions{display:grid;gap:18px;justify-items:start}.site-nav__actions{margin-top:14px}.site-nav-backdrop{display:block;position:fixed;inset:0;background:rgba(23,60,53,.28);z-index:35}.site-header:not(.is-menu-open) .site-nav-backdrop{display:none}.process-steps{grid-template-columns:1fr}.process-steps:before{left:28px;top:0;bottom:0;width:3px;height:auto;background:linear-gradient(var(--sage),var(--sage)) center/2px 100% no-repeat}.process-step{display:grid;grid-template-columns:70px 1fr;gap:0 14px}.process-step span{grid-row:1/3}.process-step h3{margin-top:0}.photo-workshop__visual{justify-content:flex-start;transform:scale(.9);transform-origin:left center}.workshop-cta{grid-template-columns:1fr}.site-footer{grid-template-columns:1fr;text-align:left}.site-footer__links{justify-content:flex-start}.site-footer small{grid-column:auto}}
@media (max-width: 620px) {
    .home-hero h1 {
        font-size: clamp(2.35rem, 11vw, 3.25rem);
        line-height: 1;
    }

    .home-hero__actions {
        display: grid;
        grid-template-columns: 1fr;
    }

    .home-hero__actions .btn {
        width: 100%;
        justify-content: center;
    }

    .trust-strip {
        grid-template-columns: 1fr;
        padding: 24px;
    }

    .trust-strip article,
    .trust-strip article:first-child,
    .trust-strip article:last-child {
        padding: 18px 0;
        border-right: 0;
        border-bottom: 1px solid rgba(74, 48, 24, 0.12);
    }

    .trust-strip article:first-child {
        padding-top: 0;
    }

    .trust-strip article:last-child {
        border-bottom: 0;
        padding-bottom: 0;
    }
}


/* Mobile viewport guard: decorative strokes must not create horizontal scrolling. */
@media(max-width:620px){
    html,
    body,
    main{
        max-width:100%;
        overflow-x:hidden;
    }

    main{
        overflow:hidden;
    }

    .home-hero{
        padding-left:0;
        padding-right:0;
        overflow:hidden;
    }

    .home-hero__inner,
    .home-hero__content{
        max-width:100%;
    }

    .home-hero .scribble-rays::after{
        content:none;
    }
}

@media(max-width:560px){.trust-mini{align-items:flex-start}.category-grid{grid-template-columns:1fr 1fr;gap:14px}.works-grid{grid-template-columns:1fr}.category-card{min-height:178px}.category-card picture,.category-card img{width:100px;height:100px}.section-heading{align-items:flex-start;flex-direction:column}.photo-workshop{padding:28px 22px}.photo-workshop__visual{transform:scale(.72);height:180px}.workshop-cta__about,.workshop-cta__idea{padding:28px 24px}.site-footer__links{display:grid;gap:10px}}
.site-header--admin .brand{display:inline-flex;text-transform:none;line-height:1}.site-header--admin .brand__plain{font-size:1.35rem;font-weight:800;letter-spacing:0;color:var(--ink)}

.print-categories,
.process,
.recent-works,
.photo-workshop,
.workshop-cta {
    content-visibility: auto;
    contain-intrinsic-size: 600px;
}

/* Reference-style order process: hand-drawn number seals with arrowed paths. */
.process-steps .process-connector {
    position: absolute;
    z-index: 0;
    left: 0;
    right: 0;
    top: 0;
    width: 100%;
    height: 86px;
    pointer-events: none;
    overflow: visible;
}

.process-steps .process-connector > path {
    fill: none;
    stroke: #9db7ad;
    stroke-width: 1.55;
    stroke-dasharray: 6 7;
    stroke-linecap: round;
    stroke-linejoin: round;
    marker-end: url(#process-arrow);
}

.process-steps .process-connector marker path {
    fill: none;
    stroke: #9db7ad;
    stroke-width: 1.8;
    stroke-dasharray: none;
    stroke-linecap: round;
    stroke-linejoin: round;
    marker-end: none;
}

.process-steps::before {
    display: none;
}

.process-step {
    isolation: isolate;
}

.process-step span {
    position: relative;
    z-index: 2;
    width: 55px;
    height: 55px;
    border-radius: 56% 44% 51% 49% / 48% 58% 42% 52%;
    font-family: var(--font-sans);
    font-weight: 800;
    line-height: 1;
    transform: rotate(-2deg);
}

.process-step span::before {
    content: "";
    position: absolute;
    inset: -5px -6px -4px -5px;
    z-index: -1;
    border-radius: 46% 54% 43% 57% / 55% 45% 55% 45%;
    background: inherit;
    opacity: .42;
    transform: rotate(9deg) scale(.92, .96);
}

.process-step span::after {
    content: "";
    position: absolute;
    inset: 7px 8px 9px 7px;
    border-radius: 54% 46% 57% 43% / 46% 54% 44% 56%;
    background: rgba(255, 255, 255, .16);
    pointer-events: none;
}

.process-step--2 span,
.process-step--4 span {
    transform: rotate(3deg);
}

.process-step--3 span,
.process-step--5 span {
    transform: rotate(-5deg);
}

@media(max-width:860px) {
    .process-steps .process-connector {
        display: none;
    }

    .process-steps::before {
        display: block;
        background: linear-gradient(#9db7ad, #9db7ad) center/2px 100% no-repeat;
    }
}

/* Keep recent work captions fixed while the preview image lifts on hover. */
.recent-works .work-card {
    transition: opacity .32s ease;
    will-change: opacity;
}

.recent-works .work-card.is-rotating-out {
    opacity: 0;
    pointer-events: none;
}

.recent-works .work-card.is-rotating-in {
    pointer-events: none;
}

@media (prefers-reduced-motion: reduce) {
    .recent-works .work-card {
        transition: none;
    }
}

.recent-works .work-card:hover {
    transform: none;
    box-shadow: none;
}

@media(min-width:561px){
    .recent-works .works-grid{
        align-items:start;
    }

    .recent-works .work-card h3{
        min-height:2.3em;
        line-height:1.15;
        overflow:hidden;
        display:-webkit-box;
        -webkit-line-clamp:2;
        -webkit-box-orient:vertical;
    }
}

.recent-works .work-card__image {
    transition: transform .2s ease, box-shadow .2s ease;
    backface-visibility:hidden;
    -webkit-backface-visibility:hidden;
    transform:translateZ(0);
}

.recent-works .work-card__image img {
    width: 100%;
    height: 100%;
    max-width: none;
    max-height: none;
    object-fit: cover;
    filter: none;
    backface-visibility:hidden;
    -webkit-backface-visibility:hidden;
    transform:translateZ(0);
}

.recent-works .work-card:hover .work-card__image {
    transform: translate3d(0,-3px,0);
    box-shadow: 0 20px 36px rgba(74,48,24,.14);
}

.recent-works .work-card.is-rotating-out .work-card__image,
.recent-works .work-card.is-rotating-in .work-card__image,
.recent-works .work-card.is-rotating-out:hover .work-card__image,
.recent-works .work-card.is-rotating-in:hover .work-card__image {
    transform:translateZ(0);
    box-shadow:none;
}

/* Reference-style workshop CTA block. Left image is expected at /assets/img/workshop/workshop-cta.jpg. */
.workshop-cta{
    max-width:1180px;
    min-height:162px;
    margin:0 auto 24px;
    display:grid;
    grid-template-columns:minmax(330px,1.03fr) minmax(270px,.92fr) minmax(385px,1.22fr);
    gap:0;
    overflow:hidden;
    border-radius:11px;
    background:#173c35;
    box-shadow:none;
}
.workshop-cta__image{
    min-height:162px;
    background-color:#5d3c25;
    background-image:
        linear-gradient(90deg,rgba(7,12,10,.05),rgba(7,12,10,.13)),
        image-set(
            url('/assets/img/workshop/workshop-cta.webp') type('image/webp'),
            url('/assets/img/workshop/workshop-cta.jpg') type('image/jpeg')
        ),
        radial-gradient(circle at 14% 16%,rgba(234,162,82,.28),transparent 20%),
        linear-gradient(135deg,#24180f,#7a5131 58%,#15231c);
    background-size:cover,cover,cover,cover;
    background-position:center;
}
.workshop-cta__about{
    display:flex;
    flex-direction:column;
    justify-content:center;
    min-height:162px;
    padding:18px 28px 18px 34px;
    background:#173c35;
    color:#fff8ec;
}
.workshop-cta__about h2,
.workshop-cta__idea h2{
    margin:0;
    font-family:var(--font-sans);
    font-size:21px;
    line-height:1.05;
    font-weight:800;
    letter-spacing:.01em;
}
.workshop-cta__about h2{
    position:relative;
    display:inline-block;
    width:max-content;
    color:#fff8ec;
}
.workshop-cta__about h2::after{
    content:"";
    position:absolute;
    left:0;
    right:4px;
    bottom:-5px;
    height:6px;
    background:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 150 12'%3E%3Cpath d='M3 8c18-9 34 6 52-1 15-6 27 4 43-1 17-5 29 4 48-2' fill='none' stroke='%23f0a26f' stroke-width='3' stroke-linecap='round'/%3E%3C/svg%3E") center/100% 100% no-repeat;
}
.workshop-cta__about p,
.workshop-cta__idea p{
    margin:17px 0 0;
    max-width:340px;
    font-size:12px;
    line-height:1.5;
    font-weight:650;
}
.workshop-cta__about p{color:#fff7e6;}
.workshop-cta__points{
    display:grid !important;
    grid-template-columns:repeat(3,minmax(0,1fr));
    gap:13px;
    margin-top:17px !important;
}
.workshop-cta__point{
    display:grid;
    grid-template-rows:22px auto;
    justify-items:center;
    align-items:start;
    gap:3px;
    min-width:0;
    color:#fff7e6 !important;
    font-size:11px;
    line-height:1.07;
    font-weight:700;
    text-align:center;
}
.workshop-cta__point svg{
    width:31px;
    height:24px;
    fill:none;
    stroke:#e1ad74;
    stroke-width:2.25;
    stroke-linecap:round;
    stroke-linejoin:round;
    overflow:visible;
}
.workshop-cta__idea{
    position:relative;
    display:flex;
    flex-direction:column;
    justify-content:center;
    min-height:162px;
    margin-left:-45px;
    padding:20px 34px 20px 82px;
    background:#f2a287;
    clip-path:polygon(10% 0,100% 0,100% 100%,0 100%);
    color:#271a16;
}
.workshop-cta__idea h2{color:#271a16;font-size:24px;}
.idea-title::after{content:none !important;}
.idea-bulb{
    position:absolute;
    top:25px;
    right:27px;
    width:54px;
    height:54px;
    fill:none;
    stroke:#b16b52;
    stroke-width:1.9;
    stroke-linecap:round;
    stroke-linejoin:round;
    opacity:.86;
}
.workshop-cta__idea p{
    max-width:330px;
    color:#3c2922;
}
.workshop-cta__actions{
    display:flex;
    flex-wrap:wrap;
    gap:30px;
    margin-top:18px;
}
.workshop-cta__actions .btn{
    min-height:38px;
    padding:0 22px;
    border:0;
    border-radius:10px;
    font-size:13px;
    line-height:1;
    font-weight:800;
    letter-spacing:-.01em;
    box-shadow:none;
}
.workshop-cta__actions .btn svg{
    width:21px;
    height:21px;
    fill:none;
    stroke:currentColor;
    stroke-width:1.9;
    stroke-linecap:round;
    stroke-linejoin:round;
}
.workshop-cta__actions .btn--dark{background:#254f45;color:#fffdf5;}
.workshop-cta__actions .btn--light{background:#fff7ed;color:#20201e;}
@media(max-width:1120px){
    .workshop-cta{
        margin-left:24px;
        margin-right:24px;
        grid-template-columns:1fr 1fr;
    }
    .workshop-cta__image{min-height:210px;}
    .workshop-cta__about{min-height:210px;}
    .workshop-cta__idea{
        grid-column:1/-1;
        margin-left:0;
        padding-left:38px;
        clip-path:none;
    }
}
@media(max-width:760px){
    .workshop-cta{grid-template-columns:1fr;border-radius:14px;}
    .workshop-cta__image{min-height:190px;}
    .workshop-cta__about{padding:26px 24px;}
    .workshop-cta__points{grid-template-columns:repeat(3,1fr);}
    .workshop-cta__idea{padding:28px 24px;}
    .idea-bulb{top:20px;right:18px;width:46px;height:46px;}
    .workshop-cta__idea p{padding-right:42px;}
    .workshop-cta__actions{gap:12px;}
}
@media(max-width:430px){
    .workshop-cta__points{grid-template-columns:1fr;justify-items:start;}
    .workshop-cta__point{grid-template-columns:34px 1fr;grid-template-rows:auto;justify-items:start;text-align:left;align-items:center;}
    .workshop-cta__actions .btn{width:100%;justify-content:center;}
}

/* Prevent closed mobile navigation and wide flex text from creating sideways page panning. */

@media(max-width:860px){
    html,
    body{
        width:100%;
        max-width:100%;
        overflow-x:hidden;
        overscroll-behavior-x:none;
    }

    body{
        position:relative;
    }

    .body-public .site-header{
        max-width:100vw;
        overflow:hidden;
    }

    .body-public .site-header.is-menu-open{
        overflow:visible;
    }

    .body-public .site-header .site-nav{
        right:0;
        transform:none;
        opacity:0;
        visibility:hidden;
        pointer-events:none;
    }

    .body-public .site-header.is-menu-open .site-nav{
        transform:none;
        opacity:1;
        visibility:visible;
        pointer-events:auto;
    }

    .body-public .site-header:not(.is-menu-open) .site-nav{
        box-shadow:none;
    }

    .trust-mini{
        min-width:0;
        max-width:100%;
        flex-wrap:wrap;
    }

    .trust-mini p{
        min-width:0;
        max-width:100%;
    }
}

/* Mobile recent works: show one square catalog card and let JS rotate it randomly. */
@media(max-width:560px){
    .recent-works .works-grid{
        display:block;
    }

    .recent-works .work-card{
        display:none;
        position:relative;
        overflow:hidden;
        border-radius:28px;
        background:#f8ead9;
        box-shadow:0 18px 34px rgba(74,48,24,.12);
    }

    .recent-works .work-card:first-child,
    .recent-works .works-grid.is-mobile-shuffling .work-card.is-mobile-active{
        display:block;
    }

    .recent-works .works-grid.is-mobile-shuffling .work-card:first-child{
        display:none;
    }

    .recent-works .works-grid.is-mobile-shuffling .work-card:first-child.is-mobile-active{
        display:block;
    }

    .recent-works .work-card__image{
        aspect-ratio:1/1;
        height:auto;
        width:100%;
        border-radius:28px;
    }

    .recent-works .work-card__image::after{
        content:"";
        position:absolute;
        inset:auto 0 0;
        height:42%;
        background:linear-gradient(180deg,rgba(22,18,14,0),rgba(22,18,14,.72));
        pointer-events:none;
    }

    .recent-works .work-card__image img{
        transition:opacity .28s ease,transform .28s ease;
    }

    .recent-works .work-card h3{
        position:absolute;
        left:18px;
        right:78px;
        bottom:17px;
        z-index:1;
        margin:0;
        color:#fffaf1;
        font-size:1.35rem;
        line-height:1.08;
        text-shadow:0 2px 12px rgba(0,0,0,.32);
    }

    .recent-works .work-card__image span{
        z-index:2;
        right:14px;
        bottom:14px;
        padding:7px 12px;
        font-size:1.08rem;
        backdrop-filter:blur(8px);
    }
}


/* Catalog: keep the desktop product listing balanced and comfortably spaced. */
.catalog-page {
    width: min(100% - 48px, 1320px);
    margin: 0 auto;
    background: transparent;
    border: 0;
    box-shadow: none;
    padding: clamp(30px, 5vw, 58px) 0 clamp(44px, 6vw, 72px);
}

.catalog-page h1 {
    margin: 0 0 clamp(22px, 3vw, 34px);
    font-size: clamp(2rem, 3.1vw, 3.25rem);
    line-height: 1.05;
    letter-spacing: -0.045em;
}

.catalog-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: clamp(18px, 2vw, 28px);
}

.catalog-card {
    position: relative;
    display: flex;
    flex-direction: column;
    isolation: isolate;
    overflow: hidden;
    cursor: pointer;
    transition: transform .24s ease, box-shadow .24s ease, border-color .24s ease;
}

.catalog-card::before {
    content: "";
    position: absolute;
    inset: 12px;
    z-index: 0;
    border-radius: 22px;
    background: radial-gradient(circle at 50% 20%, rgba(217, 120, 86, .16), transparent 62%);
    opacity: 0;
    transform: scale(.94);
    transition: opacity .24s ease, transform .24s ease;
}

.catalog-card::after {
    content: "→";
    position: absolute;
    right: 24px;
    top: 24px;
    z-index: 3;
    display: grid;
    place-items: center;
    width: 44px;
    height: 44px;
    border-radius: 999px;
    background: rgba(255, 253, 248, .92);
    color: var(--accent-dark);
    font-size: 1.45rem;
    font-weight: 800;
    box-shadow: 0 14px 32px rgba(74, 48, 24, .16);
    opacity: 0;
    transform: translate(10px, -10px) scale(.86);
    transition: opacity .24s ease, transform .24s ease;
    pointer-events: none;
}

.catalog-card:hover,
.catalog-card:focus-within {
    transform: translateY(-8px);
    border-color: rgba(217, 120, 86, .42);
    box-shadow: 0 22px 48px rgba(74, 48, 24, .14);
}

.catalog-card:hover::before,
.catalog-card:focus-within::before,
.catalog-card:hover::after,
.catalog-card:focus-within::after {
    opacity: 1;
    transform: none;
}

.catalog-card__stretched-link {
    position: absolute;
    inset: 0;
    z-index: 2;
    border-radius: inherit;
}

.catalog-card__stretched-link:focus-visible {
    outline: 3px solid rgba(217, 120, 86, .52);
    outline-offset: 4px;
}

.catalog-card h3 {
    position: relative;
    z-index: 1;
    color: var(--sage-dark);
}

.catalog-card__meta {
    position: relative;
    z-index: 3;
    pointer-events: none;
}

.catalog-card img {
    width: 100%;
    border-radius: 18px;
    transition: transform .28s ease, filter .28s ease;
}

.catalog-card:hover img,
.catalog-card:focus-within img {
    transform: scale(1.035);
    filter: saturate(1.04) contrast(1.02);
}

.catalog-card .product-like {
    position: relative;
    z-index: 4;
    pointer-events: auto;
}

@media (max-width: 860px) {
    .catalog-page {
        width: min(100% - 28px, 1320px);
        padding-top: 24px;
    }

    .catalog-grid {
        grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
    }
}

/* Product detail: keep opened catalog cards centered and readable on all screens. */
.product-page {
    width: min(1320px, calc(100% - clamp(28px, 5vw, 72px)));
    margin: 0 auto;
    padding: clamp(28px, 5vw, 64px) 0 clamp(44px, 6vw, 82px);
    background: transparent;
    border: 0;
    box-shadow: none;
}

.product-page .breadcrumbs {
    margin: 0 0 clamp(18px, 2.5vw, 28px);
    line-height: 1.45;
}

.product-page .product-layout {
    grid-template-columns: minmax(300px, 0.94fr) minmax(340px, 1.06fr);
    gap: clamp(24px, 3vw, 42px);
}

.product-page .product-summary {
    padding: clamp(22px, 3vw, 34px);
}

.product-page .product-summary h1 {
    margin: 0 0 clamp(14px, 1.8vw, 22px);
    font-size: clamp(2rem, 3vw, 3.35rem);
    line-height: 1.06;
    letter-spacing: -0.02em;
    font-weight: 700;
    text-wrap: balance;
}

.product-page .product-gallery__main {
    overflow: hidden;
}

.product-page .product-description {
    margin-top: clamp(24px, 3vw, 42px);
}

@media (max-width: 860px) {
    .product-page {
        width: min(1320px, calc(100% - 28px));
        padding-top: 24px;
    }

    .product-page .product-layout {
        grid-template-columns: 1fr;
    }

    .product-page .product-summary h1 {
        font-size: clamp(1.7rem, 9vw, 2.45rem);
        line-height: 1.1;
        letter-spacing: -0.032em;
    }
}

/* Auth pages: keep login/register forms as focused centered cards. */
.auth {
    width: calc(100% - 32px);
    max-width: 480px;
    margin: 64px auto 80px;
    margin: clamp(44px, 8vh, 92px) auto clamp(56px, 10vh, 112px);
    padding: clamp(24px, 4vw, 36px);
    border-color: rgba(232, 216, 198, 0.9);
    border-radius: 30px;
    background:
        radial-gradient(circle at 16% 0%, rgba(255, 255, 255, 0.88), rgba(255, 253, 248, 0) 44%),
        var(--card);
    box-shadow: 0 24px 70px rgba(74, 48, 24, 0.10);
}

.auth h1 {
    margin: 0 0 24px;
    font-size: clamp(2rem, 4vw, 2.8rem);
    line-height: 1.05;
    letter-spacing: -0.045em;
}

.auth .form {
    max-width: none;
}

.auth .form label {
    color: #3b352f;
}

.auth .form input {
    min-height: 48px;
    border-color: var(--line);
    background: #fffdf8;
}

.auth .btn {
    width: 100%;
    min-height: 50px;
    margin-top: 2px;
    background: var(--accent);
    color: #fff;
    box-shadow: 0 14px 28px rgba(201, 95, 67, 0.18);
}

.auth .btn:hover {
    background: var(--accent-dark);
}

.auth p {
    margin: 8px 0 0;
    text-align: center;
    font-weight: 600;
}

@media (max-width: 560px) {
    .auth {
        width: calc(100% - 28px);
        margin-top: 28px;
        padding: 22px;
        border-radius: 24px;
    }
}

/* Account order detail redesign */
.order-page{display:grid;gap:16px}
.order-layout{display:block}
.order-main{display:grid;gap:14px;min-width:0;width:100%}
.order-card,.order-hero-card,.order-side-card,.order-payment-callout{background:#fffdf8;border:1px solid rgba(74,48,24,.14);border-radius:24px;box-shadow:0 18px 50px rgba(74,48,24,.06)}
.order-card{padding:24px 26px}
.order-hero-card{padding:28px 32px 26px}
.order-side-card{padding:0;overflow:hidden}
.order-payment-callout{display:grid;grid-template-columns:minmax(160px,.35fr) minmax(0,1fr);gap:18px;align-items:center;padding:20px 22px;border-color:rgba(47,143,91,.25);background:linear-gradient(135deg,#f2fff7,#fffdf8)}
.order-kicker{margin:0 0 6px;color:var(--muted);font-size:.82rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em}
.order-payment-callout p{margin:0 0 6px;color:var(--muted);line-height:1.55}
.order-payment-callout__sum{display:block;color:#2f8f5b;font-size:clamp(1.35rem,3vw,2rem);line-height:1.05}
.order-hero-card__header{display:flex;align-items:flex-start;justify-content:space-between;gap:18px;margin-bottom:22px}
.order-hero-card h2,.order-card h2,.order-side-card h2{margin:0;color:var(--ink);letter-spacing:-.02em}
.order-hero-card h2{font-size:clamp(1.45rem,1.8vw,1.85rem);line-height:1.12}
.order-side-card h2{font-size:1.35rem;line-height:1.15}
.order-status-badges{display:flex;align-items:center;gap:8px;flex-wrap:wrap;justify-content:flex-end;margin-top:2px}
.order-badge{display:inline-flex;align-items:center;gap:8px;border-radius:9px;padding:8px 13px;border:1px solid transparent;font-weight:700;font-size:.9rem;line-height:1}
.order-badge::before{content:"";width:9px;height:9px;border-radius:50%;background:currentColor;box-shadow:0 0 0 3px color-mix(in srgb,currentColor 13%,transparent)}
.order-badge--success{background:#dff7e6;border-color:#9ad9b4;color:#21784b}
.order-badge--warning{background:#fff7e8;border-color:#edcaa7;color:#a85a20}
.order-badge--danger{background:#fff0ed;border-color:#efb0a2;color:#b44731}
.order-badge--muted{background:#f3eee8;border-color:#ded0c1;color:#686057}
.order-progress{display:flex;align-items:flex-start;gap:0;padding:8px 4px 0;overflow:visible}
.order-progress-step{position:relative;flex:1 1 0;display:grid;justify-items:center;align-content:start;gap:8px;min-width:0;text-align:center;color:var(--muted);transition:flex-grow .72s cubic-bezier(.22,.9,.24,1),flex-basis .72s cubic-bezier(.22,.9,.24,1)}
.order-progress-step__line{position:absolute;top:17px;left:-50%;width:100%;height:2px;background:#d8cabd;z-index:0}
.order-progress-step:first-child .order-progress-step__line{display:none}
.order-progress-step--completed .order-progress-step__line,.order-progress-step--current .order-progress-step__line{background:#53a574}
.order-is-stopped .order-progress-step__line,.order-progress-step--upcoming .order-progress-step__line{background:repeating-linear-gradient(90deg,#d8cabd 0 7px,transparent 7px 12px)}
.order-progress-step__dot{position:relative;z-index:1;display:grid;place-items:center;width:32px;height:32px;border-radius:50%;border:2px solid #d8cabd;background:#fffdf8;color:#8b8075;font-size:0;font-weight:700}
.order-progress-step--completed .order-progress-step__dot{background:#2f8f5b;border-color:#2f8f5b;color:#fff}
.order-progress-step__dot svg{display:block;width:16px;height:16px;color:currentColor}
.order-progress-step--current .order-progress-step__dot{width:36px;height:36px;background:var(--accent);border-color:var(--accent);color:#fff;box-shadow:0 0 0 7px rgba(217,120,86,.16)}
.order-progress-step--current .order-progress-step__dot svg{width:17px;height:17px}
.order-progress-step--upcoming .order-progress-step__dot svg{width:18px;height:18px;color:#8b8075}
.order-progress-step--stopped .order-progress-step__dot,.order-progress-step.stopped .order-progress-step__dot,.order-progress-step.is-stopped .order-progress-step__dot{background:#fff0ed;border-color:#d97856;color:#b44731}
.order-progress-step__label{color:var(--ink);font-weight:700;font-size:.92rem}
.order-progress-step--current .order-progress-step__label,.order-progress-step--current .order-progress-step__meta--current{color:var(--accent-dark)}
.order-progress-step__meta{min-height:1.1em;color:var(--muted);font-size:.78rem}

.order-progress.order-progress--production-expandable{overflow:visible}
.order-progress-step--production{position:relative;flex-grow:1;transition:flex-grow .72s cubic-bezier(.22,.9,.24,1),flex-basis .72s cubic-bezier(.22,.9,.24,1)}
.order-progress--production-expanded .order-progress-step--production{flex-grow:3.2}
.order-progress-step--production .order-progress-step__dot-main,.order-progress-step--production>.order-progress-step__label,.order-progress-step--production>.order-progress-step__meta{transition:opacity .25s ease,transform .35s cubic-bezier(.22,.9,.24,1)}
.order-progress--production-expanded .order-progress-step--production .order-progress-step__dot-main{opacity:0;transform:scale(.7)}
.order-progress--production-expanded .order-progress-step--production>.order-progress-step__label,.order-progress--production-expanded .order-progress-step--production>.order-progress-step__meta{opacity:0;transform:translateY(-3px)}
.order-progress-production-inline{position:absolute;top:0;left:0;right:0;width:100%;height:76px;display:grid;grid-template-columns:repeat(4,minmax(0,1fr));opacity:0;pointer-events:none;z-index:4;transition:opacity .28s ease .14s}
.order-progress--production-expanded .order-progress-production-inline{opacity:1;pointer-events:auto}
.order-progress-production-substep{position:relative;display:grid;justify-items:center;align-content:start;gap:7px;min-width:0;text-align:center;color:var(--muted);opacity:0;transform:translateY(5px);transition:opacity .34s ease,transform .42s cubic-bezier(.22,.9,.24,1)}
.order-progress--production-expanded .order-progress-production-substep{opacity:1;transform:translateY(0)}
.order-progress--production-expanded .order-progress-production-substep:nth-child(1){transition-delay:.18s}
.order-progress--production-expanded .order-progress-production-substep:nth-child(2){transition-delay:.24s}
.order-progress--production-expanded .order-progress-production-substep:nth-child(3){transition-delay:.30s}
.order-progress--production-expanded .order-progress-production-substep:nth-child(4){transition-delay:.36s}
.order-progress-production-substep__line{position:absolute;top:14px;left:calc(-50% + 16px);width:calc(100% - 32px);height:2px;z-index:0;background:repeating-linear-gradient(90deg,#d8cabd 0 7px,transparent 7px 12px);opacity:0;transition:opacity .28s ease}
.order-progress--production-expanded .order-progress-production-substep__line{opacity:1;transition-delay:.22s}
.order-progress-production-substep:first-child .order-progress-production-substep__line{display:none}
.order-progress-production-substep--completed .order-progress-production-substep__line,.order-progress-production-substep--current .order-progress-production-substep__line{background:#53a574}
@media(min-width:521px){.order-progress--production-expanded .order-progress-step--production>.order-progress-step__line{opacity:0}.order-progress--production-expanded .order-progress-production-substep__line{top:17px}.order-progress--production-expanded .order-progress-production-substep:first-child .order-progress-production-substep__line{display:block;left:calc(-62.5% + 16px);width:calc(112.5% - 32px)}.order-progress--production-expanded .order-progress-step--production+.order-progress-step .order-progress-step__line{left:calc(-40% + 16px);width:calc(90% - 32px)}}
.order-progress-production-substep__dot{position:relative;z-index:1;display:grid;place-items:center;width:32px;height:32px;border-radius:50%;border:2px solid #d8cabd;background:#fffdf8;color:#8b8075}
.order-progress-production-substep__dot svg{display:block;width:16px;height:16px;color:currentColor}
.order-progress-production-substep--completed .order-progress-production-substep__dot{background:#2f8f5b;border-color:#2f8f5b;color:#fff}
.order-progress-production-substep--current .order-progress-production-substep__dot{width:36px;height:36px;background:var(--accent);border-color:var(--accent);color:#fff;box-shadow:0 0 0 7px rgba(217,120,86,.16)}
.order-progress-production-substep--current .order-progress-production-substep__dot::after{content:"";width:8px;height:8px;border-radius:50%;background:#fff}
.order-progress-production-substep--current .order-progress-production-substep__dot svg{display:none}
.order-progress-production-substep__label{max-width:112px;color:var(--muted);font-weight:700;font-size:.92rem;line-height:1.15}
.order-progress-production-substep--completed .order-progress-production-substep__label{color:#2f8f5b}
.order-progress-production-substep--current .order-progress-production-substep__label{color:var(--accent-dark)}
@media (prefers-reduced-motion:reduce){.order-progress-step,.order-progress-step--production .order-progress-step__dot-main,.order-progress-step--production>.order-progress-step__label,.order-progress-step--production>.order-progress-step__meta,.order-progress-production-inline,.order-progress-production-substep,.order-progress-production-substep__line{transition:none}}
.order-card-header{display:flex;align-items:center;justify-content:space-between;gap:16px;margin-bottom:18px}
.order-card-header>span,.order-card-header__title+span{color:var(--muted);font-size:.86rem;font-weight:700}
.order-card-header__title{display:flex;align-items:center;gap:10px;flex-wrap:wrap}
.order-files-list{display:grid;gap:12px;margin-bottom:16px}
.order-file-row{display:grid;grid-template-columns:auto minmax(0,1fr) auto;align-items:center;gap:14px;padding:14px;border:1px solid rgba(74,48,24,.14);border-radius:16px;background:#fff}
.order-file-row__icon{display:grid;place-items:center;gap:2px;width:48px;height:48px;border-radius:12px;background:#fff4ed;color:var(--accent);font-weight:700}
.order-file-row__icon svg{width:24px;height:24px}
.order-file-row__icon small{font-size:.62rem;line-height:1}
.order-file-row__body{min-width:0}
.order-file-row__title{display:flex;align-items:baseline;gap:10px;min-width:0}
.order-file-row__title strong{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-size:1.02rem}
.order-file-row__title span{color:var(--muted);font-size:.78rem;font-weight:600}
.order-file-row__meta{display:flex;gap:8px;flex-wrap:wrap;margin-top:5px;color:var(--muted);font-size:.83rem}
.order-file-row__meta span+span::before{content:"•";margin-right:8px;color:#b8a796}
.order-file-row__download{display:grid;place-items:center;width:40px;height:40px;border-radius:12px;color:var(--ink);border:1px solid transparent}
.order-file-row__download:hover{border-color:var(--line);background:#fff7ed;color:var(--accent-dark)}
.order-file-row__download svg{width:22px;height:22px}
.order-empty-state{margin:0;padding:18px;border:1px dashed rgba(74,48,24,.2);border-radius:16px;color:var(--muted);background:#fffaf3}
.order-upload-form{display:grid;gap:14px;max-width:none}
.order-upload-zone{position:relative;display:flex;align-items:center;justify-content:center;gap:14px;min-height:82px;padding:18px;border:1.5px dashed rgba(74,48,24,.22);border-radius:16px;background:linear-gradient(180deg,#fffdf8,#fffaf3);cursor:pointer;text-align:center}
.order-upload-zone:hover{border-color:var(--accent);background:#fff8f0}
.order-upload-zone__icon svg{display:block;width:34px;height:34px;color:var(--ink)}
.order-upload-zone__text{font-weight:600;color:var(--ink)}
.order-upload-zone__button{display:inline-flex;align-items:center;justify-content:center;border:1.5px solid var(--accent);border-radius:12px;padding:9px 16px;color:var(--accent-dark);font-weight:700;background:#fffdf8}
.order-file-input{position:absolute;inset:0;width:100%;height:100%;opacity:0;cursor:pointer}
.order-upload-submit{justify-self:start;min-width:190px;border-radius:10px;background:var(--accent);box-shadow:0 14px 24px rgba(201,95,67,.18)}
.order-messages{display:grid;gap:10px;max-height:280px;margin-bottom:16px;padding-right:6px;overflow-y:auto;scroll-behavior:smooth}
.order-message{display:grid;grid-template-columns:auto minmax(0,1fr);gap:10px;align-items:start}
.order-message__avatar{display:grid;place-items:center;width:30px;height:30px;border-radius:50%;background:linear-gradient(135deg,var(--accent),#efb08d);color:#fff;font-weight:700;font-size:.88rem}
.order-message--admin .order-message__avatar{background:linear-gradient(135deg,#f0a884,#f7c6a5)}
.order-message-bubble{padding:11px 13px;border:1px solid rgba(74,48,24,.12);border-radius:14px;background:#fff;box-shadow:0 6px 18px rgba(74,48,24,.035)}
.order-message--admin .order-message-bubble{background:#fff4ed}
.order-message__meta{display:flex;align-items:baseline;gap:12px;flex-wrap:wrap;margin-bottom:5px}
.order-message__meta strong{font-size:.92rem}
.order-message__meta time{color:var(--muted);font-size:.82rem}
.order-message-bubble p{margin:0;line-height:1.5}
.order-message-form{display:grid;grid-template-columns:minmax(0,1fr) 150px;gap:12px;align-items:end}
.order-message-form textarea{min-height:58px;max-height:180px;resize:vertical;border:1px solid var(--line);border-radius:14px;padding:16px;background:#fff;color:var(--ink)}
.order-message-form .btn{height:58px;border-radius:12px;background:var(--accent);box-shadow:0 14px 24px rgba(201,95,67,.18)}
.order-side-card__title{display:flex;align-items:center;gap:12px;margin:0;padding:22px 24px 18px;border-bottom:1px solid rgba(74,48,24,.12)}
.order-side-card__title span{display:grid;place-items:center;color:var(--accent);font-weight:700}
.order-side-card__icon{display:grid;place-items:center;width:24px;height:24px;flex:0 0 24px;color:var(--accent)}
.order-side-card__icon svg{display:block;width:21px;height:21px}
.order-side-card__body{padding:20px 24px 24px}
.order-price-row{display:flex;align-items:baseline;justify-content:space-between;gap:14px;margin:16px 0}
.order-price-row span{color:var(--ink)}
.order-price-row strong{text-align:right;white-space:nowrap}
.order-side-note{margin:-6px 0 18px;color:var(--muted);font-size:.88rem;line-height:1.55}
.order-price-divider{height:1px;background:var(--line);margin:18px 0}
.order-price-row--total{font-size:1.06rem;font-weight:700}
.order-price-row--total strong{color:var(--accent-dark);font-size:1.32rem}
.order-info-box{display:flex;align-items:flex-start;gap:10px;margin-top:22px;padding:14px;border:1px solid rgba(217,120,86,.25);border-radius:14px;background:#fff7ed;color:var(--ink);font-size:.88rem;line-height:1.45}
.order-info-box::before{content:none}
.order-info-box>span{display:grid;place-items:center;width:19px;height:19px;flex:0 0 19px;color:var(--ink);margin-top:1px}
.order-info-box svg{width:19px;height:19px}
.order-info-box p{margin:0}
.order-delivery-line{margin:0 0 18px}
.order-delivery-address{margin:0 0 14px;padding:12px;border-radius:12px;background:#fff7ed;color:var(--ink);line-height:1.5}
.order-actions-card{display:grid;gap:10px}
.order-actions-card .order-side-card__title{margin-bottom:8px}
.order-actions-card .btn{width:100%;border-radius:12px;box-shadow:none}
.order-action-repeat{background:#fffdf8!important;color:var(--accent-dark)!important;border:1.5px solid var(--accent)}
.order-action-contact{background:#fde9db!important;color:var(--accent-dark)!important;border:1px solid #f6d4c1}
.order-page .unread-badge{display:inline-flex;align-items:center;border-radius:999px;padding:5px 10px;background:#fff0ed;color:var(--accent-dark);font-weight:700;font-size:.82rem}
@media(max-width:1100px){
.order-card,.order-hero-card{padding:20px}
.order-side-card{padding:0}
.order-side-card__title{margin:0;padding:18px 20px 16px}
.order-side-card__body{padding:18px 20px 20px}
}
@media(max-width:900px){
.order-payment-callout{grid-template-columns:1fr}
.order-progress{overflow-x:auto;padding-bottom:6px}
.order-progress-step{min-width:126px}
.order-hero-card__header{flex-direction:column}
.order-status-badges{justify-content:flex-start}
.order-card-header{align-items:flex-start;flex-direction:column}
.order-message-form{grid-template-columns:1fr}
.order-message-form .btn{width:100%}
}
@media(max-width:520px){
.order-card,.order-hero-card,.order-payment-callout{border-radius:20px;padding:16px}
.order-side-card{border-radius:20px;padding:0}
.order-side-card__title{margin:0;padding:16px}
.order-side-card__body{padding:16px}
.order-main{gap:16px}
.order-hero-card h2{font-size:1.35rem}
.order-progress{display:grid;grid-template-columns:1fr;gap:12px;overflow:visible}
.order-progress-step{grid-template-columns:auto minmax(0,1fr);grid-template-areas:"dot label" "dot meta";justify-items:start;text-align:left;min-width:0;column-gap:12px;flex:none}
.order-progress-step__dot{grid-area:dot}
.order-progress-step__label{grid-area:label}
.order-progress-step__meta{grid-area:meta}
.order-progress-step__line{left:14px;top:-12px;width:2px;height:24px;background:#d8cabd}
.order-progress-step--completed .order-progress-step__line,.order-progress-step--current .order-progress-step__line{background:#53a574}
.order-file-row{grid-template-columns:auto minmax(0,1fr);align-items:start}
.order-file-row__download{grid-column:2;justify-self:start}
.order-file-row__title{align-items:flex-start;flex-direction:column;gap:2px}
.order-upload-zone{display:grid;gap:10px}
.order-upload-submit{justify-self:stretch}
.order-message{grid-template-columns:1fr}
.order-message__avatar{display:none}
.order-price-row{align-items:flex-start}
.order-price-row strong{white-space:normal}
.order-badge{width:100%;justify-content:center}
}
.order-upload-zone .file-name{position:relative;z-index:1;display:block;grid-column:1/-1;color:var(--muted);font-weight:600}

/* Account order workspace tabs: single wide work area without the old right sidebar. */
.order-progress{max-width:none}
.order-workspace-card{margin-top:0;background:#fffdf8;border:1px solid rgba(74,48,24,.14);border-radius:24px;box-shadow:0 18px 50px rgba(74,48,24,.06);overflow:hidden}
.order-tabs{display:flex;align-items:stretch;gap:0;padding:0 22px;border-bottom:1px solid rgba(74,48,24,.12);overflow-x:auto;overflow-y:hidden;scrollbar-width:thin}
.order-tab{position:relative;appearance:none;border:0;background:transparent;min-height:56px;padding:0 18px;display:inline-flex;align-items:center;gap:10px;color:var(--ink);font:inherit;font-weight:700;cursor:pointer;white-space:nowrap}
.order-tab::after{content:"";position:absolute;left:16px;right:16px;bottom:-1px;height:3px;border-radius:999px 999px 0 0;background:transparent}
.order-tab:hover,.order-tab:focus-visible{color:var(--accent-dark)}
.order-tab:focus-visible{outline:2px solid rgba(217,120,86,.45);outline-offset:-6px;border-radius:14px}
.order-tab.is-active{color:var(--accent-dark)}
.order-tab.is-active::after{background:var(--accent)}
.order-tab__icon{width:22px;height:22px;display:grid;place-items:center;color:currentColor;flex:0 0 22px}
.order-tab__icon svg{width:22px;height:22px;display:block}
.order-tab__count{min-width:22px;height:22px;padding:0 7px;border-radius:999px;display:inline-flex;align-items:center;justify-content:center;background:rgba(217,120,86,.18);color:var(--accent-dark);font-size:.78rem;font-weight:700;line-height:1}
.order-tab.is-active .order-tab__count{background:var(--accent);color:#fff}
.order-tab-panel{padding:24px 26px 28px}
.order-tab-panel[hidden]{display:none!important}
.order-panel-toolbar{display:flex;align-items:center;justify-content:space-between;gap:16px;margin-bottom:18px;color:var(--muted);font-weight:600}
.order-panel-toolbar h3{margin:0;color:var(--ink);font-size:1.2rem;letter-spacing:-.02em}
.order-details-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px}
.order-detail-item{padding:16px;border:1px solid rgba(74,48,24,.12);border-radius:16px;background:#fff;min-width:0}
.order-detail-item--wide{grid-column:1/-1}
.order-detail-item span{display:block;margin-bottom:7px;color:var(--muted);font-size:.86rem;font-weight:600}
.order-detail-item strong{display:block;color:var(--ink);font-size:1rem;line-height:1.45;overflow-wrap:anywhere}
.order-price-panel{display:grid;grid-template-columns:minmax(0,1fr) 320px;gap:24px;align-items:start}
.order-price-summary{max-width:560px}
.order-price-row{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:18px;align-items:baseline;margin:14px 0}
.order-price-row span{color:var(--ink)}
.order-price-row strong{font-weight:700;text-align:right;white-space:nowrap}
.order-price-row--total{margin-top:18px;padding-top:18px;border-top:1px solid rgba(74,48,24,.14);font-size:1.06rem;font-weight:700}
.order-price-row--total strong{font-size:1.45rem;color:var(--accent-dark)}
.order-price-panel .order-info-box{margin-top:0;align-self:stretch}
.order-delivery-panel{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px;align-items:start}
.order-delivery-empty{grid-column:1/-1;display:flex;align-items:center;gap:12px;padding:16px;border:1px dashed rgba(74,48,24,.18);border-radius:16px;background:#fffaf3;color:var(--muted)}
.order-delivery-empty span{display:grid;place-items:center;width:38px;height:38px;border-radius:13px;background:#fff4ed;color:var(--accent-dark);flex:0 0 38px}
.order-delivery-empty svg{width:22px;height:22px}
.order-delivery-empty p{margin:0}
.order-actions-panel{display:flex;flex-wrap:wrap;gap:14px}
.order-action-btn{min-height:50px;min-width:220px;display:inline-flex;align-items:center;justify-content:center;gap:10px;max-width:420px;border-radius:12px;box-shadow:none;font-weight:700}
.order-action-btn svg{width:19px;height:19px}
.order-workspace-card .order-files-list{margin-bottom:18px}
.order-workspace-card .order-messages{max-height:280px;margin-bottom:16px;padding-right:6px;overflow-y:auto;scroll-behavior:smooth}
@media(max-width:900px){.order-layout{display:block}.order-tabs{padding:0 14px}.order-tab{min-height:56px;padding:0 14px}.order-tab-panel{padding:18px}.order-price-panel,.order-delivery-panel{grid-template-columns:1fr}.order-actions-panel{flex-direction:column}.order-action-btn{width:100%;max-width:none}.order-hero-card{padding:20px}.order-progress{overflow-x:auto;padding-bottom:6px}.order-progress-step{min-width:126px}}
@media(max-width:520px){.order-workspace-card{border-radius:18px}.order-tabs{padding:0 10px}.order-tab{min-height:54px;font-size:.92rem}.order-tab-panel{padding:16px}.order-workspace-card .order-messages{max-height:min(300px,45vh)}.order-message-form{grid-template-columns:1fr}.order-message-form .btn{width:100%}.order-details-grid{grid-template-columns:1fr}.order-price-row{grid-template-columns:1fr;gap:4px}.order-price-row strong{text-align:left;white-space:normal}.order-panel-toolbar{align-items:flex-start;flex-direction:column}.order-upload-zone{align-items:stretch;flex-direction:column}.order-upload-submit{width:100%}.order-file-row{grid-template-columns:auto minmax(0,1fr)}.order-file-row__download{grid-column:2;justify-self:start}.order-hero-card{padding:20px 18px}}

/* Keep the home "Photo in 3D" strip aligned: the large intrinsic result image must not set the grid track width. */
.photo-workshop__copy,
.photo-workshop__visual,
.photo-workshop__list {
    min-width: 0;
}

.photo-workshop .figure-ready img {
    display: block;
    width: 180px;
    height: 180px;
}

html {
    scroll-behavior: smooth;
    scroll-padding-top: 88px;
}

.process {
    border-radius: 28px;
    transition: box-shadow .35s ease, background-color .35s ease, transform .35s ease;
}

.process.process--highlight {
    animation: process-highlight 1.55s ease both;
}

@keyframes process-highlight {
    0% {
        background-color: rgba(255, 241, 223, 0);
        box-shadow: 0 0 0 0 rgba(217, 120, 86, 0);
        transform: scale(1);
    }
    22% {
        background-color: rgba(255, 241, 223, .64);
        box-shadow: 0 18px 52px rgba(217, 120, 86, .20), 0 0 0 8px rgba(243, 200, 95, .16);
        transform: scale(1.006);
    }
    100% {
        background-color: rgba(255, 241, 223, 0);
        box-shadow: 0 0 0 0 rgba(217, 120, 86, 0);
        transform: scale(1);
    }
}

.how-page {
    display: grid;
    gap: 34px;
}

.how-page__intro,
.how-page__seo {
    max-width: 860px;
    margin: 0 auto;
    padding: 30px;
    border: 1px solid rgba(223, 231, 239, .95);
    border-radius: 26px;
    background: linear-gradient(180deg, #fff, #fffaf3);
    box-shadow: 0 14px 34px rgba(74, 48, 24, .07);
}

.how-page__intro h1 {
    margin: .25rem 0 1rem;
    font-size: clamp(2rem, 1.3rem + 2vw, 3rem);
    line-height: 1.05;
    letter-spacing: -.035em;
}

.how-page__intro p,
.how-page__seo p {
    color: var(--muted);
    line-height: 1.7;
}

.how-page__intro p:last-child,
.how-page__seo p:last-child {
    margin-bottom: 0;
}

.how-page .process {
    width: 100%;
    margin-bottom: 0;
    padding-top: 10px;
    padding-bottom: 10px;
}

@media (max-width: 760px) {
    .how-page {
        gap: 24px;
    }

    .how-page__intro,
    .how-page__seo {
        padding: 22px;
        border-radius: 20px;
    }
}

@media (prefers-reduced-motion: reduce) {
    html {
        scroll-behavior: auto;
    }

    .process {
        transition: none;
    }

    .process.process--highlight {
        animation: none;
        background-color: rgba(255, 241, 223, .58);
        box-shadow: 0 0 0 6px rgba(243, 200, 95, .14);
        transform: none;
    }
}
@media(max-width:520px){.order-progress--production-expanded .order-progress-step--production{flex:none}.order-progress-production-inline{position:relative;top:auto;left:auto;right:auto;grid-column:1 / -1;width:100%;height:auto;opacity:0;max-height:0;overflow:hidden;display:grid;grid-template-columns:1fr;gap:9px;margin-top:0;padding-left:44px;transition:opacity .28s ease,max-height .45s cubic-bezier(.2,.8,.2,1),margin-top .45s cubic-bezier(.2,.8,.2,1)}.order-progress--production-expanded .order-progress-production-inline{opacity:1;max-height:260px;margin-top:10px}.order-progress-production-substep{grid-template-columns:auto minmax(0,1fr);justify-items:start;align-items:center;text-align:left;column-gap:10px;gap:0}.order-progress-production-substep__line{left:16px;top:-16px;width:2px;height:20px}.order-progress-production-substep__label{max-width:none;font-size:.92rem;line-height:1.25}.order-progress--production-expanded .order-progress-step--production .order-progress-step__dot-main,.order-progress--production-expanded .order-progress-step--production>.order-progress-step__label,.order-progress--production-expanded .order-progress-step--production>.order-progress-step__meta{opacity:1;transform:none}}

.cookie-consent {
  position: fixed;
  right: max(18px, env(safe-area-inset-right));
  bottom: max(18px, env(safe-area-inset-bottom));
  z-index: 60;
  display: flex;
  align-items: center;
  gap: 14px;
  width: min(92vw, 520px);
  padding: 14px 14px 14px 18px;
  border: 1px solid rgba(223, 231, 239, .78);
  border-radius: 22px;
  background: rgba(255, 255, 255, .80);
  box-shadow: 0 18px 42px rgba(20, 33, 61, .14);
  backdrop-filter: blur(16px);
  -webkit-backdrop-filter: blur(16px);
  opacity: 0;
  transform: translateY(14px) scale(.98);
  pointer-events: none;
  transition: opacity .24s ease, transform .24s ease;
}
.cookie-consent.is-visible {
  opacity: 1;
  transform: translateY(0) scale(1);
  pointer-events: auto;
}
.cookie-consent p {
  flex: 1 1 auto;
  margin: 0;
  color: var(--ink);
  font-size: .94rem;
  line-height: 1.4;
}
.cookie-consent__actions {
  display: flex;
  flex: 0 0 auto;
  gap: 8px;
}
.cookie-consent__button {
  min-height: 40px;
  padding: 0 16px;
  border: 1px solid var(--accent);
  border-radius: 999px;
  background: var(--accent);
  color: #fff;
  font-weight: 800;
  cursor: pointer;
  transition: transform .18s ease, box-shadow .18s ease, background .18s ease;
}
.cookie-consent__button:hover,
.cookie-consent__button:focus-visible {
  transform: translateY(-1px);
  box-shadow: 0 10px 20px rgba(74,48,24,.18);
  outline: 0;
}
.cookie-consent__button--ghost {
  background: rgba(255, 255, 255, .58);
  color: var(--ink);
  border-color: rgba(20, 33, 61, .16);
}
.policy-page {
  display: grid;
  gap: 20px;
  max-width: 980px;
  margin: 0 auto;
  justify-items: center;
}
.policy-page__eyebrow {
  margin: 0;
  color: var(--accent);
  font-weight: 800;
  letter-spacing: .12em;
  text-transform: uppercase;
  text-align: center;
}
.policy-page h1 {
  margin: 0;
  text-align: center;
}
.policy-page__lead {
  max-width: 760px;
  margin: 0;
  color: var(--muted);
  font-size: 1.08rem;
  line-height: 1.65;
  text-align: center;
}
.policy-page__grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 18px;
  width: 100%;
}
.policy-card {
  padding: 22px;
  border: 1px solid var(--line);
  border-radius: 24px;
  background: rgba(255, 255, 255, .84);
  box-shadow: 0 18px 42px rgba(20, 33, 61, .07);
  width: 100%;
}
.policy-card--wide {
  width: 100%;
  max-width: 780px;
}
.policy-card h2 {
  margin: 0 0 12px;
  color: var(--ink);
  font-size: 1.12rem;
}
.policy-card p,
.policy-card li {
  color: #2f3d52;
  line-height: 1.62;
}
.policy-card p {
  margin: 0 0 10px;
}
.policy-card p:last-child {
  margin-bottom: 0;
}
.policy-card ul {
  display: grid;
  gap: 10px;
  margin: 0;
  padding-left: 20px;
}

@media (max-width: 760px) {
  .cookie-consent {
    left: max(12px, env(safe-area-inset-left));
    right: max(12px, env(safe-area-inset-right));
    bottom: max(12px, env(safe-area-inset-bottom));
    width: auto;
    align-items: stretch;
    gap: 12px;
    padding: 13px;
    border-radius: 18px;
  }
  .cookie-consent p {
    font-size: .9rem;
  }
  .cookie-consent__actions {
    align-items: center;
  }
  .cookie-consent__button {
    min-height: 42px;
    padding: 0 14px;
  }
  .policy-page__grid {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 430px) {
  .cookie-consent {
    flex-direction: column;
  }
  .cookie-consent__actions {
    width: 100%;
  }
  .cookie-consent__button {
    flex: 1 1 0;
  }
}

@media (prefers-reduced-motion: reduce) {
  .cookie-consent,
  .cookie-consent__button {
    transition: none;
  }
}

/* Footer logo matches the compact stacked PrintShip workshop mark. */
.site-footer__brand {
  align-items: start;
  gap: 0;
  line-height: .82;
}
.site-footer__brand strong {
  display: grid;
  color: #111;
  font-size: 1.18rem;
  font-weight: 900;
  letter-spacing: -.055em;
  line-height: .82;
}
.site-footer__brand em {
  margin-top: 2px;
  color: var(--accent);
  font-family: var(--font-serif);
  font-size: 1.05rem;
  font-style: italic;
  font-weight: 700;
  letter-spacing: .015em;
  line-height: 1;
  text-transform: none;
}
.site-footer small {
  grid-column: auto;
  white-space: nowrap;
}

/* Admin order detail: compact information-dense card layout. */
.admin-order-page {
  background: transparent;
  border: 0;
  box-shadow: none;
  padding: 0;
}
.admin-order-topbar {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 18px;
  margin-bottom: 16px;
}
.admin-order-topbar h1 {
  margin: 4px 0 8px;
  font-size: clamp(1.7rem, 3vw, 2.45rem);
  letter-spacing: -.04em;
}
.admin-order-back {
  display: inline-flex;
  align-items: center;
  color: var(--muted);
  font-weight: 800;
  font-size: .9rem;
}
.admin-order-meta,
.admin-order-badges {
  display: flex;
  align-items: center;
  gap: 10px;
  flex-wrap: wrap;
}
.admin-order-meta {
  color: var(--muted);
  font-size: .9rem;
  font-weight: 650;
}
.admin-order-badge {
  display: inline-flex;
  align-items: center;
  min-height: 34px;
  padding: 7px 12px;
  border-radius: 999px;
  border: 1px solid transparent;
  font-weight: 800;
  font-size: .88rem;
}
.admin-order-badge--success {
  background: #EAF6F1;
  color: #2F8F5B;
  border-color: #b9ebdd;
}
.admin-order-badge--warning {
  background: #fff6d8;
  color: #8a5b00;
  border-color: #f2df95;
}
.admin-order-badge--danger {
  background: #ffe2e2;
  color: #991b1b;
  border-color: #ffc8c8;
}
.admin-order-badge--muted {
  background: #F4DFC3;
  color: var(--muted);
  border-color: var(--line);
}
.admin-order-hero {
  display: grid;
  grid-template-columns: 1.25fr .75fr .9fr;
  gap: 14px;
  margin: 16px 0;
}
.admin-order-summary-card,
.admin-order-card {
  background: #fff;
  border: 1px solid var(--line);
  border-radius: 22px;
  box-shadow: 0 14px 34px rgba(20, 33, 61, .07);
}
.admin-order-summary-card {
  display: grid;
  align-content: start;
  gap: 7px;
  min-width: 0;
  padding: 18px;
}
.admin-order-summary-card--wide {
  grid-column: span 1;
}
.admin-order-summary-card h2,
.admin-order-summary-card p,
.admin-order-summary-card strong,
.admin-order-summary-card small {
  min-width: 0;
  overflow-wrap: anywhere;
}
.admin-order-summary-card h2 {
  margin: 0;
  font-size: 1.2rem;
  letter-spacing: -.025em;
}
.admin-order-summary-card p {
  margin: 0;
  color: var(--muted);
  line-height: 1.45;
}
.admin-order-summary-card strong {
  font-size: 1rem;
  line-height: 1.45;
}
.admin-order-summary-card small {
  display: block;
  color: var(--muted);
  font-weight: 650;
}
.admin-order-label {
  display: block;
  color: var(--accent);
  font-size: .74rem;
  font-weight: 900;
  letter-spacing: .08em;
  text-transform: uppercase;
}
.admin-order-total {
  font-size: 1.65rem !important;
  color: var(--ink);
  letter-spacing: -.04em;
}
.admin-order-note {
  margin-top: 6px;
  padding: 10px 12px;
  border-radius: 14px;
  background: #FFFCF6;
  color: var(--ink);
  line-height: 1.45;
}
.admin-order-layout {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(330px, 380px);
  gap: 18px;
  align-items: start;
}
.admin-order-main {
  display: grid;
  gap: 16px;
}
.admin-order-sidebar {
  position: sticky;
  top: 92px;
  min-width: 0;
}
.admin-order-card {
  padding: 18px;
}
.admin-order-card__head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 14px;
  margin-bottom: 14px;
}
.admin-order-card__head h2 {
  margin: 2px 0 0;
  font-size: 1.2rem;
  letter-spacing: -.025em;
}
.admin-order-card__head > strong {
  font-size: 1.15rem;
}
.admin-order-action-grid {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 12px;
  align-items: end;
}
.admin-order-inline-form {
  display: grid;
  grid-template-columns: minmax(220px, 1fr) auto;
  gap: 12px;
  align-items: end;
}
.admin-order-pay-form {
  display: flex;
}
.admin-order-price-form,
.admin-order-shipment-form {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 12px;
}
.admin-order-price-form label,
.admin-order-shipment-form label,
.admin-order-inline-form label {
  display: grid;
  gap: 6px;
  color: var(--ink);
  font-weight: 750;
}
.admin-order-price-form input,
.admin-order-price-form textarea,
.admin-order-shipment-form input,
.admin-order-shipment-form select,
.admin-order-inline-form select,
.admin-order-upload-form select,
.admin-order-upload-form input[type=file] {
  width: 100%;
  border: 1px solid var(--line);
  border-radius: 14px;
  background: #fff;
  padding: 12px;
  color: var(--ink);
}
.admin-order-price-form textarea {
  min-height: 76px;
  resize: vertical;
}
.admin-order-field-wide {
  grid-column: 1 / -1;
}
.admin-order-files {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(210px, 1fr));
  gap: 10px;
  margin-bottom: 14px;
}
.admin-order-file {
  display: grid;
  grid-template-columns: auto minmax(0, 1fr);
  gap: 3px 10px;
  padding: 12px;
  border: 1px solid var(--line);
  border-radius: 16px;
  background: #FFFCF6;
  color: var(--ink);
}
.admin-order-file span {
  grid-row: span 2;
  display: grid;
  place-items: center;
  min-width: 48px;
  height: 48px;
  padding: 0 8px;
  border-radius: 13px;
  background: #F4DFC3;
  color: var(--accent);
  font-size: .74rem;
  font-weight: 900;
}
.admin-order-file strong {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.admin-order-file small {
  font-weight: 650;
}
.admin-order-upload-form {
  display: grid;
  grid-template-columns: minmax(150px, 210px) minmax(0, 1fr) auto;
  gap: 10px;
  align-items: center;
}
.admin-order-upload-form .upload-hint,
.admin-order-upload-form .upload-progress {
  grid-column: 1 / -1;
  margin: 0;
}
.admin-order-breakdown-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
  gap: 10px;
}
.admin-order-breakdown-grid div {
  padding: 12px;
  border: 1px solid var(--line);
  border-radius: 14px;
  background: #FFFCF6;
}
.admin-order-breakdown-grid span {
  display: block;
  margin-bottom: 5px;
  color: var(--muted);
  font-size: .82rem;
  font-weight: 750;
}
.admin-order-breakdown-grid strong {
  display: block;
  overflow-wrap: anywhere;
}
.admin-order-messages-card {
  padding: 16px;
}
.admin-order-customer-note {
  margin-bottom: 12px;
  padding: 12px;
  border: 1px dashed rgba(20, 33, 61, .18);
  border-radius: 16px;
  background: #FFFCF6;
}
.admin-order-customer-note p {
  margin: 6px 0 0;
  color: var(--muted);
  line-height: 1.45;
}
.admin-order-messages {
  max-height: 320px;
}
.admin-order-message-form {
  grid-template-columns: 1fr;
}
.admin-order-message-form textarea {
  min-height: 82px;
}
.admin-order-message-form .btn {
  height: auto;
  min-height: 50px;
  width: 100%;
}
@media (max-width: 1040px) {
  .admin-order-hero {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
  .admin-order-layout {
    grid-template-columns: 1fr;
  }
  .admin-order-sidebar {
    position: static;
  }
  .admin-order-action-grid {
    grid-template-columns: 1fr;
  }
  .admin-order-pay-form .btn {
    width: 100%;
  }
}
@media (max-width: 720px) {
  .admin-order-topbar {
    display: grid;
  }
  .admin-order-hero,
  .admin-order-price-form,
  .admin-order-shipment-form,
  .admin-order-inline-form,
  .admin-order-upload-form {
    grid-template-columns: 1fr;
  }
  .admin-order-summary-card--wide,
  .admin-order-field-wide {
    grid-column: auto;
  }
  .admin-order-card,
  .admin-order-summary-card {
    border-radius: 18px;
    padding: 14px;
  }
  .admin-order-file strong {
    white-space: normal;
  }
  .admin-order-meta {
    display: grid;
    gap: 4px;
  }
  .admin-order-badges {
    align-items: stretch;
  }
  .admin-order-badge {
    justify-content: center;
  }
}


/* Public warm palette alignment */
.site-nav__links a{position:relative;padding:8px 10px;border-radius:10px;color:var(--ink);background:transparent;transition:color .2s ease}
.site-nav__links a::after{content:"";position:absolute;left:12px;right:12px;bottom:2px;height:2px;border-radius:999px;background:var(--accent);opacity:0;transform:scaleX(.6);transform-origin:center;transition:opacity .2s ease,transform .2s ease}
.site-nav__links a:hover,.site-nav__links a:focus-visible,.site-nav__links a.is-active{color:var(--accent);background:transparent}
.site-nav__links a:hover::after,.site-nav__links a:focus-visible::after,.site-nav__links a.is-active::after{opacity:1;transform:scaleX(1)}


.contact-page{padding:20px 8px 52px;background:var(--bg)}
.contact-page .contact-shell{max-width:1120px;margin:0 auto;display:grid;gap:16px}
.contact-hero-card,.contact-guidance,.contact-process,.contact-faq,.contact-info-card{background:var(--card);border:1px solid var(--line);box-shadow:0 10px 24px rgba(74,48,24,.08)}
.contact-hero-card{display:grid;grid-template-columns:minmax(340px,1fr) minmax(340px,1fr);border-radius:28px;overflow:hidden;align-items:stretch;position:relative}
.contact-hero-copy{position:relative;z-index:2;padding:clamp(24px,3.2vw,40px)}
.contact-hero-copy h1{margin:0;color:var(--ink);font-size:clamp(3rem,5vw,4rem);line-height:.95}
.contact-hero-copy p{margin:18px 0 0;max-width:560px;color:var(--muted);font-size:clamp(1.04rem,1.35vw,1.18rem);line-height:1.65}
.contact-actions{display:flex;flex-wrap:wrap;gap:12px;margin-top:28px}.contact-btn{display:inline-flex;align-items:center;gap:10px;min-height:52px;border-radius:13px;padding:0 20px;font-weight:700;border:1px solid transparent;transition:.2s ease}.contact-btn svg{width:20px;height:20px;fill:none;stroke:currentColor;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}
.contact-btn--primary{color:#fff;background:linear-gradient(135deg,var(--accent) 0%,var(--accent-dark) 100%);box-shadow:0 12px 24px rgba(74,48,24,.22)}.contact-btn--ghost{color:var(--ink);border-color:var(--line);background:var(--cream)}.contact-btn:hover{transform:translateY(-1px)}
.contact-response-time{display:flex;align-items:center;gap:8px;margin-top:20px;font-size:.95rem;font-weight:600;color:var(--muted)}.contact-response-time svg{width:18px;height:18px;stroke:var(--sage);fill:none;stroke-width:2}
.contact-hero-image-wrap{position:absolute;inset:0 0 0 34%;min-height:100%;isolation:isolate;z-index:1}
.contact-hero-image-wrap img{width:100%;height:100%;object-fit:cover;display:block}
.contact-hero-image-wrap:before{content:"";position:absolute;left:0;top:0;bottom:0;width:58%;background:linear-gradient(90deg,var(--card) 0%,rgba(255,252,246,.6) 52%,transparent 100%);pointer-events:none;z-index:1}
.contact-info-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:14px}
.contact-info-card{display:flex;gap:14px;border-radius:18px;padding:20px;height:100%}
.contact-info-card h2{margin:2px 0 8px;color:var(--ink);font-size:1.2rem}.contact-main{margin:0;color:var(--ink);font-size:1rem;font-weight:650}.contact-note{margin:10px 0 0;color:var(--muted);line-height:1.56}.contact-main a{color:var(--sage-dark)}
.contact-info-icon{display:grid;place-items:center;width:44px;height:44px;border-radius:999px;border:1px solid color-mix(in srgb,var(--sage) 30%,var(--line));color:var(--sage);background:var(--cream);flex:0 0 auto;margin-top:2px}.contact-info-icon svg{width:22px;height:22px;fill:none;stroke:currentColor;stroke-width:2}
.contact-guidance,.contact-process,.contact-faq{display:grid;grid-template-columns:235px 1fr;gap:18px;align-items:start;padding:20px;border-radius:22px}
.contact-guidance h2,.contact-process h2,.contact-faq h2{margin:4px 4px 0;font-size:clamp(1.5rem,2.2vw,1.85rem);line-height:1.15;color:var(--ink)}
.contact-guidance-list{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:12px}
.contact-mini-card{padding:14px 14px;border-radius:14px;background:linear-gradient(160deg,#fffdf9 0%,var(--card) 100%);border:1px solid color-mix(in srgb,var(--line) 82%,#fff)}
.contact-mini-icon{display:inline-grid;place-items:center;width:32px;height:32px;margin-bottom:8px;border-radius:999px;border:1px solid color-mix(in srgb,var(--sage) 25%,var(--line));background:var(--cream);color:var(--sage)}
.contact-mini-icon svg{width:18px;height:18px;fill:none;stroke:currentColor;stroke-width:1.9;stroke-linecap:round;stroke-linejoin:round}
.contact-mini-card h3{margin:0 0 6px;font-size:1rem}.contact-mini-card p{margin:0;color:var(--muted);font-size:.92rem;line-height:1.45}
.contact-process ol{list-style:none;margin:0;padding:2px 0 0;display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:16px}
.contact-process li{position:relative;padding-right:10px}.contact-process li:not(:last-child):after{content:"";position:absolute;top:18px;right:-10px;width:20px;border-top:1px dashed color-mix(in srgb,var(--sage) 38%,var(--line))}
.contact-process span{display:grid;place-items:center;width:36px;height:36px;border-radius:999px;background:var(--cream);border:1px solid var(--line);color:var(--accent-dark);font-weight:800;margin-bottom:10px}.contact-process h3{margin:0 0 5px;font-size:1.02rem}.contact-process p{margin:0;color:var(--muted);font-size:.93rem;line-height:1.48}
.contact-faq-list{display:grid;gap:8px}
.contact-faq details{border:1px solid color-mix(in srgb,var(--line) 85%,#fff);border-radius:14px;background:#fff;padding:0 14px;transition:background .2s,border-color .2s}
.contact-faq details:hover{background:#fffdfa;border-color:color-mix(in srgb,var(--sage) 24%,var(--line))}
.contact-faq summary{cursor:pointer;list-style:none;padding:14px 28px 14px 0;font-weight:700;position:relative}
.contact-faq summary::-webkit-details-marker{display:none}
.contact-faq summary:after{content:"";position:absolute;right:1px;top:50%;width:12px;height:12px;border-right:1.8px solid var(--muted);border-bottom:1.8px solid var(--muted);transform:translateY(-65%) rotate(45deg);transition:transform .2s ease}
.contact-faq details[open] summary:after{transform:translateY(-35%) rotate(225deg)}
.contact-faq details p{margin:0 0 14px;color:var(--muted);line-height:1.55}
@media (max-width:1000px){.contact-guidance,.contact-process,.contact-faq{grid-template-columns:1fr}.contact-guidance-list{grid-template-columns:repeat(2,minmax(0,1fr))}}
@media (max-width:940px){.contact-hero-card{grid-template-columns:1fr}.contact-hero-image-wrap{position:relative;inset:auto;min-height:320px}.contact-info-grid{grid-template-columns:1fr}.contact-process ol{grid-template-columns:1fr}.contact-process li:not(:last-child):after{display:none}}
@media (max-width:768px){.contact-page{padding:14px 0 36px}.contact-page .contact-shell{padding:0 10px}.contact-hero-copy{padding:20px 18px}.contact-hero-copy h1{font-size:clamp(2.35rem,12vw,3rem)}.contact-actions .contact-btn{flex:1 1 100%;justify-content:center}.contact-guidance,.contact-process,.contact-faq{padding:16px}.contact-guidance-list{grid-template-columns:1fr}}

.photo-wizard-preview{display:grid;place-items:center;padding:16px}
.photo-wizard-preview img{max-width:100%;max-height:360px;object-fit:contain;border-radius:18px;box-shadow:0 18px 38px rgba(74,48,24,.12)}