/* ============================================================
   DUBEL ART — editorial catalogue stylesheet
   ============================================================ */

:root{
  --paper:#e7e1d2;
  --paper-2:#ede8db;
  --card:#f3efe5;
  --ink:#17120b;
  --ink-soft:#46402f;
  --muted:#8d8675;
  --red:#c5392b;
  --red-deep:#9f2b20;
  --green:#3c5141;
  --line:rgba(23,18,11,.16);
  --line-strong:rgba(23,18,11,.35);
  --shadow:0 24px 60px -28px rgba(23,18,11,.5);
  --maxw:1320px;
  --display:"Anton",sans-serif;
  --util:"Archivo",sans-serif;
  --body:"Inter",sans-serif;
  --serif:"Playfair Display",serif;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  background:var(--paper);
  color:var(--ink);
  font-family:var(--body);
  font-size:16px;
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
  /* subtle paper grain */
  background-image:
    radial-gradient(rgba(23,18,11,.025) 1px, transparent 1px);
  background-size:3px 3px;
}
img{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer}

.wrap{max-width:var(--maxw);margin:0 auto;padding:0 28px}

/* ---------- ticker ---------- */
.ticker{
  background:var(--ink);
  color:var(--paper);
  overflow:hidden;
  white-space:nowrap;
  border-bottom:2px solid var(--red);
}
.ticker__track{
  display:inline-flex;
  align-items:center;
  gap:0;
  padding:9px 0;
  animation:scroll 34s linear infinite;
  will-change:transform;
}
.ticker__track span{
  font-family:var(--util);
  font-weight:700;
  font-size:12px;
  letter-spacing:.22em;
  text-transform:uppercase;
  padding:0 18px;
}
.ticker__track b{color:var(--red);font-weight:900;padding:0 4px}
@keyframes scroll{from{transform:translateX(0)}to{transform:translateX(-50%)}}
@media (prefers-reduced-motion:reduce){.ticker__track{animation:none;padding-left:18px}}

/* ---------- header ---------- */
.site-header{
  position:sticky;top:0;z-index:60;
  background:rgba(231,225,210,.94);
  border-bottom:1px solid var(--line);
}
@supports ((backdrop-filter:blur(8px)) or (-webkit-backdrop-filter:blur(8px))){
  .site-header{
    background:color-mix(in srgb,var(--paper) 88%, transparent);
    -webkit-backdrop-filter:blur(8px);
    backdrop-filter:blur(8px);
  }
}
.site-header .wrap{display:flex;align-items:center;gap:22px;height:84px}
.brand{display:flex;align-items:center;gap:14px;margin-right:auto}
.brand__mark{
  width:46px;height:46px;border-radius:50%;
  border:2px solid var(--ink);
  display:grid;place-items:center;flex:0 0 auto;
  font-family:var(--display);font-size:17px;letter-spacing:.02em;
  background:var(--card);
}
.brand__name{font-family:var(--display);font-size:24px;line-height:.9;letter-spacing:.01em}
.brand__name b{color:var(--red)}
.brand__tag{font-family:var(--serif);font-style:italic;color:var(--red);font-size:13px;margin-top:3px}
.nav{display:flex;align-items:center;gap:26px}
.nav a{
  font-family:var(--util);font-weight:700;font-size:12.5px;
  letter-spacing:.16em;text-transform:uppercase;color:var(--ink-soft);
  padding:6px 0;position:relative;
}
.nav a:hover{color:var(--ink)}
.nav a::after{content:"";position:absolute;left:0;right:100%;bottom:-2px;height:2px;background:var(--red);transition:right .25s ease}
.nav a:hover::after{right:0}
.btn{
  font-family:var(--util);font-weight:800;font-size:12.5px;
  letter-spacing:.16em;text-transform:uppercase;
  background:var(--red);color:#fff;border:none;
  padding:13px 22px;border-radius:2px;display:inline-block;
  transition:background .2s ease,transform .2s ease;
}
.btn:hover{background:var(--red-deep)}
.btn--ghost{background:transparent;color:var(--ink);border:1.5px solid var(--ink)}
.btn--ghost:hover{background:var(--ink);color:var(--paper)}
.btn--block{display:block;width:100%;text-align:center;padding:16px}
.nav-toggle{display:none}

/* ---------- hero ---------- */
.hero{padding:70px 0 40px;border-bottom:2px solid var(--ink)}
.hero__eyebrow{display:flex;align-items:center;gap:12px;margin-bottom:18px}
.hero__eyebrow span{
  font-family:var(--util);font-weight:700;font-size:12px;letter-spacing:.22em;
  text-transform:uppercase;color:var(--ink-soft)
}
.hero__eyebrow .dot{width:9px;height:9px;border-radius:50%;background:var(--red);flex:0 0 auto}
.hero__eyebrow .rule{flex:1;height:1px;background:var(--line-strong)}
.hero__grid{display:grid;grid-template-columns:1.15fr .85fr;gap:40px;align-items:end}
.hero__head{font-family:var(--display);line-height:.84;letter-spacing:.005em;margin:0;
  font-size:clamp(64px,12vw,168px);text-transform:uppercase}
.hero__head .l1{color:var(--ink)}
.hero__head .l2{color:var(--muted)}
.hero__head .l3{color:var(--red);position:relative}
.hero__head .l3::before{content:"";position:absolute;left:-2%;right:-2%;top:46%;height:6px;background:var(--ink)}
.hero__aside{padding-bottom:10px;border-left:3px solid var(--red);padding-left:22px}
.hero__statement{font-family:var(--util);font-weight:800;font-size:clamp(20px,2.2vw,27px);line-height:1.12;margin:0 0 14px}
.hero__body{font-family:var(--serif);font-style:italic;font-size:17px;line-height:1.5;color:var(--ink-soft);margin:0}

/* ---------- section heading ---------- */
.section{padding:54px 0}
.section__head{display:flex;align-items:baseline;justify-content:space-between;gap:20px;margin-bottom:30px;border-bottom:1px solid var(--line);padding-bottom:14px}
.section__title{font-family:var(--display);font-size:clamp(30px,4.6vw,52px);text-transform:uppercase;line-height:.92;margin:0}
.section__count{font-family:var(--util);font-weight:700;font-size:13px;letter-spacing:.18em;text-transform:uppercase;color:var(--muted);white-space:nowrap}

/* ---------- filter bar ---------- */
.filters{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:30px}
.chip{
  font-family:var(--util);font-weight:700;font-size:12px;letter-spacing:.12em;text-transform:uppercase;
  padding:9px 15px;border:1.5px solid var(--line-strong);background:transparent;color:var(--ink-soft);border-radius:2px;
  transition:.18s ease;
}
.chip:hover{border-color:var(--ink);color:var(--ink)}
.chip[aria-pressed="true"]{background:var(--ink);color:var(--paper);border-color:var(--ink)}

/* ---------- gallery grid ---------- */
.grid{display:grid;grid-template-columns:repeat(3,1fr);gap:34px 30px}
.card{display:flex;flex-direction:column;background:transparent}
.card__frame{
  background:var(--card);border:1px solid var(--line);padding:22px;
  box-shadow:var(--shadow);
  display:flex;align-items:center;justify-content:center;
  aspect-ratio:1/1;overflow:hidden;position:relative;
  transition:transform .3s ease;
}
.card a:hover .card__frame{transform:translateY(-4px)}
.card__frame img{max-height:100%;width:auto;object-fit:contain;box-shadow:0 10px 26px -14px rgba(23,18,11,.6)}
.card__tag{
  position:absolute;top:14px;left:14px;
  font-family:var(--util);font-weight:800;font-size:10.5px;letter-spacing:.16em;text-transform:uppercase;
  padding:6px 10px;background:var(--ink);color:var(--paper);border-radius:2px;
}
.card__tag--reserved{background:var(--green)}
.card__tag--sold{background:var(--red)}
.card__meta{padding:16px 2px 0}
.card__artist{font-family:var(--display);font-size:20px;line-height:1;text-transform:uppercase;letter-spacing:.01em}
.card__title{font-family:var(--serif);font-style:italic;font-size:16px;color:var(--ink-soft);margin-top:5px}
.card__title .yr{font-style:normal;color:var(--muted)}
.card__spec{font-family:var(--util);font-weight:600;font-size:12px;letter-spacing:.04em;color:var(--muted);margin-top:8px;text-transform:uppercase}
.card__price{font-family:var(--util);font-weight:800;font-size:15px;margin-top:10px;display:flex;align-items:center;gap:8px}
.card__price .lbl{font-size:10px;letter-spacing:.16em;color:var(--muted);text-transform:uppercase;font-weight:700}
.card--sold .card__frame img{filter:grayscale(.55) opacity(.85)}

/* ---------- detail page ---------- */
.back{display:inline-flex;align-items:center;gap:8px;font-family:var(--util);font-weight:700;font-size:12px;letter-spacing:.16em;text-transform:uppercase;color:var(--ink-soft);margin:30px 0 8px}
.back:hover{color:var(--red)}
.work__hero{border-bottom:2px solid var(--ink);padding-bottom:20px;margin-bottom:34px}
.work__artist{font-family:var(--display);font-size:clamp(40px,7vw,92px);text-transform:uppercase;line-height:.86;margin:6px 0 0}
.work__titleline{display:flex;align-items:baseline;gap:14px;flex-wrap:wrap;margin-top:10px}
.work__title{font-family:var(--serif);font-style:italic;font-size:clamp(20px,2.6vw,30px)}
.work__year{font-family:var(--util);font-weight:700;letter-spacing:.14em;color:var(--muted);font-size:15px}
.work__grid{display:grid;grid-template-columns:1.35fr .65fr;gap:48px;align-items:start}
.work__imgwrap{background:var(--card);border:1px solid var(--line);padding:38px;box-shadow:var(--shadow);display:flex;justify-content:center}
.work__imgwrap img{max-height:78vh;width:auto;box-shadow:0 18px 44px -20px rgba(23,18,11,.65)}
.panel{position:sticky;top:108px}
.panel__price{font-family:var(--display);font-size:40px;line-height:1;color:var(--ink)}
.panel__pricelbl{font-family:var(--util);font-weight:700;font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--muted);margin-bottom:6px}
.panel__status{display:inline-block;font-family:var(--util);font-weight:800;font-size:11px;letter-spacing:.16em;text-transform:uppercase;padding:6px 12px;border-radius:2px;margin:16px 0 22px;background:var(--ink);color:var(--paper)}
.panel__status--reserved{background:var(--green)}
.panel__status--sold{background:var(--red)}
.spec-list{border-top:1px solid var(--line);margin:24px 0}
.spec-list div{display:flex;justify-content:space-between;gap:16px;padding:11px 0;border-bottom:1px solid var(--line);font-size:14px}
.spec-list dt{font-family:var(--util);font-weight:700;letter-spacing:.1em;text-transform:uppercase;font-size:11.5px;color:var(--muted)}
.spec-list dd{margin:0;text-align:right;color:var(--ink)}
.prose-block{margin-top:40px}
.prose-block h3{font-family:var(--util);font-weight:800;font-size:13px;letter-spacing:.2em;text-transform:uppercase;color:var(--red);border-bottom:2px solid var(--ink);padding-bottom:8px;margin:0 0 16px}
.prose-block p{font-family:var(--serif);font-size:17.5px;line-height:1.65;color:var(--ink-soft);margin:0}
.prov{list-style:none;padding:0;margin:0;counter-reset:p}
.prov li{position:relative;padding:11px 0 11px 40px;border-bottom:1px solid var(--line);font-size:14.5px;color:var(--ink-soft)}
.prov li::before{counter-increment:p;content:counter(p,decimal-leading-zero);position:absolute;left:0;top:11px;font-family:var(--util);font-weight:800;font-size:12px;color:var(--red);letter-spacing:.05em}
.cols2{display:grid;grid-template-columns:1fr 1fr;gap:40px}

/* more from collection */
.more{border-top:2px solid var(--ink);margin-top:64px;padding-top:36px}

/* ---------- footer ---------- */
.site-footer{background:var(--ink);color:var(--paper);margin-top:80px;padding:60px 0 34px}
.site-footer a{color:var(--paper)}
.foot__grid{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:36px;padding-bottom:40px;border-bottom:1px solid rgba(231,225,210,.22)}
.foot__name{font-family:var(--display);font-size:40px;line-height:.9;text-transform:uppercase}
.foot__name b{color:var(--red)}
.foot__tag{font-family:var(--serif);font-style:italic;color:#d9c9b0;margin-top:8px}
.foot__h{font-family:var(--util);font-weight:800;font-size:12px;letter-spacing:.2em;text-transform:uppercase;color:#bdae97;margin:0 0 14px}
.foot__grid p{margin:0 0 8px;font-size:14.5px;color:#e7e1d2}
.foot__grid a:hover{color:var(--red)}
.foot__bottom{display:flex;justify-content:space-between;flex-wrap:wrap;gap:12px;padding-top:22px;font-family:var(--util);font-size:11.5px;letter-spacing:.12em;text-transform:uppercase;color:#9a8f7c}
.foot__bottom a:hover{color:var(--paper)}

/* ---------- empty state ---------- */
.empty{padding:60px 0;text-align:center;color:var(--muted);font-family:var(--serif);font-style:italic;font-size:20px}

/* ---------- responsive ---------- */
@media(max-width:980px){
  .hero__grid{grid-template-columns:1fr;gap:26px}
  .hero__aside{border-left:none;border-top:3px solid var(--red);padding-left:0;padding-top:18px}
  .work__grid{grid-template-columns:1fr;gap:30px}
  .panel{position:static}
  .grid{grid-template-columns:repeat(2,1fr);gap:26px 22px}
  .foot__grid{grid-template-columns:1fr 1fr}
}
@media(max-width:620px){
  .wrap{padding:0 18px}
  .site-header .wrap{height:64px;gap:12px}
  .brand{gap:10px}
  .brand__mark--logo{width:40px;height:40px}
  .brand__name{font-size:19px}
  .brand__tag{font-size:11px;margin-top:1px}
  .nav{position:absolute;top:100%;left:0;right:0;background:var(--paper);flex-direction:column;align-items:stretch;
    gap:0;padding:8px 18px 16px;border-bottom:1px solid var(--line);box-shadow:0 18px 30px -18px rgba(23,18,11,.5);
    transform:translateY(-12px);opacity:0;visibility:hidden;transition:transform .25s ease,opacity .25s ease,visibility .25s;z-index:60}
  .nav.open{transform:translateY(0);opacity:1;visibility:visible}
  .nav a{padding:14px 0;width:100%;border-bottom:1px solid var(--line);font-size:14px}
  .nav .btn{margin-top:12px;width:100%;text-align:center;padding:15px}
  .nav-toggle{display:grid;place-items:center;width:42px;height:42px;border:1.5px solid var(--ink);background:transparent;border-radius:2px;flex:0 0 auto}
  .grid{grid-template-columns:1fr;gap:26px}
  .cols2{grid-template-columns:1fr}
  .foot__grid{grid-template-columns:1fr}
  .hero__head .l3::before{height:4px}
}

/* ---------- enquiry CTA (home) ---------- */
.cta{display:flex;align-items:center;justify-content:space-between;gap:40px;flex-wrap:wrap;
  background:var(--card);border:1px solid var(--line);box-shadow:var(--shadow);padding:40px 44px}
.cta__eyebrow{font-family:var(--util);font-weight:700;font-size:12px;letter-spacing:.18em;text-transform:uppercase;color:var(--red);margin-bottom:10px}
.cta__title{font-family:var(--display);font-size:clamp(30px,4vw,46px);text-transform:uppercase;line-height:.92;margin:0 0 12px}
.cta__body{font-family:var(--serif);font-style:italic;font-size:17px;color:var(--ink-soft);margin:0;max-width:60ch}
.btn--lg{padding:18px 34px;font-size:13.5px}

/* ---------- contact page ---------- */
.contact__grid{display:grid;grid-template-columns:.8fr 1.2fr;gap:54px;align-items:start}
.contact__intro .hero__body{margin-bottom:18px}
.contact__work{background:var(--card);border:1px solid var(--line);padding:18px 20px;margin-top:24px}
.contact__work .cw__lbl{font-family:var(--util);font-weight:700;font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--muted)}
.contact__work .cw__name{font-family:var(--display);font-size:22px;text-transform:uppercase;line-height:1;margin-top:6px}
.contact__work .cw__title{font-family:var(--serif);font-style:italic;color:var(--ink-soft);margin-top:4px}
.form{display:grid;grid-template-columns:1fr 1fr;gap:18px 20px}
.form .full{grid-column:1 / -1}
.field{display:flex;flex-direction:column;gap:7px}
.field label{font-family:var(--util);font-weight:700;font-size:11.5px;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-soft)}
.field label .req{color:var(--red)}
.field input,.field select,.field textarea{
  font-family:var(--body);font-size:15px;color:var(--ink);background:var(--paper-2);
  border:1.5px solid var(--line-strong);border-radius:2px;padding:13px 14px;width:100%;transition:border-color .15s ease}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--ink)}
.field textarea{resize:vertical;min-height:120px}
.form__hp{position:absolute;left:-9999px;opacity:0;height:0;overflow:hidden}
.form__actions{grid-column:1 / -1;display:flex;align-items:center;gap:18px;flex-wrap:wrap;margin-top:4px}
.form__note{font-family:var(--serif);font-style:italic;font-size:13.5px;color:var(--muted);margin:0}
.form__msg{grid-column:1 / -1;padding:16px 18px;border-radius:2px;font-family:var(--util);font-weight:600;font-size:14px;display:none}
.form__msg.show{display:block}
.form__msg--ok{background:rgba(60,81,65,.12);border:1px solid var(--green);color:var(--green)}
.form__msg--err{background:rgba(197,57,43,.1);border:1px solid var(--red);color:var(--red-deep)}
.contact__sent{display:none;padding:46px 0}
.contact__sent.show{display:block}
.contact__sent h2{font-family:var(--display);font-size:clamp(34px,5vw,60px);text-transform:uppercase;line-height:.9;margin:0 0 14px}
.contact__sent p{font-family:var(--serif);font-style:italic;font-size:19px;color:var(--ink-soft);max-width:56ch}
@media(max-width:980px){
  .contact__grid{grid-template-columns:1fr;gap:30px}
  .cta{padding:30px}
}
@media(max-width:620px){
  .form{grid-template-columns:1fr}
}

/* price / shipping note */
.panel__note{font-family:var(--body);font-size:12.5px;line-height:1.5;color:var(--muted);
  margin:18px 0 0;padding-top:14px;border-top:1px solid var(--line)}

/* brand logo badge */
.brand__mark--logo{border:none;background:transparent;width:52px;height:52px;padding:0}
.brand__mark--logo img{width:100%;height:100%;object-fit:contain;display:block}
.foot__logo{width:72px;height:72px;object-fit:contain;display:block;margin-bottom:16px}
