/* =========================================================================
   Record shop — "Editorial Press" theme (warm cream + ink black + red)
   Headings: Archivo (heavy grotesque) · Body / Thai: Sarabun
   Signature: the vinyl disc slides out from behind the album sleeve.
   ========================================================================= */
:root{
  --bg:#e2e0d8; --paper:#f1f0ea; --ink:#34382e; --muted:#8c897d;
  --line:#d1cec3; --accent:#e9543a; --accent-d:#cf4329;
  --ok:#3f7d54; --danger:#cf4329; --field:#ffffff;
  --head:'Archivo','Sarabun',system-ui,sans-serif;
  --sans:'Sarabun',system-ui,-apple-system,'Segoe UI',sans-serif;
  --radius:2px; --shadow:0 10px 34px rgba(40,42,34,.10);
}
*{box-sizing:border-box}
body{margin:0;font-family:var(--sans);background:var(--bg);color:var(--ink);
  line-height:1.6;-webkit-font-smoothing:antialiased}
.wrap{max-width:1180px;margin:0 auto;padding:0 32px}
a{color:var(--ink);text-decoration:none}
a:hover{color:var(--accent)}

h1,h2,h3{font-family:var(--head);font-weight:800;line-height:1.02;margin:0 0 .4em;
  color:var(--ink);letter-spacing:-.02em}
h1{font-size:clamp(2.2rem,6vw,4rem)}
h2{font-size:clamp(1.7rem,3.4vw,2.4rem)}
h3{font-size:1.25rem;font-weight:700}

/* main sheet — the whole shop sits on a floating paper panel like the refs */
body:not(.admin) main.wrap{background:var(--paper);max-width:1180px;margin:26px auto 40px;
  padding:46px 56px 70px;border:1px solid var(--line);box-shadow:var(--shadow);min-height:60vh}
@media(max-width:760px){body:not(.admin) main.wrap{padding:30px 22px 50px;margin:0}}
body.admin main.wrap{padding-top:34px;padding-bottom:70px;min-height:60vh}

/* ---- top bar ---- */
.topbar{background:transparent}
.topbar .wrap{display:flex;align-items:center;justify-content:space-between;min-height:60px;gap:16px}
.brand{display:inline-flex;align-items:center}
.brand-logo{height:48px;width:auto;display:block;transition:opacity .15s;mix-blend-mode:multiply}
.brand:hover .brand-logo{opacity:.8}
.topbar-right{display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.topbar nav{display:flex;align-items:center;gap:20px}
.topbar nav a{color:var(--ink);opacity:.7;font-size:.82rem;font-weight:600}
.topbar nav a:hover{opacity:1;color:var(--accent)}
.cart-link{display:inline-flex;align-items:center;gap:5px}
.cart-badge{background:var(--accent);color:#fff;border-radius:999px;font-size:.66rem;
  font-weight:700;padding:1px 7px}
.lang-switch{margin-left:6px;display:flex;align-items:center;gap:7px;font-size:.76rem;
  font-weight:600}
.lang-switch a{color:var(--muted)}
.lang-switch a:hover{color:var(--ink)}
.lang-switch .on{color:var(--accent)}
.lang-switch i{color:var(--line);font-style:normal}

/* ---- giant editorial hero ---- */
.hero{position:relative;margin:6px 0 54px;padding-bottom:22px;border-bottom:1px solid var(--line)}
.hero-logo-wrap{padding:20px 0 10px;display:flex;justify-content:center}
.hero-logo{max-width:520px;width:85%;height:auto;display:block;mix-blend-mode:multiply;margin:0 auto}
.hero-type{font-family:var(--head);font-weight:900;text-transform:uppercase;
  line-height:.82;letter-spacing:-.035em;font-size:clamp(2rem,10vw,6.7rem);
  color:var(--accent);position:relative;z-index:2;text-align:center}
.hero-type .line{display:block}
.hero-type .accent-line{position:relative}
/* spinning vinyl tucked beside the word VINYL */
.hero-vinyl{display:inline-block;vertical-align:-.14em;width:.86em;height:.86em;margin-left:.1em;
  border-radius:50%;position:relative;background:#111;
  background-image:repeating-radial-gradient(circle at 50% 50%,
    rgba(255,255,255,.06) 0 1px, rgba(0,0,0,0) 1px 4px),
    radial-gradient(circle at 50% 50%, #232323 0 7%, #0d0d0d 7% 100%);
  box-shadow:0 6px 20px rgba(0,0,0,.3);animation:spin 6s linear infinite}
.hero-vinyl::before{content:"";position:absolute;top:50%;left:50%;width:32%;height:32%;
  border-radius:50%;transform:translate(-50%,-50%);
  background:radial-gradient(circle at 50% 50%, var(--paper) 0 9%, var(--accent) 9% 100%)}
@keyframes spin{to{transform:rotate(360deg)}}
@media(prefers-reduced-motion:reduce){.hero-vinyl{animation:none}}
.hero-foot{display:flex;align-items:center;justify-content:space-between;gap:18px;
  flex-wrap:wrap;margin-top:24px}
.hero-tag{color:var(--muted);font-size:.82rem;text-transform:uppercase;letter-spacing:.16em;font-weight:600}
.hero-cue{font-family:var(--head);font-weight:700;font-size:.84rem;text-transform:uppercase;
  letter-spacing:.05em;color:var(--ink)}
.hero-cue:hover{color:var(--accent)}
@media(max-width:760px){.hero-type{font-size:clamp(1.8rem,8vw,3rem)}}

/* ---- section head (Best sellers + genre nav) ---- */
.section-head{display:flex;align-items:baseline;gap:22px;flex-wrap:wrap;margin:0 0 30px}
.section-head h1{margin:0;font-size:clamp(1.9rem,4vw,2.6rem)}
.genre-nav{display:flex;gap:18px;flex-wrap:wrap;align-items:baseline}
.genre-nav a{font-size:.86rem;font-weight:600;color:var(--muted)}
.genre-nav a:hover{color:var(--ink)}
.genre-nav a.on{color:var(--ink);text-decoration:underline;text-underline-offset:4px;text-decoration-color:var(--accent)}
.shop-search{margin-left:auto;display:flex;gap:0;align-items:stretch;
  border:1px solid var(--line);border-radius:999px;overflow:hidden;background:#fff}
.shop-search input[type=text]{border:none;margin:0;padding:8px 16px;min-width:170px;background:transparent;font-size:.86rem}
.shop-search input:focus{outline:none}
.shop-search button{border:none;border-radius:0;background:transparent;color:var(--ink);
  padding:8px 16px;font-size:.86rem}
.shop-search button:hover{background:var(--accent);color:#fff}
.count-line{color:var(--muted);font-size:.8rem;text-transform:uppercase;letter-spacing:.12em;margin:-18px 0 26px}

/* ---- record grid ---- */
.records{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:30px 34px;margin:8px 0}
.record{display:flex;flex-direction:column}
.record.soldout{opacity:.7}

/* framed box that holds the sleeve + the vinyl peeking out */
.record-frame{position:relative;display:flex;align-items:center;justify-content:center;
  border:1px solid var(--line);background:#fff;padding:30px;aspect-ratio:1.18;overflow:hidden}
.record-frame:hover{border-color:var(--ink)}
.cover-wrap{position:relative;width:62%;aspect-ratio:1}
.cover-wrap .sleeve{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;
  z-index:2;box-shadow:0 10px 26px rgba(20,18,12,.22);background:#eee}
.cover-wrap .sleeve.fallback{display:flex;align-items:center;justify-content:center;
  font-size:2.6rem;color:#bbb;background:#f1efe9}
/* the spinning black disc */
.disc{position:absolute;inset:0;width:100%;height:100%;border-radius:50%;z-index:1;
  transform:translateX(16%);transition:transform .5s cubic-bezier(.22,.7,.18,1);
  background:#111;
  background-image:repeating-radial-gradient(circle at 50% 50%,
    rgba(255,255,255,.05) 0 1px, rgba(0,0,0,0) 1px 3px),
    radial-gradient(circle at 50% 50%, #232323 0 8%, #0d0d0d 8% 100%);
  box-shadow:0 8px 22px rgba(0,0,0,.28)}
.disc::before{content:"";position:absolute;top:50%;left:50%;width:34%;height:34%;
  border-radius:50%;transform:translate(-50%,-50%);
  background:radial-gradient(circle at 50% 50%, #fff 0 7%, var(--accent) 7% 100%)}
.record-frame:hover .disc,.product-cover:hover .disc{transform:translateX(40%) rotate(8deg)}
.cover-tag{position:absolute;top:12px;left:12px;z-index:3;background:var(--accent);color:#fff;
  font-family:var(--head);text-transform:uppercase;font-size:.64rem;font-weight:700;
  letter-spacing:.06em;padding:3px 9px}
.format-tag{position:absolute;top:14px;right:16px;z-index:3;color:var(--muted);
  font-size:.66rem;text-transform:uppercase;letter-spacing:.12em;font-weight:600}

/* info under the frame */
.record-info{padding:14px 2px 0;display:flex;flex-direction:column;flex:1}
.record-title{font-family:var(--head);font-weight:800;font-size:1rem;text-transform:uppercase;
  letter-spacing:-.01em;line-height:1.15;color:var(--ink)}
.record-title:hover{color:var(--accent)}
.record-artist{font-size:.92rem;margin-top:3px;color:var(--ink)}
.record .meta{font-size:.68rem;color:var(--muted);margin-top:5px;text-transform:uppercase;letter-spacing:.1em}
.record-foot{display:flex;align-items:center;justify-content:space-between;gap:8px;margin-top:12px}
.price{font-family:var(--head);font-size:1.15rem;font-weight:800;color:var(--ink)}
.lowstock{margin-top:6px;font-size:.72rem;color:var(--accent);text-transform:uppercase;letter-spacing:.08em}

/* red round button (View all) */
.round-btn{display:inline-flex;align-items:center;justify-content:center;text-align:center;
  width:118px;height:118px;border-radius:50%;background:var(--accent);color:#fff;
  font-family:var(--head);font-weight:700;text-transform:uppercase;letter-spacing:.04em;
  font-size:.82rem;line-height:1.1;transition:transform .15s,background .15s}
.round-btn:hover{background:var(--accent-d);color:#fff;transform:scale(1.05)}
.viewall-row{display:flex;justify-content:center;margin-top:40px}

/* ---- product page ---- */
.product{display:grid;grid-template-columns:minmax(0,1fr) minmax(0,1fr);gap:40px;align-items:start}
@media(max-width:760px){.product{grid-template-columns:1fr}}
.product-cover{position:relative;display:flex;align-items:center;justify-content:center;
  border:1px solid var(--line);background:#fff;padding:44px;aspect-ratio:1.1;overflow:hidden}
.product-cover .cover-wrap{width:66%}
.product-artist{color:var(--accent);font-family:var(--head);font-weight:700;font-size:1.2rem;margin:0 0 16px}
.add-form{margin-top:12px}
.add-form input[type=number]{max-width:120px}

/* ---- forms ---- */
input,select,textarea,button{font:inherit;font-family:var(--sans)}
input,select,textarea{width:100%;padding:11px 13px;border:1px solid var(--line);
  border-radius:var(--radius);background:var(--field);margin-bottom:14px;color:var(--ink)}
input::placeholder,textarea::placeholder{color:var(--muted)}
input:focus,select:focus,textarea:focus{outline:2px solid var(--ink);border-color:var(--ink)}
label{display:block;font-size:.78rem;color:var(--muted);margin-bottom:6px;
  text-transform:uppercase;letter-spacing:.08em;font-weight:600}
label.check{display:flex;align-items:center;gap:8px;color:var(--ink);text-transform:none;letter-spacing:0}
label.check input{width:auto;margin:0}
.inline{display:inline}

button,.btn{display:inline-block;background:var(--ink);color:#fff;border:none;
  padding:12px 26px;border-radius:var(--radius);cursor:pointer;font-weight:700;
  font-family:var(--head);text-transform:uppercase;letter-spacing:.05em;font-size:.8rem;
  text-align:center;transition:background .15s}
button:hover,.btn:hover{background:var(--accent);color:#fff;text-decoration:none}
button.big,.btn.big{width:100%;padding:14px;margin-top:4px}
.btn.small,button.small{padding:7px 14px;font-size:.7rem}
.btn.ghost,button.ghost{background:transparent;color:var(--ink);border:1px solid var(--line)}
.btn.ghost:hover,button.ghost:hover{background:var(--ink);color:#fff;border-color:var(--ink)}
button.ok{background:var(--ok);color:#fff} button.ok:hover{background:#26794c}
button.danger,.btn.danger{background:var(--accent);color:#fff} .btn.danger:hover,button.danger:hover{background:var(--accent-d)}

/* ---- card ---- */
.card{background:var(--paper);border:1px solid var(--line);border-radius:var(--radius);
  padding:26px;margin-bottom:24px}
.card h1,.card h2{margin-top:0}

/* ---- layout helpers ---- */
.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:26px}
.grid-2>div{min-width:0}
@media(max-width:760px){.grid-2{grid-template-columns:1fr}}
.cart-layout{grid-template-columns:1.3fr 1fr}
@media(max-width:760px){.cart-layout{grid-template-columns:1fr}}
.center{text-align:center}.muted{color:var(--muted)}.small{font-size:.85rem}.nowrap{white-space:nowrap}
.back{display:inline-block;margin-bottom:18px;color:var(--muted);text-transform:uppercase;
  letter-spacing:.1em;font-size:.74rem;font-weight:600}
.back:hover{color:var(--accent)}

/* summary table */
table.sum{width:100%;border-collapse:collapse}
table.sum td{padding:10px 0;border-bottom:1px solid var(--line)}
table.sum td:last-child{text-align:right;font-weight:600}
table.sum tr.grand td{font-family:var(--head);font-size:1.3rem;font-weight:800;border-bottom:none;padding-top:14px;color:var(--ink)}

/* alerts */
.alert{padding:12px 15px;border-radius:var(--radius);margin:14px 0;font-size:.95rem}
.alert.error{background:#fbe4df;color:#8f231a;border:1px solid #f0c4bc}
.alert.success{background:#e2f0e6;color:#1f5f3c;border:1px solid #bfe0c9}

/* payment */
.pay{text-align:center;margin:12px 0}
.qr{max-width:250px;width:100%;border:1px solid var(--line);border-radius:var(--radius);padding:8px;background:#fff}
ul.bank{list-style:none;padding:0;margin:16px 0;text-align:left}
ul.bank li{padding:8px 0;border-bottom:1px dashed var(--line)}

/* badges */
.badge{display:inline-block;padding:4px 12px;border-radius:999px;font-size:.66rem;font-weight:700;
  font-family:var(--head);text-transform:uppercase;letter-spacing:.06em;vertical-align:middle}
.badge.pending{background:#f4e6c4;color:#8a6a1c}
.badge.submitted{background:#d8e8f3;color:#23557a}
.badge.paid{background:#dcefdf;color:#1f6e44}
.badge.shipped{background:#d6f0cf;color:#2f6a23}
.badge.rejected,.badge.cancelled{background:#fbe0db;color:#9a2c20}

/* ---- tables (admin + cart) ---- */
table.list{width:100%;border-collapse:collapse;font-size:.92rem}
table.list th{text-align:left;color:var(--muted);font-weight:600;padding:9px 8px;border-bottom:2px solid var(--line);
  text-transform:uppercase;letter-spacing:.07em;font-size:.7rem}
table.list td{padding:11px 8px;border-bottom:1px solid var(--line);vertical-align:top}
.cart-table td,.cart-table th{vertical-align:middle}
.qty-input{width:70px;margin:0;text-align:center}
.filters{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:18px}
.chip{background:transparent;color:var(--ink);padding:7px 15px;border-radius:999px;font-size:.78rem;
  border:1px solid var(--line)}
.chip.on{background:var(--ink);color:#fff;border-color:var(--ink)}
.actions .btn-row{display:flex;gap:8px;flex-wrap:wrap;margin-top:6px}
.slip{max-width:100%;border:1px solid var(--line);border-radius:var(--radius)}

/* ---- accounts ---- */
.acc-cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:16px;margin-bottom:8px}
.acc-card{background:var(--paper);border:1px solid var(--line);border-radius:var(--radius);padding:22px 24px}
.acc-card.accent{background:var(--ink);color:#fff;border-color:var(--ink)}
.acc-card.muted-card{opacity:.7}
.acc-label{font-size:.7rem;text-transform:uppercase;letter-spacing:.1em;font-weight:600;margin-bottom:8px;opacity:.7}
.acc-card.accent .acc-label{opacity:.8;color:#fff}
.acc-val{font-family:var(--head);font-size:1.9rem;font-weight:800;line-height:1;color:var(--accent)}
.acc-card.accent .acc-val{color:#fff}
.acc-sub{font-size:.76rem;color:var(--muted);margin-top:6px}
.acc-card.accent .acc-sub{color:rgba(255,255,255,.6)}

/* ---- product gallery ---- */
.product-gallery{display:flex;flex-wrap:wrap;gap:12px;margin-top:32px;padding-top:24px;border-top:1px solid var(--line)}
.gallery-thumb{display:block;width:140px;height:140px;overflow:hidden;border:1px solid var(--line);border-radius:var(--radius);transition:border-color .15s}
.gallery-thumb:hover{border-color:var(--ink)}
.gallery-thumb img{width:100%;height:100%;object-fit:cover;display:block}
@media(max-width:760px){.gallery-thumb{width:calc(33% - 8px)}}

/* ---- footer ---- */
.foot{background:var(--ink);padding:34px 0;color:rgba(233,84,58,.92);
  font-size:.78rem;text-align:center;text-transform:uppercase;letter-spacing:.14em;
  font-family:var(--head);font-weight:600}
body:not(.admin) .foot{margin-top:-1px}
