:root{
  --background: 42 81% 96%;
}

@font-face{
  font-family:"Material Symbols Outlined";
  font-style:normal;
  font-weight:100 700;
  font-display:block;
  src:url(MaterialSymbolsOutlined[FILL,GRAD,opsz,wght].woff2) format("woff2");
}

html:not(.icons-font-ready) .menu-icon{
  visibility:hidden;
}

html.icons-font-ready .menu-icon{
  visibility:visible;
}

.ms{
  font-family:"Material Symbols Outlined";
  font-weight:400;
  font-style:normal;
  font-size:20px;
  line-height:1;
  letter-spacing:normal;
  text-transform:none;
  display:inline-block;
  white-space:nowrap;
  word-wrap:normal;
  direction:ltr;
  -webkit-font-feature-settings:"liga";
  -webkit-font-smoothing:antialiased;
  font-variation-settings:"FILL" 0,"wght" 400,"GRAD" 0,"opsz" 24;
}

@media (min-width: 1024px){
  .site-header nav ul .ms{
    font-size:18px;
  }
}

@media (max-width: 1180px){
  /* Header: hide nav icons to avoid wrapping */
  .site-header nav ul .ms{
    display:none !important;
  }
  .site-header nav ul{
    gap:22px !important;
  }
}

.navy-section .ms{
  font-size:18px;
}

/* Admin header navigation alignment */
.admin-nav{
  display:flex;
  align-items:center;
  white-space:nowrap;
}

.admin-nav__list{
  display:flex;
  align-items:center;
  flex-wrap:nowrap;
  gap:24px;
  list-style:none;
  margin:0;
  padding:0;
}

.admin-nav__item{
  display:flex;
  align-items:center;
  margin-right:24px;
}

.admin-nav__item:last-child{
  margin-right:0;
}

.admin-nav__form{
  display:flex;
  align-items:center;
  margin:0;
  padding:0;
}

.admin-nav__link{
  display:inline-flex;
  align-items:center;
  gap:8px;
  font-size:0.875rem;
  line-height:1;
  white-space:nowrap;
  vertical-align:middle;
}

.admin-nav__button{
  background:none;
  border:0;
  padding:0;
  cursor:pointer;
  line-height:1;
}

.admin-nav__icon{
  display:inline-flex;
  align-items:center;
  line-height:1;
}

body{
  background:#fdf8ec;
  background-image: url(bg.png);
  background-repeat: no-repeat;
  background-position: top center;
  background-size: auto auto;
}

/* Content pages (non-home): bring page title closer to header */
.page-section{
  padding-top:18px !important; /* 48px (py-12) - 30px */
}

@media (min-width: 768px){
  .page-section{
    padding-top:34px !important; /* 64px (md:py-16) - 30px */
  }
}

/* Content headings: ensure spacing from text even if utility margins are missing */
.text-muted-foreground h2.font-display,
.text-muted-foreground h3.font-display,
.text-muted-foreground h4.font-display,
.bg-card h2.font-display,
.bg-card h3.font-display,
.bg-card h4.font-display,
.work-page h2.font-display,
.work-page h3.font-display,
.work-page h4.font-display{
  margin-top:24px;
  margin-bottom:18px;
}

/* Rich text blocks (About, Delivery/Payment): add gallery-style highlights */
.rich-content p{
  margin:0 0 18px;
}

.rich-content p:last-child{
  margin-bottom:0;
}

.rich-content > p:first-child{
  padding:14px 16px;
  border-left:2px solid rgba(180, 140, 70, 0.75);
  background:rgba(253,252,248,0.72);
  color:rgba(44,74,98,0.86);
  font-style:italic;
}

.rich-content strong{
  color:rgba(44,74,98,0.92);
  font-weight:600;
}

.rich-content em{
  color:rgba(44,74,98,0.82);
}

.rich-content blockquote{
  border-left-color: rgba(180, 140, 70, 0.75) !important;
  background: rgba(253,252,248,0.92) !important;
  border-radius:0 !important;
  margin:22px 0 !important;
}

.rich-content blockquote p{
  color:rgba(44,74,98,0.86) !important;
  margin:0 !important;
}

.rich-content .rich-callout{
  border-left-color: rgba(180, 140, 70, 0.75) !important;
  background: rgba(253,252,248,0.72) !important;
  border-radius:0 !important;
  margin:22px 0 !important;
}

.rich-content .rich-callout p{
  color:rgba(44,74,98,0.86) !important;
  margin:0 !important;
}

.rich-content .rich-callout--strong{
  background: rgba(253,252,248,0.92) !important;
}

.rich-content .rich-callout--strong p{
  color:rgba(44,74,98,0.92) !important;
  font-weight:600;
}

/* About page: top background image inside the white panel */
.about-panel{
  --about-hero-h: 280px;
  --about-avatar-size: 138px;
  position:relative;
  overflow:hidden;
}

.about-panel::before{
  content:"";
  position:absolute;
  left:0;
  right:0;
  top:0;
  height:var(--about-hero-h);
  background:url(about-back.jpeg) no-repeat center / cover;
  opacity:0.95;
  pointer-events:none;
  -webkit-mask-image: linear-gradient(to bottom, rgba(0,0,0,1) 0%, rgba(0,0,0,1) 55%, rgba(0,0,0,0) 100%);
  mask-image: linear-gradient(to bottom, rgba(0,0,0,1) 0%, rgba(0,0,0,1) 55%, rgba(0,0,0,0) 100%);
}

.about-panel__avatar{
  position:absolute;
  left:50%;
  top:calc((var(--about-hero-h) * 0.5) + 25px);
  transform:translate(-50%, -50%);
  width:var(--about-avatar-size);
  height:var(--about-avatar-size);
  border-radius:50%;
  padding:5px;
  background:#fff;
  box-shadow:0 10px 24px rgba(0,0,0,0.18);
  z-index:2;
  pointer-events:none;
  opacity:0;
  animation:aboutAvatarFrameIn 1.15s cubic-bezier(.2,.7,.2,1) .08s forwards;
}

.about-panel__avatar img{
  width:100%;
  height:100%;
  display:block;
  border-radius:50%;
  object-fit:cover;
  opacity:0;
  filter:blur(5px) saturate(.88);
  transform:scale(1.05);
  animation:aboutAvatarImageIn 1.45s cubic-bezier(.2,.7,.2,1) .18s forwards;
}

.about-panel__avatar::after{
  content:"";
  position:absolute;
  inset:4px;
  border-radius:50%;
  background:rgba(253,248,236,0.96);
  pointer-events:none;
  -webkit-mask-image:
    repeating-linear-gradient(160deg, rgba(0,0,0,1) 0 12px, rgba(0,0,0,0) 12px 21px),
    linear-gradient(rgba(0,0,0,1), rgba(0,0,0,1));
  mask-image:
    repeating-linear-gradient(160deg, rgba(0,0,0,1) 0 12px, rgba(0,0,0,0) 12px 21px),
    linear-gradient(rgba(0,0,0,1), rgba(0,0,0,1));
  -webkit-mask-size:220% 220%, 100% 100%;
  mask-size:220% 220%, 100% 100%;
  -webkit-mask-position:0% 0%, 0 0;
  mask-position:0% 0%, 0 0;
  opacity:.98;
  animation:aboutAvatarBrushReveal 1.55s cubic-bezier(.25,.7,.2,1) .12s forwards;
}

@keyframes aboutAvatarFrameIn{
  0%{
    opacity:0;
    transform:translate(-50%, -50%) scale(.92);
  }
  100%{
    opacity:1;
    transform:translate(-50%, -50%) scale(1);
  }
}

@keyframes aboutAvatarImageIn{
  0%{
    opacity:0;
    filter:blur(5px) saturate(.88);
    transform:scale(1.05);
  }
  100%{
    opacity:1;
    filter:blur(0) saturate(1);
    transform:scale(1);
  }
}

@keyframes aboutAvatarBrushReveal{
  0%{
    opacity:.98;
    -webkit-mask-position:0% 0%, 0 0;
    mask-position:0% 0%, 0 0;
  }
  65%{
    opacity:.72;
    -webkit-mask-position:72% 42%, 0 0;
    mask-position:72% 42%, 0 0;
  }
  100%{
    opacity:0;
    -webkit-mask-position:125% 90%, 0 0;
    mask-position:125% 90%, 0 0;
  }
}

.about-panel__content{
  position:relative;
  padding-top:calc(var(--about-hero-h) + (var(--about-avatar-size) / 2) - 96px);
}

@media (min-width: 768px){
  .about-panel{
    --about-hero-h: 320px;
    --about-avatar-size: 168px;
  }
  .about-panel__avatar{
    padding:6px;
  }
}

/* Delivery & payment: top background image inside the delivery panel */
.delivery-panel{
  position:relative;
  overflow:hidden;
}

.delivery-panel::before{
  content:"";
  position:absolute;
  left:0;
  right:0;
  top:0;
  height:240px;
  background:url(payment-bg.jpg) no-repeat center / cover;
  opacity:0.95;
  pointer-events:none;
  -webkit-mask-image: linear-gradient(to bottom, rgba(0,0,0,1) 0%, rgba(0,0,0,1) 55%, rgba(0,0,0,0) 100%);
          mask-image: linear-gradient(to bottom, rgba(0,0,0,1) 0%, rgba(0,0,0,1) 55%, rgba(0,0,0,0) 100%);
}

.delivery-panel__content{
  position:relative;
  z-index:1;
  padding-top:140px;
}

@media (min-width: 768px){
  .delivery-panel::before{height:280px}
  .delivery-panel__content{padding-top:170px}
}

@media (min-width: 2731px){
  body{
    background-size: 100% auto;
  }
}

.site-header,
.site-header [data-mobile-menu]{
  background:#fdfcf8 !important;
}

/* Work page: keep consistent offset from sticky header.
   We can't rely on utility classes here because assets are prebuilt. */
.work-page{
  padding-top:25px;
  padding-bottom:48px;
}

@media (min-width: 768px){
  .work-page{
    padding-top:25px;
    padding-bottom:64px;
  }
}

/* Work page: flat borders (no rounding) like the description section */
.work-page .rounded-sm{
  border-radius:0 !important;
}

/* Footer: center social icons vertically between the gold line and the nav */
.footer-social{
  min-height:64px;
  margin-top:-5px;
}

.footer-copyright{
  padding-bottom:20px;
}

.footer-legal-wrap{
  margin-top:8px;
  border-top:1px solid rgba(255,255,255,0.14);
}

.footer-legal{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:22px;
  padding:12px 0 18px;
}

.footer-legal__left{
  display:flex;
  flex-direction:column;
  align-items:flex-start;
  gap:3px;
}

.footer-legal__rights{
  margin:0;
  color:rgba(253,248,236,0.52);
  font-size:12px;
  line-height:1.12;
  font-weight:400;
}

.footer-legal__link{
  display:inline-block;
  color:rgba(253,248,236,0.56);
  font-size:12px;
  line-height:1.12;
  text-decoration:none;
  transition:color .2s ease;
}

.footer-legal__link:hover{
  color:#eabf7a;
}

.footer-legal__creator{
  display:inline-flex;
  align-items:center;
  gap:8px;
  color:rgba(253,248,236,0.56);
  text-decoration:none;
  font-size:12px;
  line-height:1;
  font-weight:400;
  transition:color .2s ease;
}

.footer-legal__creator img{
  width:20px;
  height:20px;
  display:block;
  border-radius:50%;
  filter:grayscale(1) saturate(.75) brightness(1.15);
  transition:filter .22s ease, transform .22s ease;
}

.footer-legal__creator:hover{
  color:#eabf7a;
}

.footer-legal__creator:hover img{
  filter:grayscale(.2) saturate(.9) brightness(1.05);
  transform:translateY(-1px);
}

@media (max-width: 900px){
  .footer-legal{
    padding:12px 0 14px;
    flex-direction:column;
    align-items:flex-start;
    gap:10px;
  }

  .footer-legal__rights,
  .footer-legal__link{
    font-size:11px;
  }

  .footer-legal__creator{
    font-size:11px;
  }
}

/* Admin: small rich-text toolbar for settings */
.admin .rt-toolbar{
  display:flex;
  flex-wrap:wrap;
  gap:8px;
  align-items:center;
  margin:0 0 8px;
}

.admin .rt-btn{
  height:32px;
  padding:0 10px;
  border:1px solid hsl(var(--border));
  background:rgba(253,252,248,0.92);
  color:hsl(var(--foreground));
  font-size:12px;
  letter-spacing:0.08em;
  text-transform:uppercase;
  transition:border-color .18s ease, background-color .18s ease, color .18s ease;
}

.admin .rt-btn:hover{
  border-color: rgba(180, 140, 70, 0.9);
}

.admin .rt-btn:focus-visible{
  outline:2px solid rgba(180, 140, 70, 0.8);
  outline-offset:2px;
}

.admin .rt-swatch{
  width:18px;
  height:18px;
  border:1px solid hsl(var(--border));
  display:inline-block;
  vertical-align:middle;
}

.admin .rt-swatch--accent{background:hsl(var(--accent))}
.admin .rt-swatch--primary{background:hsl(var(--foreground))}
.admin .rt-swatch--muted{background:hsl(var(--muted-foreground))}

.admin .bg-card{
  background:transparent !important;
}

.admin .form-input{
  background:#fff;
  border-color:rgba(0,0,0,0.16);
}

.admin .form-input:focus{
  border-color:rgba(180, 140, 70, 0.65);
  outline:2px solid rgba(180, 140, 70, 0.35);
  outline-offset:2px;
}

.admin .admin-section + .admin-section{
  margin-top:28px;
  padding-top:28px;
}

.admin .admin-section__title{
  display:flex;
  align-items:baseline;
  justify-content:space-between;
  gap:16px;
  padding-bottom:10px;
  margin-bottom:18px;
  border-bottom:1px solid rgba(0,0,0,0.08);
}

.admin .admin-details{
  padding:0;
}

.admin .admin-details summary{
  cursor:pointer;
  list-style:none;
  padding:12px 0;
  border-bottom:1px solid rgba(0,0,0,0.08);
}

.admin .admin-details summary::-webkit-details-marker{
  display:none;
}

.admin .admin-details[open] summary{
  margin-bottom:16px;
}

.admin .admin-header-links{
  display:flex;
  align-items:center;
}

.admin .admin-header-links__sep{
  width:1px;
  height:18px;
  background:rgba(0,0,0,0.14);
  margin:0 18px;
}

.admin .admin-k{
  display:inline-block;
  color:rgba(0,0,0,0.45);
  margin-right:6px;
  text-transform:uppercase;
  letter-spacing:0.08em;
  font-size:11px;
}

.admin .admin-work-list{
  display:flex;
  flex-direction:column;
}

.admin .admin-work-row{
  display:grid;
  grid-template-columns:72px 1fr auto;
  gap:18px;
  padding:16px 0;
  border-bottom:1px solid rgba(0,0,0,0.08);
}

.admin .admin-work-row:first-child{
  padding-top:8px;
}

.admin .admin-work-thumb{
  width:72px;
}

.admin .admin-work-thumb img,
.admin .admin-work-thumb__empty{
  width:72px;
  height:92px;
  display:block;
  object-fit:cover;
  background:#fff;
  border:1px solid rgba(0,0,0,0.16);
  border-radius:4px;
}

.admin .admin-work-thumb__empty{
  background:rgba(255,255,255,0.6);
}

.admin .admin-work-title{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
  align-items:baseline;
}

.admin .admin-work-title__ru{
  font-weight:500;
  color:rgba(0,0,0,0.86);
}

.admin .admin-work-title__en{
  font-size:12px;
  color:rgba(0,0,0,0.55);
}

.admin .admin-work-meta{
  display:flex;
  flex-wrap:wrap;
  gap:10px 18px;
  margin-top:8px;
  font-size:12px;
  color:rgba(0,0,0,0.72);
}

.admin .admin-work-actions{
  display:flex;
  flex-direction:column;
  gap:10px;
  align-items:flex-end;
  justify-content:flex-start;
  padding-top:4px;
}

.admin .admin-action{
  display:inline-flex;
  align-items:center;
  gap:8px;
  font-size:12px;
  text-transform:uppercase;
  letter-spacing:0.08em;
  color:rgba(0,0,0,0.72);
  transition:color .18s ease;
}

.admin .admin-action .ms{
  font-size:18px;
}

.admin .admin-action:hover{
  color:rgba(0,0,0,0.9);
}

.admin .admin-action--danger{
  color:rgba(0,0,0,0.55);
}

.admin .admin-action--danger:hover{
  color:hsl(var(--destructive));
}

.admin .admin-action--danger .ms{
  color:inherit;
}

.admin .admin-action--danger{
  background:transparent;
  border:0;
  padding:0;
  cursor:pointer;
}

.admin .admin-image-row{
  display:flex;
  gap:16px;
  align-items:flex-start;
}

.admin .admin-image-thumb{
  width:92px;
  height:92px;
  border:1px solid rgba(0,0,0,0.16);
  border-radius:4px;
  background:#fff;
  overflow:hidden;
  flex:0 0 auto;
}

.admin .admin-image-thumb img{
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
}

.admin .admin-image-thumb__empty{
  width:100%;
  height:100%;
  background:rgba(255,255,255,0.6);
}

.admin .admin-image-thumb--square{
  width:88px;
  height:88px;
}

.admin .admin-image-row__body{
  flex:1;
  min-width:0;
  display:flex;
  flex-direction:column;
  gap:10px;
}

.admin .admin-inline-upload{
  display:flex;
  flex-direction:column;
  gap:10px;
}

.admin .admin-gallery-grid{
  display:grid;
  grid-template-columns:repeat(auto-fill, minmax(210px, 1fr));
  gap:14px 16px;
}

.admin .admin-gallery-item{
  display:flex;
  gap:12px;
  align-items:flex-start;
}

.admin .admin-gallery-item__controls{
  flex:1;
  min-width:0;
  display:flex;
  flex-direction:column;
  gap:10px;
}

.admin .admin-input--xs{
  height:36px;
  width:84px;
  padding:0 10px;
}

.admin .admin-gallery-item__actions{
  display:flex;
  gap:10px;
  align-items:center;
}

.admin .admin-icon-btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  width:40px;
  height:36px;
  border:1px solid rgba(0,0,0,0.16);
  background:#fff;
  color:rgba(0,0,0,0.72);
  transition:border-color .18s ease, color .18s ease;
}

.admin .admin-icon-btn .ms{
  font-size:18px;
}

.admin .admin-icon-btn:hover{
  border-color: rgba(180, 140, 70, 0.6);
  color:rgba(0,0,0,0.92);
}

.admin .admin-icon-btn--danger{
  color:rgba(0,0,0,0.55);
}

.admin .admin-icon-btn--danger:hover{
  border-color: rgba(180, 40, 40, 0.35);
  color:hsl(var(--destructive));
}

@media (max-width: 768px){
  .admin .admin-work-row{
    grid-template-columns:72px 1fr;
  }
  .admin .admin-work-actions{
    grid-column:1 / -1;
    flex-direction:row;
    justify-content:flex-start;
    gap:14px;
    padding-top:10px;
  }
}

.admin .admin-log-pre{
  max-height:70vh;
  white-space:pre-wrap;
  word-break:break-word;
  background:#fff;
}

.site-monogram{
  width:28px;
  height:28px;
  display:inline-block;
  background: currentColor;
  -webkit-mask: url(monogram.svg) no-repeat center / contain;
  mask: url(monogram.svg) no-repeat center / contain;
}

@media (min-width: 768px){
  .site-monogram{
    width:32px;
    height:32px;
  }
}

.hero{
  position:relative;
  isolation:isolate;
  display:flex;
  flex-direction:column;
  gap:18px;
  padding-top:16px;
  padding-bottom:36px;
}

.hero__mobile-art{
  display:none;
}

.hero__mobile-art img,
.hero__mobile-art .hero__placeholder{
  width:100%;
  height:100%;
  display:block;
  object-fit:cover;
  object-position:center;
}

.hero__mobile-art{
  position:absolute;
  left:0;
  right:0;
  top:0;
  height:var(--hero-mobile-art-h, 360px);
  z-index:0;
  overflow:hidden;
  pointer-events:none;
  -webkit-mask-image: linear-gradient(to bottom, rgba(0,0,0,1) 0%, rgba(0,0,0,1) 72%, rgba(0,0,0,0) 100%);
          mask-image: linear-gradient(to bottom, rgba(0,0,0,1) 0%, rgba(0,0,0,1) 72%, rgba(0,0,0,0) 100%);
}

.hero__content,
.hero__portrait{
  position:relative;
  z-index:2;
}

.hero__content{order:1}
.hero__portrait{order:2}
.hero__artwork{order:3;display:none}

.hero__title{
  font-size:clamp(28px, 5vw, 56px);
  line-height:1.06;
  letter-spacing:0.01em;
  text-transform:uppercase;
  text-wrap:balance;
  margin:0 0 18px;
  max-width:18ch;
}

.hero__title-text{
  display:inline;
}

.hero__cta{
  display:flex;
  flex-wrap:wrap;
  gap:12px;
  align-items:center;
}

.hero__portrait{
  border-radius:6px;
  overflow:hidden;
}

.hero__portrait{
  width:min(240px, 60%);
  aspect-ratio:3/4;
  align-self:center;
  background:#ffffff;
  border:1px solid rgba(0,0,0,0.08);
  padding:10px;
  box-shadow:0 12px 35px rgba(0,0,0,0.10);
  transition:width 1000ms ease, height 1000ms ease, transform 1000ms ease;
  position:relative;
  box-sizing:border-box;
}

.hero__portrait--video{
  position:relative;
  padding:10px;
  text-align:initial;
}

.hero__portrait.hero__portrait--video{
  appearance:none;
  -webkit-appearance:none;
  border:1px solid rgba(0,0,0,0.08);
}

.hero__portrait-frame{
  width:100%;
  height:100%;
  border-radius:4px;
  overflow:hidden;
  background:#000;
  position:relative;
}

.hero__portrait-img{
  position:absolute;
  inset:0;
  width:100%;
  height:100%;
  object-fit:cover;
  object-position:center;
  transition:opacity 700ms ease, filter 700ms ease;
}

.hero__portrait-video{
  position:absolute;
  inset:0;
  opacity:0;
  pointer-events:none;
  transition:opacity 700ms ease;
}

.hero__portrait-video video{
  width:100%;
  height:100%;
  display:block;
  background:#000;
  object-fit:contain;
  pointer-events:none;
}

.hero__portrait-video video::-webkit-media-controls{
  display:none !important;
}

.hero__portrait-video video::-webkit-media-controls-enclosure{
  display:none !important;
}

.hero__portrait.is-opening .hero__portrait-img{
  opacity:0;
  filter:brightness(0);
}

.hero__portrait.is-video .hero__portrait-video{
  opacity:1;
  pointer-events:auto;
}

.hero__portrait.is-expanded .hero__portrait-frame{
  border-radius:4px;
}

.hero__portrait.is-expanded{
  --video-w: 640px;
  --video-h: 352px;
  --video-pad: 10px;
  --video-outer-w: calc(var(--video-w) + (var(--video-pad) * 2));
  --video-outer-h: calc(var(--video-h) + (var(--video-pad) * 2));
  --hero-video-w: min(calc(100vw - 32px), var(--video-outer-w));
  width:var(--hero-video-w);
  height:calc(((var(--hero-video-w) - (var(--video-pad) * 2)) * (352 / 640)) + (var(--video-pad) * 2));
  z-index:9999;
}

.hero__portrait--video:focus-visible{
  outline:2px solid rgba(180, 140, 70, 0.8);
  outline-offset:2px;
}

.hero__play{
  position:absolute;
  right:16px;
  bottom:16px;
  width:44px;
  height:44px;
  border-radius:999px;
  background:rgba(253, 252, 248, 0.88);
  border:1px solid rgba(0,0,0,0.08);
  box-shadow:0 10px 24px rgba(0,0,0,0.14);
  display:flex;
  align-items:center;
  justify-content:center;
  color:#1f1d1a;
  padding:0;
  cursor:pointer;
}

.hero__play:focus-visible{
  outline:2px solid rgba(180, 140, 70, 0.8);
  outline-offset:2px;
}

.hero__portrait.is-expanded .hero__play{
  opacity:0;
  pointer-events:none;
}

.hero__play .ms{
  font-size:26px;
}

.hero__portrait img,
.hero__work img{
  width:100%;
  height:100%;
  display:block;
  object-fit:cover;
  object-position:center;
}

.hero__placeholder{
  background:rgba(0,0,0,0.04);
  width:100%;
  height:100%;
}

.hero__portrait img,
.hero__portrait .hero__placeholder{
  border-radius:4px;
}

.hero__portrait .hero__placeholder{
  border-radius:4px;
}

@media (min-width: 768px){
  .hero__portrait.is-expanded{
    width:660px;
    height:372px;
  }
}

.video-modal{
  position:fixed;
  inset:0;
  z-index:9999;
}

.video-modal__backdrop{
  position:absolute;
  inset:0;
  background:rgba(0,0,0,0.32);
  backdrop-filter: blur(2px);
}

.video-modal__dialog{
  position:relative;
  width:min(720px, calc(100vw - 32px));
  margin: min(8vh, 72px) auto 0;
}

.video-modal__close{
  position:absolute;
  right:8px;
  top:-52px;
  width:40px;
  height:40px;
  border-radius:999px;
  background:rgba(253, 252, 248, 0.92);
  border:1px solid rgba(0,0,0,0.10);
  box-shadow:0 10px 24px rgba(0,0,0,0.14);
  display:flex;
  align-items:center;
  justify-content:center;
  color:#1f1d1a;
}

.video-modal__close .ms{
  font-size:22px;
}

.video-modal__frame{
  border-radius:6px;
  overflow:hidden;
  background:#ffffff;
  border:1px solid rgba(255,255,255,0.85);
  padding:10px;
  box-shadow:0 24px 70px rgba(0,0,0,0.16);
}

.video-modal__frame video{
  width:100%;
  height:auto;
  display:block;
  border-radius:4px;
  background:#000;
}

@media (min-width: 768px){
  .hero{
    padding-top:44px;
    padding-bottom:56px;
    display:block;
  }

  .hero__artwork{
    display:block;
    position:relative;
    height:clamp(380px, 34vw, 540px);
  }

  .hero__work{
    position:absolute;
    border-radius:6px;
    overflow:hidden;
    background:rgba(0,0,0,0.04);
    border:1px solid rgba(255,255,255,0.85);
    box-shadow:0 24px 70px rgba(0,0,0,0.16);
  }

  .hero__work--left{
    left:0;
    top:0;
    width:58%;
    height:100%;
    z-index:1;
  }

  .hero__work--right{
    right:0;
    top:66px;
    width:58%;
    height:88%;
    z-index:2;
  }

  .hero__portrait{
    --portrait-scale: 0.75;
    --portrait-w: clamp(240px, 18vw, 340px);
    --portrait-h: clamp(380px, calc(24vw + 60px), 513px);
    --portrait-w-final: calc(var(--portrait-w) * var(--portrait-scale));
    --portrait-h-final: calc(var(--portrait-h) * var(--portrait-scale));
    position:absolute;
    left:50%;
    top: calc(58% - (var(--portrait-w-final) / 2) + 13px);
    transform:translateX(-50%) translateX(-170px);
    width:var(--portrait-w-final);
    height:var(--portrait-h-final);
    z-index:3;
  }

  .hero__content{
    position:absolute;
    z-index:4;
    top:calc(48% + 101px);
    right:clamp(18px, 3vw, 48px);
    transform:translate(-156px, -50%);
    max-width:440px;
  }
}

@media (min-width: 1024px){
  .hero__work--left{width:60%}
  .hero__work--right{width:60%}
  .hero__portrait{
    top: calc(58% - (var(--portrait-w-final) / 2) + 21px);
    transform:translateX(-50%) translateX(-170px);
  }
}

@media (min-width: 768px) and (max-width: 1180px){
  /* Hero: keep title/CTA anchored on the right artwork and away from the portrait */
  .hero__portrait{
    /* At 1180px: -90px (80px to the right vs default -170px).
       At 768px:  -113px (57px to the right vs default -170px).
       As viewport shrinks, portrait shifts left progressively. */
    transform:translateX(-50%) translateX(calc(-155.86px + 5.58vw));
  }

  .hero__content{
    left:auto;
    right:24px;
    transform:translate(0, -50%);
    max-width:calc(58% - 48px);
  }

  .hero__title{
    font-size:clamp(22px, 3.2vw, 44px);
    margin-bottom:14px;
    max-width:22ch;
  }

  .hero__cta{
    gap:10px;
  }

  .hero__cta a{
    height:44px !important;
    padding-left:22px !important;
    padding-right:22px !important;
    font-size:14px !important;
  }
}

@media (max-width: 767px){
  /* Header: keep site title in one line; scale font with viewport */
  body:not(.admin) .site-header a.font-display{
    white-space:nowrap;
    font-size:clamp(14px, 4.4vw, 17px) !important;
  }

  body:not(.admin) .site-header a.font-display{
    gap:12px !important;
  }

  /* Hero: center title and CTAs on mobile */
  .hero{
    padding-top:0;
    padding-bottom:34px;
  }

  .hero__mobile-art{
    display:block;
  }

  /* iOS Safari occasionally clips rounded boxes when masks are present; keep portrait overflow visible */
  .hero__portrait{
    overflow:visible;
    height:calc((min(240px, 60%) * 4 / 3) + 20px);
  }

  .hero__content{
    text-align:center;
    padding-top:0;
  }

  .hero__title{
    margin-left:auto;
    margin-right:auto;
    text-align:center;
    max-width:none;
    font-weight:700;
    color:rgba(255,255,255,0.96) !important;
    text-shadow:0 10px 30px rgba(0,0,0,0.28), 0 2px 10px rgba(0,0,0,0.24);
    background:rgba(44, 74, 98, 0.8);
    padding:12px 16px;
    margin-top:0;
    margin-bottom:18px;
    width:100vw;
    margin-left:calc(50% - 50vw);
    margin-right:calc(50% - 50vw);
    border-bottom:1px solid rgba(255,255,255,0.8);
  }

  .hero__title-text{
    display:block;
    max-width:22ch;
    margin:0 auto;
  }

  .hero__cta{
    justify-content:center;
    margin-top:10px;
  }

  .hero__btn--price{
    background:rgba(255,255,255,0.90) !important;
    color:rgba(44,74,98,0.92) !important;
  }
}

@media (max-width: 1023px){
  /* Mobile menu: ensure spacing between icon and label */
  .site-header [data-mobile-menu] a .ms{
    margin-right:10px;
  }
}

/* Language switch: move into burger menu on very small screens */
body:not(.admin) .mobile-lang-switch{
  display:none;
}

@media (max-width: 400px){
  body:not(.admin) .site-lang-switch{
    display:none !important;
  }
  body:not(.admin) .mobile-lang-switch{
    display:block;
  }
}

/* Home page: featured works cards framed like hero artworks */
.artwork-card--home-framed{
  text-decoration:none;
}

.artwork-grid{
  align-items:start;
}

.artwork-card--home-framed .artwork-card__frame{
  border-radius:6px;
  overflow:hidden;
  background:rgba(253,252,248,0.92);
  border:1px solid rgba(255,255,255,0.85);
  box-shadow:0 24px 70px rgba(0,0,0,0.16);
}

.artwork-card--home-framed .artwork-card__media{
  background:rgba(0,0,0,0.04);
}

.artwork-card__media--fit{
  aspect-ratio:3 / 4;
  display:flex;
  align-items:center;
  justify-content:center;
}

.artwork-card__media--fit .artwork-card__img{
  width:100%;
  height:100%;
  object-fit:contain;
  display:block;
}

.artwork-card--home-framed .artwork-card__meta{
  text-align:center;
  padding:14px 16px 18px;
}

/* Price list row: make thumbnail stretch full row height */
.price-row{
  display:block;
}

.price-row__layout{
  display:flex;
  gap:16px;
  align-items:stretch;
}

.price-row__content{
  flex:1 1 auto;
  min-width:0;
}

.price-row__header{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:24px;
}

.price-row__thumb{
  width:96px;
  align-self:stretch;
  border-radius:4px;
  overflow:hidden;
  background:rgba(0,0,0,0.04);
  flex:0 0 auto;
}

.price-row__thumb img,
.price-row__thumb-empty{
  width:100%;
  height:100%;
  display:block;
  object-fit:cover;
}

.price-row__thumb-empty{
  background:rgba(0,0,0,0.06);
}

.price-row__info{
  position:relative;
  top:-25px;
  min-width:0;
}

.price-row__info h3{
  overflow-wrap:anywhere;
}

@media (min-width: 768px){
  .price-row__thumb{width:110px}
}

@media (max-width: 767px){
  .price-row__layout{
    align-items:flex-start;
  }

  .price-row__thumb{
    width:108px;
  }

  .price-row__header{
    display:block;
  }

  .price-row__info{
    top:0;
  }

  .price-row__aside{
    margin-top:8px;
    text-align:left;
    min-width:0;
  }

  .price-row__aside .font-display{
    font-size:2rem;
    line-height:1.05;
  }
}

/* Delivery & payment: QR payment block */
.qr-pay{
  margin-top:26px;
  display:flex;
  justify-content:center;
}

.qr-pay__frame{
  width:min(320px, 100%);
  background:rgba(253,252,248,0.92);
  border:1px solid rgba(255,255,255,0.85);
  box-shadow:0 18px 54px rgba(0,0,0,0.14);
  border-radius:6px;
  padding:12px;
}

.qr-pay__frame img{
  width:100%;
  height:auto;
  display:block;
}

.qr-pay__hint{
  margin-top:14px;
}

/* Work page */
.work-title{
  text-wrap:balance;
}

.work-head{
  display:flex;
  flex-direction:column;
  gap:14px;
  margin:0 0 22px;
}

.work-head__left{
  display:flex;
  flex-direction:column;
  gap:10px;
}

.work-head__back{
  width:fit-content;
}

.work-head__params{
  background:rgba(253,252,248,0.92);
  border:1px solid hsl(var(--border));
  border-radius:0;
  box-shadow:none;
  padding:14px 16px;
}

.work-head__dl{
  display:flex;
  flex-direction:column;
  gap:10px;
}

.work-head__row{
  display:flex;
  align-items:baseline;
  justify-content:space-between;
  gap:16px;
}

.work-head__row dt{
  font-size:13px;
  letter-spacing:0.06em;
  text-transform:uppercase;
  color:rgba(0,0,0,0.50);
  white-space:nowrap;
}

.work-head__row dd{
  font-size:14px;
  color:rgba(0,0,0,0.86);
  text-align:right;
  max-width:70%;
}

.work-gallery{
  display:flex;
  flex-direction:column;
  align-items:center;
  gap:14px;
  width:100%;
  margin:0 auto 36px;
}

.work-gallery__view{
  width:min(800px, 100%);
  display:flex;
  flex-direction:column;
  align-items:stretch;
  gap:10px;
}

.work-gallery__main{
  width:100%;
  aspect-ratio:1/1;
  border-radius:0;
  overflow:hidden;
  background:#ffffff;
  border:1px solid hsl(var(--border));
  box-shadow:none;
  padding:10px;
  box-sizing:border-box;
  display:flex;
  align-items:center;
  justify-content:center;
  position:relative;
}

.work-gallery__img{
  width:100%;
  height:100%;
  display:block;
  object-fit:contain;
  background:transparent;
  border-radius:0;
  max-width:780px;
  max-height:780px;
}

@media (max-width: 767px){
  .work-gallery__view{width:min(800px, calc(100vw - 24px));}
}

.work-gallery__thumbs{
  width:min(820px, 100%);
  display:flex;
  flex-wrap:wrap;
  justify-content:center;
  gap:10px;
}

.work-thumbs__label{
  width:100%;
  font-size:11px;
  letter-spacing:0.12em;
  text-transform:uppercase;
  color:rgba(0,0,0,0.50);
  margin-top:2px;
}

.work-thumbs__rule{
  width:100%;
  height:1px;
  background:hsl(var(--border));
  margin:10px 0 6px;
}

.work-thumb{
  width:64px;
  height:64px;
  padding:6px;
  border-radius:0;
  background:rgba(253,252,248,0.92);
  border:1px solid hsl(var(--border));
  box-shadow:none;
  overflow:hidden;
  transition:border-color .18s ease, background-color .18s ease;
}

.work-thumb img{
  width:100%;
  height:100%;
  display:block;
  object-fit:cover;
  border-radius:0;
}

.work-thumb:hover{
  border-color: rgba(180, 140, 70, 0.9);
}

.work-thumb.is-active{
  border-color: rgba(180, 140, 70, 0.9);
  background:rgba(253,252,248,1);
}

.work-gallery__note{
  position:absolute;
  left:50%;
  bottom:22px;
  transform:translateX(-50%);
  width:max-content;
  max-width:calc(100% - 36px);
  border:1px solid hsl(var(--border));
  background:rgba(253,252,248,0.84);
  padding:9px 12px;
  font-size:12.5px;
  line-height:1.45;
  color:rgba(0,0,0,0.72);
  text-align:left;
  box-sizing:border-box;
  pointer-events:none;
}

.work-gallery__note strong{
  color:rgba(0,0,0,0.9);
  font-weight:600;
}

@media (max-width: 767px){
  .work-gallery__note{
    bottom:16px;
    max-width:calc(100% - 24px);
    font-size:12px;
    padding:8px 10px;
  }
}

.work-interior{
  border-radius:0;
  overflow:hidden;
  background:rgba(0,0,0,0.04);
  border:1px solid hsl(var(--border));
  box-shadow:none;
}

.work-details{
  display:flex;
  flex-direction:column;
  gap:0;
}

.work-details__row{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:18px;
  padding:12px 0;
  border-bottom:1px solid rgba(0,0,0,0.06);
}

.work-details__row:last-child{
  border-bottom:0;
}

.work-details__row dt{
  color:rgba(0,0,0,0.55);
  font-size:14px;
}

.work-details__row dd{
  color:rgba(0,0,0,0.86);
  font-size:14px;
  text-align:right;
  max-width:60%;
}

@media (min-width: 768px){
  .work-thumb{width:72px;height:72px}

  .work-head{
    flex-direction:row;
    align-items:center;
    justify-content:space-between;
    gap:28px;
    margin-bottom:26px;
  }

  .work-head__params{
    width:min(520px, 44%);
    padding:16px 18px;
  }

  .work-gallery{
    flex-direction:row;
    align-items:flex-start;
    justify-content:flex-start;
    gap:16px;
    height:800px;
    margin-bottom:44px;
  }

  .work-gallery__thumbs{
    order:1;
    width:96px;
    height:800px;
    flex-direction:column;
    flex-wrap:nowrap;
    justify-content:flex-start;
    align-items:stretch;
    overflow:auto;
    padding-right:4px;
  }

  .work-thumbs__label,
  .work-thumbs__rule{
    width:100%;
  }

  .work-gallery__main{
    width:100%;
    height:800px;
    aspect-ratio:auto;
    min-width:0;
  }

  .work-gallery__view{
    order:2;
    flex:1;
    width:auto;
    min-width:0;
  }

  .work-thumb{
    width:80px;
    height:80px;
  }
}
