:root{
  --ink:#101820;
  --paper:#FAFBFC;
  --card:#FFFFFF;
  --accent:#E0218A;        /* process magenta */
  --accent-dark:#B5126C;
  --cyan:#00B5D4;
  --yellow:#F4C20D;
  --slate:#5B6770;
  --line:#E2E8EC;
  --wash:#FBEAF3;
  --radius:14px;
  --display:'Anton', sans-serif;
  --body:'Archivo', sans-serif;
  --mono:'IBM Plex Mono', monospace;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
@media (prefers-reduced-motion: reduce){
  html{scroll-behavior:auto}
  *,*::before,*::after{animation:none!important;transition:none!important}
}
body{font-family:var(--body);background:var(--paper);color:var(--ink);line-height:1.55;-webkit-font-smoothing:antialiased}
a{color:inherit}
button{font-family:inherit;cursor:pointer}
:focus-visible{outline:3px solid var(--accent);outline-offset:2px;border-radius:4px}
.wrap{max-width:1100px;margin:0 auto;padding:0 24px}

/* ---------- header ---------- */
header{position:sticky;top:0;z-index:20;background:rgba(250,251,252,.9);backdrop-filter:blur(8px);border-bottom:1px solid var(--line)}
.nav{display:flex;align-items:center;justify-content:space-between;height:62px}
.logo{font-family:var(--display);font-size:1.3rem;letter-spacing:.04em;text-transform:uppercase;text-decoration:none;display:flex;align-items:center;gap:.55rem}
.cmyk{display:inline-flex;gap:3px}
.cmyk i{width:9px;height:9px;border-radius:50%}
.cmyk i:nth-child(1){background:var(--cyan)}
.cmyk i:nth-child(2){background:var(--accent)}
.cmyk i:nth-child(3){background:var(--yellow)}
.cmyk i:nth-child(4){background:var(--ink)}
.back{font-family:var(--mono);font-size:.78rem;text-decoration:none;color:var(--slate)}
.back:hover{color:var(--ink)}

/* ---------- hero ---------- */
.hero{padding:60px 0 40px;text-align:left}
.eyebrow{font-family:var(--mono);font-size:.78rem;letter-spacing:.14em;text-transform:uppercase;color:var(--accent-dark);margin-bottom:16px;display:flex;align-items:center;gap:10px}
.eyebrow::before{content:"";width:34px;height:2px;background:var(--accent)}
h1{font-family:var(--display);font-weight:400;font-size:clamp(2.3rem,5.5vw,4rem);line-height:1.04;text-transform:uppercase}
h1 .accent{color:var(--accent)}
.lede{margin-top:18px;font-size:1.1rem;color:var(--slate);max-width:60ch}

/* ---------- studio layout ---------- */
.studio{display:grid;grid-template-columns:1fr 400px;gap:26px;align-items:start;padding:34px 0 60px}

/* preview wall */
.preview-card{
  background:var(--card);border:1px solid var(--line);border-radius:var(--radius);
  overflow:hidden;position:sticky;top:84px;
}
.wall{
  background:linear-gradient(180deg,#EDF1F4 0%, #E2E8EC 100%);
  padding:46px 30px 0;display:grid;place-items:end center;min-height:380px;position:relative;
}
.wall::after{ /* floor */
  content:"";position:absolute;left:0;right:0;bottom:0;height:54px;
  background:linear-gradient(180deg,#D6DEE3,#C9D2D8);
}
.frame{
  position:relative;z-index:2;background:#fff;
  box-shadow:0 22px 40px -16px rgba(16,24,32,.45);
  padding:10px;transition:width .25s ease, height .25s ease;
  margin-bottom:26px;
}
.frame.canvas-wrap{padding:0;background:none}
.frame img,.frame .ph{display:block;width:100%;height:100%;object-fit:cover;background:#EDE3EA}
.frame .ph{
  display:grid;place-items:center;color:var(--slate);font-family:var(--mono);
  font-size:.72rem;letter-spacing:.1em;text-transform:uppercase;text-align:center;padding:10px;
}
/* crop marks — the print-shop signature */
.frame::before,.frame::after{
  content:"";position:absolute;width:18px;height:18px;pointer-events:none;
}
.frame::before{top:-12px;left:-12px;border-top:2px solid var(--ink);border-left:2px solid var(--ink)}
.frame::after{bottom:-12px;right:-12px;border-bottom:2px solid var(--ink);border-right:2px solid var(--ink)}
.preview-meta{
  display:flex;justify-content:space-between;align-items:center;gap:10px;
  padding:14px 18px;border-top:1px solid var(--line);
  font-family:var(--mono);font-size:.74rem;color:var(--slate);flex-wrap:wrap;
}
.preview-meta b{color:var(--ink)}

/* configurator */
.config{display:grid;gap:16px}
.panel{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);padding:20px}
.panel h2{
  font-family:var(--mono);font-size:.72rem;letter-spacing:.16em;text-transform:uppercase;
  color:var(--accent-dark);margin-bottom:14px;display:flex;align-items:center;gap:8px;
}
.step-dot{
  width:18px;height:18px;border-radius:50%;background:var(--ink);color:#fff;
  display:inline-grid;place-items:center;font-size:.62rem;flex:none;
}

/* upload */
.drop{
  border:2px dashed #D9B8CB;border-radius:10px;background:var(--wash);
  padding:26px 16px;text-align:center;cursor:pointer;transition:border-color .15s, background .15s;
  display:block;
}
.drop:hover,.drop.drag{border-color:var(--accent);background:#F8DEEC}
.drop .big{font-weight:700;font-size:.95rem}
.drop .small{font-size:.8rem;color:var(--slate);margin-top:4px}
.drop input{display:none}
.file-row{
  display:none;margin-top:12px;align-items:center;justify-content:space-between;gap:10px;
  font-family:var(--mono);font-size:.76rem;color:var(--slate);
}
.file-row.show{display:flex}
.file-row button{background:none;border:none;color:var(--accent-dark);font-weight:600;font-size:.76rem;font-family:var(--mono)}

/* chips */
.chips{display:flex;flex-wrap:wrap;gap:8px}
.chip{
  border:1.5px solid var(--line);background:#fff;border-radius:999px;
  padding:.45rem .9rem;font-size:.83rem;font-weight:600;color:var(--ink);
  transition:all .12s;
}
.chip:hover{border-color:#c4ced5}
.chip[aria-pressed="true"]{background:var(--ink);border-color:var(--ink);color:#fff}

textarea{
  width:100%;border:1.5px solid var(--line);border-radius:10px;padding:.65rem .75rem;
  font-family:var(--body);font-size:.9rem;resize:vertical;min-height:64px;color:var(--ink);
}
textarea::placeholder{color:#9AA6AE}

/* size grid */
.size-grid{display:grid;grid-template-columns:1fr 1fr 1fr;gap:8px}
.size{
  border:1.5px solid var(--line);border-radius:10px;background:#fff;padding:10px 6px;
  text-align:center;transition:all .12s;
}
.size:hover{border-color:#c4ced5}
.size[aria-pressed="true"]{border-color:var(--accent);background:var(--wash)}
.size .dim{font-family:var(--mono);font-weight:600;font-size:.86rem}
.size .price{font-size:.74rem;color:var(--slate);margin-top:2px}

.qty-row{display:flex;align-items:center;gap:12px}
.qty-row label{font-size:.85rem;font-weight:600}
.qty-btn{
  width:32px;height:32px;border-radius:8px;border:1.5px solid var(--line);background:#fff;
  font-size:1.05rem;font-weight:700;
}
.qty-btn:hover{border-color:var(--ink)}
#qtyVal{font-family:var(--mono);font-weight:600;min-width:24px;text-align:center}
.qty-note{font-size:.75rem;color:var(--slate);margin-left:auto}

/* total */
.total-panel{background:var(--ink);color:#fff;border:none}
.total-panel h2{color:#F08CC1}
.total-line{display:flex;justify-content:space-between;font-size:.85rem;color:#B8C0C7;padding:3px 0}
.total-line.grand{
  border-top:1px solid #2A323D;margin-top:10px;padding-top:12px;
  color:#fff;font-size:1.05rem;font-weight:700;align-items:baseline;
}
.total-line.grand b{font-family:var(--mono);font-size:1.5rem}
.order-btn{
  margin-top:16px;width:100%;background:var(--accent);border:none;color:#fff;
  font-size:1rem;font-weight:700;border-radius:12px;padding:.9rem;
  transition:background .12s, transform .12s;
}
.order-btn:hover{background:var(--accent-dark);transform:translateY(-1px)}
.order-note{margin-top:10px;font-size:.74rem;color:#9AA1A8;text-align:center}

/* confirmation */
#confirm{display:none;margin:0 0 60px}
#confirm.show{display:block;animation:rise .4s ease}
@keyframes rise{from{opacity:0;transform:translateY(12px)}to{opacity:1;transform:none}}
.confirm-card{
  background:var(--card);border:2px solid var(--ink);border-radius:var(--radius);
  padding:26px;max-width:620px;
}
.confirm-card h2{font-family:var(--display);font-weight:400;font-size:1.5rem;text-transform:uppercase;margin-bottom:6px}
.confirm-card .sub{color:var(--slate);font-size:.9rem;margin-bottom:16px}
.confirm-card dl{display:grid;grid-template-columns:auto 1fr;gap:6px 18px;font-size:.9rem}
.confirm-card dt{color:var(--slate)}
.confirm-card dd{font-family:var(--mono);font-weight:500}

/* product strip */
.strip{border-top:1px solid var(--line);padding:56px 0}
.strip h2{font-family:var(--display);font-weight:400;font-size:1.8rem;text-transform:uppercase;margin-bottom:26px}
.strip-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.strip-card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:22px}
.strip-card h3{font-size:1rem;margin-bottom:6px}
.strip-card p{font-size:.88rem;color:var(--slate)}
.swatch{width:34px;height:34px;border-radius:8px;margin-bottom:12px}

/* ---------- subpages (legal, FAQ, about) ---------- */
.page{padding:54px 0 70px;max-width:760px}
.page .eyebrow{margin-bottom:12px}
.page h1{font-size:clamp(1.9rem,4vw,2.8rem);margin-bottom:6px}
.page .updated{font-family:var(--mono);font-size:.76rem;color:var(--slate);margin-bottom:30px}
.page h2{font-family:var(--body);font-weight:700;font-size:1.15rem;margin:32px 0 10px}
.page h3{font-size:1rem;margin:20px 0 8px}
.page p,.page li{font-size:.95rem;color:#2A323D}
.page ul,.page ol{padding-left:1.3rem;margin:8px 0 14px;display:grid;gap:6px}
.page a{color:var(--accent-dark)}
.page .callout{
  background:var(--wash);border:1px solid #EFC8DD;border-radius:10px;
  padding:14px 16px;font-size:.9rem;margin:16px 0;
}

/* FAQ accordion */
.faq-item{border:1px solid var(--line);border-radius:10px;background:#fff;margin-bottom:10px}
.faq-item summary{
  cursor:pointer;padding:14px 16px;font-weight:600;font-size:.95rem;list-style:none;
  display:flex;justify-content:space-between;align-items:center;gap:12px;
}
.faq-item summary::-webkit-details-marker{display:none}
.faq-item summary::after{content:"+";font-family:var(--mono);color:var(--accent-dark);font-size:1.1rem}
.faq-item[open] summary::after{content:"−"}
.faq-item .a{padding:0 16px 14px;font-size:.9rem;color:var(--slate)}

/* ---------- footer ---------- */
footer{border-top:1px solid var(--line);padding:36px 0 30px;margin-top:20px}
.foot-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:28px;margin-bottom:26px}
.foot-grid h3{font-family:var(--mono);font-size:.7rem;letter-spacing:.14em;text-transform:uppercase;color:var(--accent-dark);margin-bottom:10px}
.foot-grid ul{list-style:none;display:grid;gap:6px}
.foot-grid a{font-size:.85rem;color:var(--slate);text-decoration:none}
.foot-grid a:hover{color:var(--ink);text-decoration:underline}
.foot-blurb{font-size:.85rem;color:var(--slate);max-width:34ch;margin-top:8px}
.foot-meta{
  display:flex;flex-wrap:wrap;gap:10px;justify-content:space-between;
  font-size:.8rem;color:var(--slate);border-top:1px solid var(--line);padding-top:18px;
}

@media (max-width: 960px){
  .studio{grid-template-columns:1fr}
  .preview-card{position:static}
  .strip-grid{grid-template-columns:1fr}
  .foot-grid{grid-template-columns:1fr 1fr}
}
@media (max-width:520px){.size-grid{grid-template-columns:1fr 1fr}}
