/* Clay Studio OS — design system: "Clean modern"
   cool off-white surfaces · single clay accent · Inter throughout
   Re-skins the existing class names so every page adopts the look.
   To switch the accent to blue, set --accent:#2f6df6 (and tints) below. */
:root{
  /* Accent (brand clay red). */
  --accent:#aa2c1c; --accent-600:#97271a; --accent-700:#7e2016;
  --accent-100:#f0d3cd; --accent-50:#f9ece9;

  /* Back-compat aliases — older inline styles still reference var(--clay*) */
  --clay:var(--accent); --clay-600:var(--accent-600); --clay-700:var(--accent-700);
  --clay-100:var(--accent-100); --clay-50:var(--accent-50); --clay-light:var(--accent-100);

  /* Surfaces & ink — warm canvas (claude.com-inspired) */
  --cream:#f4f1ea; --sand:#ece5d8; --paper:#ffffff;
  --ink:#20242b; --ink-2:#52565f; --muted:#837b70;
  --line:#e7ded0; --line-2:#d8cdbb;

  /* Status */
  --ok:#15803d; --ok-bg:#e8f6ec; --warn:#b45309; --warn-bg:#fcf2e3; --bad:#b91c1c; --bad-bg:#fcebea;

  /* Type — Inter for body/UI; Clay Studio display for headings */
  --sans:'Inter',system-ui,-apple-system,'Segoe UI',Roboto,sans-serif;
  --serif:'Clay Studio',Georgia,serif;

  /* Shape & motion */
  --r-lg:16px; --r-md:12px; --r-sm:7px;
  --sh-sm:0 1px 2px rgba(40,33,24,.05);
  --sh-md:0 6px 18px rgba(40,33,24,.08), 0 1px 3px rgba(40,33,24,.05);
  --ease:cubic-bezier(.22,.61,.36,1);
  --card-radius:var(--r-lg);
}
*{box-sizing:border-box}
body{
  margin:0; font-family:var(--sans);
  background:var(--cream);
  color:var(--ink); line-height:1.55; -webkit-font-smoothing:antialiased; text-rendering:optimizeLegibility;
}
h1,h2,h3{font-family:var(--serif);font-weight:600;line-height:1.16;letter-spacing:-.01em;color:var(--ink)}
h1{font-size:1.95rem} h2{font-size:1.4rem;font-weight:600} h3{font-size:1.08rem;font-weight:600}
a{color:var(--accent-700);text-decoration:none}
a:hover{color:var(--accent)}
small{color:var(--muted)}

/* Nav — light, crisp app bar */
nav.topbar{
  position:sticky;top:0;z-index:50;
  background:rgba(244,241,234,.85);backdrop-filter:saturate(180%) blur(8px);
  color:var(--ink);border-bottom:1px solid var(--line);
  display:flex;align-items:center;gap:1.3rem;padding:.7rem 2rem;flex-wrap:wrap;
}
nav.topbar .brand{
  font-family:var(--sans);font-size:1.12rem;letter-spacing:-.01em;color:var(--ink);font-weight:700;
  display:flex;align-items:center;gap:.55rem;text-decoration:none;text-transform:none;
}
/* The brand link now carries the real logo image, so no decorative square. */
nav.topbar a{color:var(--ink-2);text-decoration:none;opacity:1;font-size:.9rem;font-weight:500;transition:.15s var(--ease)}
nav.topbar a:hover{color:var(--accent)}
nav.topbar a.brand{color:var(--ink)}
nav.topbar .spacer{flex:1}

main{max-width:1120px;margin:0 auto;padding:1.8rem 1.4rem 4rem}

/* Hero — understated light panel with accent edge */
.hero{
  background:var(--paper);border:1px solid var(--line);border-left:4px solid var(--accent);
  color:var(--ink);border-radius:var(--r-lg);padding:2.6rem 2.4rem;margin:1rem 0 2rem;box-shadow:var(--sh-sm);
}
.hero h1{color:var(--ink);font-size:2.3rem;margin:0 0 .5rem;letter-spacing:-.025em}
.hero p{font-size:1.08rem;max-width:38rem;color:var(--ink-2);margin:0}
.hero .btn{background:var(--accent);color:#fff!important}
.hero .btn:hover{background:var(--accent-700)}

/* Cards & grid */
.grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1rem}
.card{
  background:var(--paper);border:1px solid var(--line);border-radius:var(--r-lg);
  padding:1.2rem 1.4rem;box-shadow:var(--sh-sm);transition:.16s var(--ease);
}
.card h3{margin-top:0}
.grid .card:hover{box-shadow:var(--sh-md);border-color:var(--line-2)}

/* Badges */
.badge{
  display:inline-block;font-size:.72rem;font-weight:600;font-family:var(--sans);letter-spacing:.01em;
  padding:.18rem .6rem;border-radius:6px;background:var(--sand);color:var(--ink-2);margin-right:.3rem;
}
.badge.ok{background:var(--ok-bg);color:var(--ok)}
.badge.warn{background:var(--warn-bg);color:var(--warn)}
.badge.bad{background:var(--bad-bg);color:var(--bad)}

/* Buttons */
.btn{
  display:inline-block;background:var(--accent);color:#fff!important;border:none;
  padding:.58rem 1.2rem;border-radius:var(--r-md);font-size:.92rem;font-weight:600;cursor:pointer;
  text-decoration:none;font-family:inherit;transition:.14s var(--ease);box-shadow:var(--sh-sm);
}
.btn:hover{background:var(--accent-700)}
.btn:active{transform:translateY(1px)}
.btn.secondary{background:var(--paper);color:var(--ink)!important;border:1px solid var(--line-2);box-shadow:var(--sh-sm)}
.btn.secondary:hover{background:var(--sand);border-color:var(--muted)}
.btn.small{padding:.3rem .8rem;font-size:.82rem}
.btn.danger{background:var(--bad)}
.btn.danger:hover{background:#991b1b}

/* Forms */
form.stacked label{display:block;margin:.9rem 0 .3rem;font-weight:600;font-size:.88rem;color:var(--ink-2)}
form.stacked input[type=text], form.stacked input[type=tel], form.stacked input[type=email],
form.stacked input[type=password], form.stacked input[type=number], form.stacked input[type=date],
form.stacked select, form.stacked textarea,
.filters input, .filters select{
  width:100%;max-width:28rem;padding:.55rem .75rem;border:1px solid var(--line-2);border-radius:var(--r-md);
  font-size:.93rem;font-family:inherit;background:var(--paper);color:var(--ink);transition:border-color .15s,box-shadow .15s;
}
form.stacked input:focus, form.stacked select:focus, form.stacked textarea:focus,
.filters input:focus, .filters select:focus{
  outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-50);
}
form .help{color:var(--muted);font-size:.85rem}

/* Tables */
table.list{
  width:100%;border-collapse:separate;border-spacing:0;background:var(--paper);
  border:1px solid var(--line);border-radius:var(--r-lg);overflow:hidden;box-shadow:var(--sh-sm);
}
table.list th, table.list td{text-align:left;padding:.7rem .95rem;border-bottom:1px solid var(--line);font-size:.92rem}
table.list th{
  background:var(--sand);font-family:var(--sans);font-size:.72rem;font-weight:600;
  text-transform:uppercase;letter-spacing:.05em;color:var(--muted);
}
table.list tr:last-child td{border-bottom:none}
table.list tbody tr:hover td{background:var(--cream)}

/* Messages */
.messages{list-style:none;padding:0}
.messages li{padding:.7rem 1rem;border-radius:var(--r-md);margin-bottom:.6rem;font-size:.91rem;border:1px solid transparent}
.messages li.success{background:var(--ok-bg);color:var(--ok);border-color:#cce7d4}
.messages li.error{background:var(--bad-bg);color:var(--bad);border-color:#f3d2cf}
.messages li.info, .messages li.warning{background:var(--warn-bg);color:var(--warn);border-color:#f0dcbb}

/* Dashboard stats */
.stat-row{display:flex;gap:1rem;flex-wrap:wrap;margin-bottom:1.5rem}
.stat{
  background:var(--paper);border:1px solid var(--line);border-radius:var(--r-lg);
  padding:1.1rem 1.4rem;min-width:160px;box-shadow:var(--sh-sm);
}
.stat .num{font-family:var(--sans);font-size:1.9rem;font-weight:700;color:var(--ink);line-height:1.1;letter-spacing:-.02em}
.stat .label{font-family:var(--sans);font-size:.72rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--muted)}

.piece-photo{width:72px;height:72px;object-fit:cover;border-radius:var(--r-md);border:1px solid var(--line)}
.filters{display:flex;gap:.8rem;align-items:end;flex-wrap:wrap;margin-bottom:1.2rem}
.filters label{font-size:.72rem;font-family:var(--sans);font-weight:600;color:var(--muted);display:block;text-transform:uppercase;letter-spacing:.04em}
.filters input, .filters select{max-width:14rem;padding:.45rem .6rem}

/* Wiki article body */
.wiki-content{font-size:1.02rem;line-height:1.75}
.wiki-content h1, .wiki-content h2, .wiki-content h3{color:var(--ink)}
.wiki-content table{border-collapse:collapse;margin:.8rem 0}
.wiki-content table td, .wiki-content table th{border:1px solid var(--line-2);padding:.45rem .85rem}
.wiki-content code{background:var(--sand);padding:.1rem .4rem;border-radius:5px;font-size:.9em}
.wiki-content blockquote{border-left:4px solid var(--accent-100);margin-left:0;padding-left:1rem;color:var(--ink-2)}

footer{
  text-align:center;color:var(--muted);padding:2.2rem;font-size:.85rem;
  border-top:1px solid var(--line);margin-top:3rem;
}
footer a{color:var(--accent-700)}

/* ===== Global polish ===== */
::selection{background:var(--accent-100);color:var(--ink)}
:focus-visible{outline:2px solid var(--accent);outline-offset:2px;border-radius:4px}
*::-webkit-scrollbar{width:11px;height:11px}
*::-webkit-scrollbar-thumb{background:var(--line-2);border-radius:999px;border:3px solid var(--cream)}
*::-webkit-scrollbar-thumb:hover{background:var(--muted)}
@media (prefers-reduced-motion:no-preference){
  .grid .card,.stat,.lp-tile,.cockpit,.lifecycle{animation:cs-rise .34s var(--ease) both}
}
@keyframes cs-rise{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:none}}

/* Auth screen (staff login) */
.auth-wrap{display:flex;justify-content:center;padding:3rem 1rem}
.auth-card{width:100%;max-width:24rem;background:var(--paper);border:1px solid var(--line);border-radius:var(--r-lg);box-shadow:var(--sh-md);padding:2.2rem 2rem}
.auth-mark{width:48px;height:48px;border-radius:12px;background:linear-gradient(150deg,var(--accent),var(--accent-700));color:#fff;display:flex;align-items:center;justify-content:center;font-family:var(--sans);font-weight:700;font-size:1.05rem;letter-spacing:.02em;margin:0 auto .9rem;box-shadow:var(--sh-sm)}
.auth-title{font-size:1.55rem;text-align:center;margin:0}
.auth-sub{text-align:center;color:var(--muted);margin:.2rem 0 1.4rem;font-size:.95rem}
.auth-err{background:var(--bad-bg);color:var(--bad);border:1px solid #f3d2cf;border-radius:var(--r-sm);padding:.6rem .8rem;margin-bottom:.9rem;font-size:.9rem}
.auth-card form.stacked input{max-width:none}
.auth-card form.stacked label{margin-top:.7rem}

/* Point of sale */
.pos-layout{display:grid;grid-template-columns:1fr 320px;gap:1.4rem;align-items:start}
.pos-products{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:.7rem}
.pos-item{display:flex;flex-direction:column;gap:.2rem;text-align:left;padding:.8rem .9rem;background:var(--paper);border:1px solid var(--line);border-radius:var(--r-md);cursor:pointer;transition:.14s var(--ease);font-family:inherit;color:var(--ink)}
.pos-item:hover:not(:disabled){border-color:var(--accent);box-shadow:var(--sh-md)}
.pos-item:disabled{opacity:.45;cursor:not-allowed}
.pos-item-name{font-weight:600;font-size:.93rem}
.pos-item-meta{font-size:.78rem;color:var(--muted)}
.pos-cart{position:sticky;top:84px}
.cart-line{display:grid;grid-template-columns:1fr auto auto;gap:.5rem;align-items:center;padding:.4rem 0;border-bottom:1px solid var(--line);font-size:.9rem}
.cl-controls{display:flex;align-items:center;gap:.4rem}
.cl-controls button{width:26px;height:26px;border-radius:var(--r-sm);border:1px solid var(--line-2);background:var(--sand);cursor:pointer;font-size:1rem;line-height:1}
.cl-controls button:hover{background:var(--line)}
.cl-qty{min-width:1.2rem;text-align:center}
.cl-amt{font-variant-numeric:tabular-nums;color:var(--ink-2)}
.pos-total{display:flex;justify-content:space-between;font-weight:700;font-size:1.15rem;margin:.9rem 0;font-family:var(--sans);color:var(--ink)}
@media(max-width:760px){.pos-layout{grid-template-columns:1fr}.pos-cart{position:static}}

/* Owner cockpit band */
.cockpit{background:var(--paper);border:1px solid var(--line);border-radius:var(--r-lg);padding:1.2rem 1.4rem;margin:1rem 0 1.6rem;box-shadow:var(--sh-sm)}
.cockpit-kpis{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:1rem}
.kpi-label{font-size:.72rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--muted)}
.kpi-num{font-family:var(--sans);font-size:1.65rem;font-weight:700;color:var(--ink);line-height:1.15;margin-top:.15rem;letter-spacing:-.02em}
.cockpit-bar{height:8px;border-radius:999px;background:var(--sand);overflow:hidden;margin:1.1rem 0 .2rem}
.cockpit-fill{height:100%;background:linear-gradient(90deg,var(--accent-600),var(--accent));border-radius:999px}
.cockpit-channels{margin-top:1rem;display:flex;flex-direction:column;gap:.5rem}
.cc-row{display:grid;grid-template-columns:150px 1fr auto;align-items:center;gap:.8rem;font-size:.9rem}
.cc-track{height:8px;border-radius:999px;background:var(--sand);overflow:hidden}
.cc-fill{height:100%;background:var(--accent);border-radius:999px}
.cc-amt{font-variant-numeric:tabular-nums;color:var(--ink-2)}
@media(max-width:600px){.cc-row{grid-template-columns:90px 1fr auto}}

/* Launchpad — dashboard navigation hub */
.launchpad{display:flex;flex-direction:column;gap:1.2rem;margin-bottom:2rem}
.lp-group .lp-label{font-size:.72rem;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--muted);margin:0 0 .55rem}
.lp-tiles{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:.7rem}
.lp-tile{
  display:flex;align-items:center;gap:.65rem;padding:.9rem 1rem;background:var(--paper);
  border:1px solid var(--line);border-radius:14px;color:var(--ink)!important;
  font-size:.91rem;font-weight:600;text-decoration:none;transition:transform .14s var(--ease),box-shadow .14s var(--ease),border-color .14s var(--ease);
}
.lp-tile:hover{box-shadow:var(--sh-md);border-color:var(--accent-100);transform:translateY(-2px)}
.lp-tile .lp-ic{font-size:1.2rem;line-height:1;flex:none}

/* Wiki / SOP — clean reading layout */
.wiki-crumb{font-size:.85rem;color:var(--muted);margin:0 0 1rem;display:flex;gap:.4rem;flex-wrap:wrap}
.wiki-crumb a{color:var(--accent-700);text-decoration:none}
.wiki-crumb span{color:var(--line-2)}
.wiki-layout{display:grid;grid-template-columns:minmax(0,1fr) 220px;gap:2.4rem;align-items:start}
.wiki-main{max-width:50rem}
.wiki-title{font-size:2.1rem;margin:0 0 .3rem;letter-spacing:-.025em}
.wiki-meta{margin:0 0 .8rem}
.wiki-actions{display:flex;gap:.4rem;flex-wrap:wrap;margin:0 0 1.4rem}
.wiki-content{font-size:1.03rem;line-height:1.75;color:var(--ink)}
.wiki-content h1,.wiki-content h2,.wiki-content h3{color:var(--ink);margin-top:1.8rem;font-family:var(--sans);font-weight:700;letter-spacing:-.02em}
.wiki-content h2{border-bottom:1px solid var(--line);padding-bottom:.3rem}
.wiki-content blockquote{border-left:4px solid var(--accent);background:var(--accent-50);border-radius:0 var(--r-sm) var(--r-sm) 0;margin:1rem 0;padding:.7rem 1rem;color:var(--ink-2)}
.wiki-content table{border-collapse:collapse;margin:1rem 0;width:100%}
.wiki-content th,.wiki-content td{border:1px solid var(--line-2);padding:.5rem .8rem;text-align:left}
.wiki-content th{background:var(--sand)}
.wiki-content code{background:var(--sand);padding:.1rem .4rem;border-radius:5px;font-size:.92em}
.wiki-outline{position:sticky;top:84px;font-size:.85rem;border-left:1px solid var(--line);padding-left:1rem}
.wiki-outline-label{font-size:.72rem;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:var(--muted);margin-bottom:.5rem}
.wiki-outline .toc>ul{list-style:none;margin:0;padding:0}
.wiki-outline .toc ul ul{padding-left:.8rem}
.wiki-outline .toc li{margin:.25rem 0}
.wiki-outline a{color:var(--ink-2);text-decoration:none;display:block}
.wiki-outline a:hover{color:var(--accent)}
@media (max-width:860px){ .wiki-layout{grid-template-columns:1fr} .wiki-outline{display:none} }

/* Global back / dashboard crumb bar (staff pages) */
.crumbbar{display:flex;gap:1.2rem;font-size:.85rem;margin:0 0 1.1rem}
.crumbbar a{color:var(--muted);font-weight:500;text-decoration:none}
.crumbbar a:hover{color:var(--accent)}

/* Product image lifecycle (sketch → retail) */
.lifecycle{display:flex;align-items:flex-start;gap:.4rem;flex-wrap:wrap;margin:.4rem 0 1.6rem}
.lc-stage{display:flex;flex-direction:column;align-items:center;gap:.45rem;width:120px}
.lc-thumb{width:110px;height:110px;border-radius:var(--r-md);border:1px solid var(--line);background:var(--sand);display:flex;align-items:center;justify-content:center;overflow:hidden}
.lc-thumb img{width:100%;height:100%;object-fit:cover}
.lc-empty{color:var(--muted);font-size:1.6rem}
.lc-label{font-size:.8rem;font-weight:600;color:var(--ink-2);text-align:center}
.lc-arrow{align-self:flex-start;color:var(--accent);font-size:1.3rem;padding-top:2.3rem}

/* ===== Responsive (mobile / tablet) ===== */
.nav-links{display:contents}
.nav-burger{display:none}
.nav-toggle{position:absolute;width:1px;height:1px;opacity:0;pointer-events:none}

@media (max-width:760px){
  nav.topbar{gap:.5rem 1rem;padding:.7rem 1.1rem}
  .nav-burger{display:inline-block;margin-left:auto;font-size:1.6rem;line-height:1;color:var(--ink-2);cursor:pointer;user-select:none}
  /* Menu pops up as a card anchored under the burger, on the right. */
  .nav-links{display:none;position:absolute;top:100%;right:1.1rem;flex-direction:column;
    align-items:stretch;gap:.1rem;min-width:200px;margin-top:.45rem;padding:.5rem;
    background:var(--paper);border:1px solid var(--line);border-radius:14px;box-shadow:var(--sh-md);z-index:60}
  #nav-toggle:checked ~ .nav-links{display:flex}
  .nav-links a{padding:.6rem .8rem;border-radius:9px}
  .nav-links a:hover{background:var(--sand)}
  .nav-links .spacer{display:none}

  main{padding:1.2rem 1rem 3rem}
  .hero{padding:2rem 1.3rem}
  .hero h1{font-size:1.8rem}
  .hero p{font-size:1.02rem}

  main [style*="grid-template-columns"]{grid-template-columns:1fr !important}
  table.list{display:block;overflow-x:auto;white-space:nowrap;-webkit-overflow-scrolling:touch}
  .stat{flex:1 1 calc(50% - .6rem);min-width:0;padding:.9rem 1rem}
  .stat .num{font-size:1.6rem}
  form.stacked input, form.stacked select, form.stacked textarea{max-width:100%}
}

@media (prefers-reduced-motion:reduce){
  *{transition:none !important; animation:none !important}
}

/* ===== Class gallery (public class detail) ===== */
.gallery{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:.6rem;margin:1rem 0 1.6rem}
.gallery img{width:100%;height:160px;object-fit:cover;border-radius:var(--r-md);box-shadow:var(--sh-sm);display:block}
.gallery .hero-shot{grid-column:1 / -1;height:340px}

/* ===== Booking calendar ===== */
.cal-wrap{display:flex;flex-wrap:wrap;gap:1.4rem;margin:1rem 0}
.cal{flex:1 1 18rem;min-width:17rem}
.cal h3{font-size:1rem;margin:0 0 .5rem}
.cal table{width:100%;border-collapse:collapse;table-layout:fixed}
.cal th{font-size:.7rem;color:var(--muted);font-weight:600;padding:.3rem 0;text-align:center}
.cal td{height:2.5rem;text-align:center;padding:0;border:1px solid var(--line)}
.cal td .num{font-size:.85rem;color:var(--ink-2)}
.cal td.out{background:var(--cream)}
.cal td.out .num{color:var(--line-2)}
.cal td.past .num{color:var(--line-2)}
.cal td.has a{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;
  text-decoration:none;background:var(--accent-50);color:var(--accent-700);font-weight:600}
.cal td.has a:hover{background:var(--accent-100)}
.cal td.has .dot{font-size:.6rem;line-height:1;margin-top:1px}
.cal td.today{outline:2px solid var(--accent);outline-offset:-2px}
.slot-day{border:1px solid var(--line);border-radius:var(--r-md);padding:.7rem .9rem;margin:.5rem 0;background:var(--paper)}
.slot-day h4{margin:0 0 .4rem;font-size:.95rem}
.slot-row{display:flex;align-items:center;gap:.6rem;flex-wrap:wrap;padding:.35rem 0;border-top:1px solid var(--line)}
.slot-row:first-of-type{border-top:0}
.slot-row .when{font-weight:600;min-width:7rem}

/* ===== Configurable dashboard board ===== */
.dash-top{display:flex;justify-content:space-between;align-items:flex-start;gap:1rem;flex-wrap:wrap}
.dash-tools{display:flex;gap:.4rem;align-items:center}
.dash-tools-bottom{justify-content:center;margin-top:1.4rem;padding-top:1.2rem;border-top:1px solid var(--line)}
.dash-hint{background:var(--accent-50);border:1px solid var(--accent-100);border-radius:var(--r-md);padding:.5rem .8rem}
.dash-wrap{margin-top:1rem;display:flex;flex-direction:column;gap:1.1rem}
/* labelled, collapsible group sections */
.dash-group{display:flex;flex-direction:column}
.dg-toggle{display:flex;align-items:center;gap:.55rem;width:100%;background:none;border:0;
  cursor:pointer;font:inherit;color:var(--ink);padding:.35rem .1rem;border-bottom:1px solid var(--line)}
.dg-caret{color:var(--muted);font-size:.9rem;transition:transform .15s ease;transform:rotate(90deg)}
.dash-group.collapsed .dg-caret{transform:rotate(0deg)}
.dg-label{font-weight:700;font-size:1.02rem;letter-spacing:.01em}
.dg-count{margin-left:auto;color:var(--muted);font-size:.78rem;background:var(--sand);
  border-radius:999px;padding:.05rem .5rem;min-width:1.4rem;text-align:center}
.dash-group .dash-board{margin-top:.9rem}
.dash-group.collapsed .dash-board{display:none}
/* while editing, every group is forced open so anything can be rearranged */
.dash-wrap.editing .dash-group.collapsed .dash-board{display:grid}
.dash-wrap.editing .dash-group.collapsed .dg-caret{transform:rotate(90deg)}

.dash-board{display:grid;grid-template-columns:repeat(2,1fr);gap:1.2rem;align-items:start}
.dash-widget{background:var(--paper);border:1px solid var(--line);border-radius:var(--r-lg);
  box-shadow:var(--sh-sm);padding:1rem 1.1rem;overflow:hidden}
.dash-widget.full{grid-column:1 / -1}
.dw-head{display:flex;align-items:center;gap:.5rem;margin:-.2rem 0 .6rem}
.dw-title{font-weight:700;font-size:1rem;flex:1}
.dw-drag{cursor:grab;color:var(--line-2);font-size:1.1rem;display:none}
.dw-remove{display:none;border:0;background:var(--sand);color:var(--ink-2);border-radius:6px;
  width:1.6rem;height:1.6rem;cursor:pointer;font-size:.9rem;line-height:1}
.dw-remove:hover{background:var(--bad-bg);color:var(--bad)}
.dw-lock{opacity:.5;font-size:.85rem}
/* normal mode: hidden widgets are gone */
.dash-wrap:not(.editing) .dash-widget.is-hidden{display:none}
/* edit mode */
.dash-wrap.editing .dash-widget{border-style:dashed;border-color:var(--line-2)}
.dash-wrap.editing .dw-drag{display:inline}
.dash-wrap.editing .dash-widget:not(.locked) .dw-remove{display:inline-flex;align-items:center;justify-content:center}
.dash-wrap.editing .dash-widget[draggable="true"]{cursor:grab}
.dash-wrap.editing .dash-widget.is-hidden{opacity:.45;cursor:pointer;outline:2px dashed var(--line-2)}
.dash-wrap.editing .dash-widget.is-hidden .dw-body{filter:grayscale(.6)}
.dash-widget.dragging{opacity:.6;box-shadow:var(--sh-md)}
@media (max-width:760px){.dash-board{grid-template-columns:1fr}.dash-widget.full{grid-column:auto}}

/* widgets reuse existing card internals; tidy nested cards */
.dash-widget .card{box-shadow:none;border:1px solid var(--line)}

/* ===== Dashboard widget settings (manager) ===== */
.dw-matrix{width:100%;border-collapse:collapse;font-size:.84rem}
.dw-matrix th,.dw-matrix td{border:1px solid var(--line);padding:.4rem .5rem;text-align:center}
.dw-matrix th.role{writing-mode:vertical-rl;transform:rotate(180deg);white-space:nowrap;font-size:.75rem}
.dw-matrix td.wname,.dw-matrix th.wname{text-align:left;white-space:nowrap;font-weight:600}
.dw-matrix .cellgrp{display:flex;flex-direction:column;gap:.15rem;align-items:center;font-size:.68rem;color:var(--muted)}

/* =====================================================================
   STOREFRONT — customer-facing theme (scoped to body.storefront so the
   admin/dashboard look is unaffected). Warm, handmade, coastal-clay.
   ===================================================================== */
body.storefront{
  /* Official Clay Studio palette (Graphics Standards Manual §06) */
  --sf-cream:#f4f5f0; --sf-paper:#ffffff; --sf-sand:#ece6dc;
  --sf-clay:#aa2c1c; --sf-clay-deep:#86200f;     /* PANTONE 2350 C — primary red */
  --sf-ink:#1d252d; --sf-ink-2:#4a525a;          /* PANTONE 433 C */
  --sf-tan:#dab38e; --sf-sky:#8bc6e8; --sf-yellow:#fcda64;  /* supplemental */
  --sf-line:#e2ddd3;
  background:var(--sf-cream); color:var(--sf-ink);
}
body.storefront main{max-width:1180px}
body.storefront h1,body.storefront h2,body.storefront h3{
  font-family:'Clay Studio',Georgia,serif; letter-spacing:-.01em; color:var(--sf-ink);
}

/* Header */
body.storefront nav.topbar{background:rgba(244,245,240,.9);backdrop-filter:saturate(140%) blur(8px);border-bottom:1px solid var(--sf-line)}
body.storefront nav.topbar a.brand{font-family:'Clay Studio',Georgia,serif;font-weight:600;font-size:1.3rem;color:var(--sf-ink)}
body.storefront nav.topbar a{color:var(--sf-ink-2)}
body.storefront nav.topbar a:hover{color:var(--sf-clay)}

/* Hero */
/* Flat brand colour (the manual says: no gradients). Type sits top-left. */
.sf-hero{position:relative;overflow:hidden;border-radius:22px;margin:1.2rem 0 2.6rem;
  background:var(--sf-tan);color:var(--sf-ink);
  border:1px solid var(--sf-line);padding:clamp(2.2rem,5vw,4.2rem);}
.sf-hero.has-img{background:var(--sf-ink);}
.sf-hero.has-img .sf-hero-bg{position:absolute;inset:0;object-fit:cover;width:100%;height:100%;opacity:.62}
.sf-hero-inner{position:relative;max-width:38rem}
.sf-hero.has-img .sf-hero-inner,.sf-hero.has-img .sf-hero-inner h1,.sf-hero.has-img .sf-eyebrow{color:#fff}
.sf-hero h1{font-size:clamp(2.1rem,4.8vw,3.5rem);line-height:1.04;margin:.4rem 0 .7rem;font-weight:400}
.sf-hero p{font-size:1.12rem;line-height:1.6;color:var(--sf-ink);opacity:.82;max-width:34rem;margin:0 0 1.4rem}
.sf-hero.has-img p{color:rgba(255,255,255,.92);opacity:1}
.sf-eyebrow{font-family:'Inter',sans-serif;text-transform:uppercase;letter-spacing:.18em;font-size:.72rem;font-weight:700;color:var(--sf-clay)}

/* Buttons (storefront) */
body.storefront .btn{background:var(--sf-clay);border-radius:999px;padding:.7rem 1.5rem;font-weight:600;box-shadow:0 6px 18px rgba(170,44,28,.22)}
body.storefront .btn:hover{background:var(--sf-clay-deep)}
body.storefront .btn.secondary{background:transparent;color:var(--sf-ink)!important;border:1.5px solid var(--sf-ink);box-shadow:none}
body.storefront .btn.secondary:hover{background:var(--sf-ink);color:#fff!important}
.sf-hero.has-img .btn.secondary{border-color:#fff;color:#fff!important}
.sf-hero.has-img .btn.secondary:hover{background:#fff;color:var(--sf-ink)!important}

/* Section heading */
.sf-section{margin:2.8rem 0}
.sf-section-head{display:flex;align-items:flex-end;justify-content:space-between;gap:1rem;margin-bottom:1.3rem;flex-wrap:wrap}
.sf-section-head h2{font-size:clamp(1.6rem,3vw,2.1rem);margin:.2rem 0 0;font-weight:600}
.sf-section-head .sf-link{font-family:'Inter',sans-serif;font-weight:600;color:var(--sf-clay);text-decoration:none;font-size:.95rem}
.sf-section-head .sf-link:hover{text-decoration:underline}

/* Card grid */
.sf-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(290px,1fr));gap:1.6rem}
.sf-card{background:#fff;border:1px solid var(--sf-line);border-radius:18px;overflow:hidden;
  display:flex;flex-direction:column;transition:transform .18s var(--ease),box-shadow .18s var(--ease)}
.sf-card:hover{transform:translateY(-4px);box-shadow:0 16px 36px rgba(42,33,27,.12)}
.sf-card-media{position:relative;aspect-ratio:4/3;overflow:hidden;background:var(--sf-sand)}
.sf-card-media img{width:100%;height:100%;object-fit:cover;transition:transform .4s var(--ease)}
.sf-card:hover .sf-card-media img{transform:scale(1.05)}
.sf-card-media .ph{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;font-size:3.4rem;opacity:.55}
.sf-card-media .tag{position:absolute;top:.7rem;left:.7rem;background:rgba(255,255,255,.92);color:var(--sf-ink);
  font-family:'Inter',sans-serif;font-size:.7rem;font-weight:700;letter-spacing:.04em;text-transform:uppercase;padding:.28rem .6rem;border-radius:999px}
.sf-card-media .tag.sold{background:var(--sf-ink);color:#fff}
.sf-card-body{padding:1.1rem 1.2rem 1.3rem;display:flex;flex-direction:column;gap:.5rem;flex:1}
.sf-card-body h3{margin:0;font-size:1.2rem;font-weight:600;line-height:1.2}
.sf-card-body h3 a{color:var(--sf-ink);text-decoration:none}
.sf-card-body h3 a:hover{color:var(--sf-clay)}
.sf-card-desc{color:var(--sf-ink-2);font-size:.93rem;line-height:1.55;margin:0}
.sf-meta{font-family:'Inter',sans-serif;font-size:.84rem;color:var(--sf-ink-2);display:flex;gap:.5rem;flex-wrap:wrap;align-items:center}
.sf-price{font-family:'Clay Studio',serif;font-weight:600;font-size:1.15rem;color:var(--sf-ink)}
.sf-card-foot{margin-top:auto;padding-top:.4rem;display:flex;align-items:center;justify-content:space-between;gap:.6rem}
.sf-chip{font-family:'Inter',sans-serif;font-size:.72rem;font-weight:600;background:var(--sf-sand);color:var(--sf-ink-2);padding:.2rem .6rem;border-radius:999px}

/* Filter pills */
.sf-pills{display:flex;gap:.5rem;flex-wrap:wrap;margin:0 0 1.8rem}
.sf-pill{font-family:'Inter',sans-serif;font-size:.86rem;font-weight:600;text-decoration:none;
  padding:.42rem .95rem;border-radius:999px;border:1.5px solid var(--sf-line);color:var(--sf-ink-2);background:#fff;transition:.15s}
.sf-pill:hover{border-color:var(--sf-clay);color:var(--sf-clay)}
.sf-pill.active{background:var(--sf-clay);border-color:var(--sf-clay);color:#fff}

/* "How it works" steps */
.sf-steps{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1.4rem}
.sf-step{background:#fff;border:1px solid var(--sf-line);border-radius:16px;padding:1.4rem}
.sf-step .n{font-family:'Clay Studio',serif;font-size:1.6rem;color:var(--sf-clay);font-weight:600}
.sf-step h3{margin:.3rem 0 .3rem;font-size:1.1rem}
.sf-step p{margin:0;color:var(--sf-ink-2);font-size:.92rem;line-height:1.55}

/* Closing CTA band — flat brand red, type left-aligned (manual: never centered) */
.sf-cta{margin:3rem 0 1rem;border-radius:22px;background:var(--sf-clay);
  color:#fff;padding:clamp(2rem,4vw,3rem);text-align:left}
.sf-cta h2{color:#fff;font-size:clamp(1.6rem,3vw,2.2rem);margin:0 0 .6rem;font-weight:400}
.sf-cta p{color:rgba(255,255,255,.9);max-width:34rem;margin:0 0 1.4rem}
.sf-cta .btn{background:#fff;color:var(--sf-clay)!important}
.sf-cta .btn:hover{background:var(--sf-cream)}

/* Storefront footer */
body.storefront footer{background:var(--sf-ink);color:rgba(255,255,255,.75);border:0;margin-top:3.5rem;padding:2.6rem 1.4rem}
body.storefront footer a{color:#fff}

@media (max-width:560px){.sf-grid{grid-template-columns:1fr}}

/* Brand logo in the header */
.brand-logo{height:26px;width:auto;display:block}
body.storefront nav.topbar .brand-logo{height:30px}
@media (max-width:560px){.brand-logo{height:23px}}

/* ===== Clay Studio brand typeface ===== */
@font-face{font-family:'Clay Studio';src:url('../fonts/ClayStudio-Light.ttf') format('truetype');font-weight:300;font-style:normal;font-display:swap}
@font-face{font-family:'Clay Studio';src:url('../fonts/ClayStudio-Book.ttf') format('truetype');font-weight:400;font-style:normal;font-display:swap}
@font-face{font-family:'Clay Studio';src:url('../fonts/ClayStudio-Medium.ttf') format('truetype');font-weight:500;font-style:normal;font-display:swap}
@font-face{font-family:'Clay Studio';src:url('../fonts/ClayStudio-SemiBold.ttf') format('truetype');font-weight:600;font-style:normal;font-display:swap}
@font-face{font-family:'Clay Studio';src:url('../fonts/ClayStudio-Bold.ttf') format('truetype');font-weight:700;font-style:normal;font-display:swap}

/* ===== Webshop — East Fork-inspired: products on solid colour tiles ===== */
.shop-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:2.4rem 1.6rem;margin-top:1.4rem}
.shop-card{display:flex;flex-direction:column;text-decoration:none}
.shop-tile{position:relative;aspect-ratio:1/1;border-radius:14px;overflow:hidden;display:flex;align-items:center;justify-content:center}
.shop-tile img{width:100%;height:100%;object-fit:cover;transition:transform .5s var(--ease)}
.shop-card:hover .shop-tile img{transform:scale(1.04)}
.shop-tile .ph{font-size:3.6rem;opacity:.5}
.shop-tile .flag{position:absolute;top:.7rem;left:.7rem;background:var(--sf-ink);color:#fff;font-family:'Inter',sans-serif;
  font-size:.66rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase;padding:.26rem .6rem;border-radius:999px}
/* rotating brand tones (manual supplementals) */
.tone-1{background:var(--sf-tan)} .tone-2{background:var(--sf-sky)} .tone-3{background:var(--sf-yellow)} .tone-4{background:var(--sf-sand)}
.shop-meta{padding:.9rem .15rem 0;display:flex;flex-direction:column;gap:.2rem}
.shop-name{font-family:'Clay Studio',Georgia,serif;font-size:1.18rem;font-weight:500;color:var(--sf-ink);line-height:1.2}
.shop-card:hover .shop-name{color:var(--sf-clay)}
.shop-price{font-family:'Inter',sans-serif;color:var(--sf-ink-2);font-size:.98rem}

/* Product detail (PDP) */
.pdp{display:grid;grid-template-columns:1.05fr 1fr;gap:2.6rem;align-items:start;margin-top:1rem}
.pdp-media{aspect-ratio:1/1;border-radius:18px;overflow:hidden;display:flex;align-items:center;justify-content:center}
.pdp-media img{width:100%;height:100%;object-fit:cover}
.pdp-media .ph{font-size:5rem;opacity:.5}
.pdp h1{font-size:clamp(1.9rem,3.5vw,2.6rem);font-weight:400;margin:.2rem 0 .5rem}
.pdp .pdp-price{font-family:'Clay Studio',serif;font-size:1.5rem;color:var(--sf-ink);margin:0 0 1rem}
.pdp .pdp-desc{color:var(--sf-ink-2);line-height:1.65;font-size:1rem}
.pdp .pdp-labels{display:flex;gap:.5rem;flex-wrap:wrap;margin:.4rem 0 1rem}
.pdp .pdp-labels .sf-chip{background:var(--sf-sand)}
.story{margin:3rem 0 0;background:var(--sf-sand);border-radius:18px;padding:1.6rem 1.8rem}
.story h3{margin:0 0 .5rem;font-weight:500}
.story p{margin:0;color:var(--sf-ink-2);line-height:1.65}
@media (max-width:680px){.pdp{grid-template-columns:1fr;gap:1.4rem}}

/* Currency toggle (MVR/USD) in the header */
.cur-toggle{display:inline-flex;border:1px solid var(--line-2);border-radius:999px;overflow:hidden;font-size:.74rem;font-weight:600}
.cur-toggle a{padding:.18rem .55rem;color:var(--ink-2);text-decoration:none;line-height:1.5}
.cur-toggle a.on{background:var(--accent);color:#fff!important}
body.storefront .cur-toggle{border-color:var(--sf-line)}
body.storefront .cur-toggle a.on{background:var(--sf-clay);color:#fff!important}

/* PDP image gallery thumbnails */
.pdp-thumbs{display:flex;gap:.5rem;margin-top:.6rem;flex-wrap:wrap}
.pdp-thumb{border:1px solid var(--sf-line,#e2ddd3);background:#fff;border-radius:10px;padding:0;width:64px;height:64px;overflow:hidden;cursor:pointer}
.pdp-thumb img{width:100%;height:100%;object-fit:cover}
.pdp-thumb:hover{border-color:var(--sf-clay,#aa2c1c)}

/* ===== Mobile polish ===== */
/* Sticky bottom action bar — phones only */
.mobile-bar{display:none}
@media (max-width:760px){
  .mobile-bar{
    position:fixed;left:0;right:0;bottom:0;z-index:60;display:flex;align-items:center;
    justify-content:space-between;gap:.8rem;padding:.6rem 1rem;background:rgba(255,255,255,.97);
    backdrop-filter:saturate(160%) blur(8px);border-top:1px solid var(--sf-line,var(--line));
    box-shadow:0 -4px 16px rgba(0,0,0,.08)}
  body.storefront{padding-bottom:4.5rem}  /* room for the bar */
  .mobile-bar .mb-price{font-family:'Clay Studio',Georgia,serif;font-weight:600;font-size:1.15rem;color:var(--sf-ink)}
  .mobile-bar .mb-price small{font-family:'Inter',sans-serif;font-weight:500;color:var(--sf-ink-2);font-size:.8rem}
  .mobile-bar .btn{flex:1;text-align:center;max-width:60%}
}
/* Touch-friendly sizing on phones */
@media (max-width:760px){
  body.storefront main{padding:1.1rem 1rem 3rem}
  .sf-hero{padding:1.6rem 1.3rem;border-radius:16px}
  .sf-hero h1{font-size:clamp(1.8rem,7vw,2.4rem)}
  .sf-hero p{font-size:1rem}
  .sf-hero .btn,.sf-cta .btn{display:block;width:100%;margin:.4rem 0 0!important;text-align:center}
  .sf-pill{padding:.55rem 1rem}                 /* ≥44px tap target */
  nav.topbar{gap:.6rem;padding:.6rem 1rem}
  nav.topbar .nav-links a{padding:.5rem 0;font-size:1rem}
  .sf-section{margin:2rem 0}
  .sf-section-head h2{font-size:clamp(1.5rem,6vw,1.9rem)}
  .btn{padding:.65rem 1.2rem}                   /* easier to tap */
  .cur-toggle a{padding:.35rem .7rem}
  table.list{display:block;overflow-x:auto}     /* wide tables scroll, not overflow */
}

/* Clickable rows + bulk-action toolbar */
tr[data-href]{cursor:pointer}
.bulk-bar{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap;margin:.8rem 0;padding:.6rem .8rem;
  background:var(--sand);border-radius:var(--r-md);font-size:.9rem}
.bulk-bar select{padding:.35rem .5rem;border:1px solid var(--line-2);border-radius:var(--r-sm);background:var(--paper)}

/* ===== Home — Claude.com-inspired: warm, calm, big type, soft panels ===== */
.cl-hero{max-width:60rem;padding:clamp(2.4rem,7vw,5.5rem) 0 clamp(1.6rem,3vw,2.6rem)}
.cl-hero h1{font-family:'Clay Studio',Georgia,serif;font-weight:600;
  font-size:clamp(2.7rem,6.6vw,4.6rem);line-height:1.02;letter-spacing:-.02em;color:var(--sf-ink);margin:.6rem 0 1.1rem}
.cl-hero p{font-size:clamp(1.1rem,2.1vw,1.45rem);line-height:1.5;color:var(--sf-ink-2);max-width:40rem;margin:0 0 1.9rem}
.cl-actions .btn{font-size:1.05rem;padding:.85rem 1.8rem}
.cl-actions .btn+.btn{margin-left:.6rem}
.cl-herofig{margin:2.4rem 0 0;border-radius:26px;overflow:hidden;aspect-ratio:16/8}
.cl-herofig img{width:100%;height:100%;object-fit:cover}

/* Big rounded pastel panels (the signature Claude.com move) */
.cl-panels{display:grid;grid-template-columns:repeat(3,1fr);gap:1.2rem;margin:.6rem 0 3.2rem}
.cl-panel{border-radius:24px;padding:2rem 1.8rem 1.8rem;min-height:248px;display:flex;flex-direction:column;
  justify-content:flex-end;text-decoration:none;color:var(--sf-ink);transition:transform .18s var(--ease),box-shadow .18s var(--ease)}
.cl-panel:hover{transform:translateY(-5px);box-shadow:0 18px 40px rgba(42,33,27,.14)}
.cl-panel .lbl{font-family:'Inter',sans-serif;text-transform:uppercase;letter-spacing:.14em;font-size:.72rem;font-weight:700;opacity:.7}
.cl-panel h3{font-family:'Clay Studio',serif;font-weight:600;font-size:1.7rem;margin:.35rem 0 .4rem;line-height:1.1}
.cl-panel p{margin:0;font-size:1rem;line-height:1.45;color:var(--sf-ink-2)}
.cl-panel .go{margin-top:.9rem;font-family:'Inter',sans-serif;font-weight:600;color:var(--sf-clay)}
.cl-panel.p1{background:#ecd9c4} .cl-panel.p2{background:#d6e7f1} .cl-panel.p3{background:#f6e7bf}

.cl-section{margin:3.4rem 0}
.cl-section-h{font-family:'Clay Studio',serif;font-weight:600;font-size:clamp(1.7rem,4vw,2.5rem);margin:0 0 1.3rem}

/* How-it-works as a soft cream panel */
.cl-how{background:#fff;border:1px solid var(--sf-line);border-radius:24px;padding:clamp(1.6rem,3vw,2.6rem)}

/* Big closing CTA */
.cl-cta{border-radius:28px;background:var(--sf-ink);color:#fff;padding:clamp(2.4rem,5vw,3.8rem);margin:3rem 0 1rem}
.cl-cta h2{font-family:'Clay Studio',serif;color:#fff;font-weight:600;font-size:clamp(1.8rem,4vw,2.6rem);margin:0 0 .6rem}
.cl-cta p{color:rgba(255,255,255,.86);max-width:36rem;margin:0 0 1.4rem;font-size:1.08rem}
.cl-cta .btn{background:#fff;color:var(--sf-ink)!important}
.cl-cta .btn:hover{background:var(--sf-cream)}

@media(max-width:780px){
  .cl-panels{grid-template-columns:1fr}
  .cl-actions .btn{display:block;width:100%;margin:.5rem 0 0}
  .cl-actions .btn+.btn{margin-left:0}
}

/* ===== Booking & checkout polish ===== */
.cl-formwrap{max-width:44rem;margin:0 auto}
.cl-formwrap .cl-hero{padding:clamp(1.6rem,5vw,2.6rem) 0 1rem}
.sf-panel{background:#fff;border:1px solid var(--sf-line);border-radius:20px;padding:clamp(1.3rem,3vw,1.9rem);margin-bottom:1.2rem}
.sf-panel h2,.sf-panel h3{font-family:'Clay Studio',Georgia,serif;font-weight:600}
.sf-summary{width:100%;border-collapse:collapse;margin:.2rem 0}
.sf-summary td{padding:.55rem 0;border-bottom:1px solid var(--sf-line);color:var(--sf-ink-2)}
.sf-summary td:last-child{text-align:right;color:var(--sf-ink)}
.sf-summary tr:last-child td{border-bottom:0;font-weight:700;color:var(--sf-ink);font-size:1.05rem}
.pay-opt{display:block;border:1.5px solid var(--sf-line);border-radius:14px;padding:.85rem 1rem;margin:.5rem 0;cursor:pointer;transition:.15s var(--ease);font-weight:400}
.pay-opt:hover{border-color:var(--sf-clay);background:var(--sf-cream)}
.pay-opt input{margin-right:.55rem}
.discount-row{display:flex;gap:.5rem;margin:.4rem 0 0}
.discount-row input{max-width:14rem}

/* Page-level currency toggle (storefront only — sits by the listings, not in the nav) */
/* Small inline "Prices in [MVR|USD]" row above priced grids. */
.cur-inline{display:flex;justify-content:flex-end;align-items:center;gap:.4rem;
  margin:.2rem 0 .8rem;font-size:.78rem;color:var(--sf-ink-2)}
.pdp-price .cur-toggle,.badge + .cur-toggle{vertical-align:middle;margin-left:.5rem}

/* Dashboard 'reset to default' — subtle text link, only shown while customizing */
.dash-reset-link{background:none;border:0;color:var(--muted);text-decoration:underline;
  cursor:pointer;font:inherit;font-size:.85rem;padding:.3rem .2rem;margin-left:.4rem}
.dash-reset-link:hover{color:var(--accent)}

/* Image cropper (upload screens) */
.crop-wrap{margin:.5rem 0}
.crop-view{position:relative;width:100%;max-width:360px;aspect-ratio:4/3;overflow:hidden;
  border:1px solid var(--line);border-radius:8px;background:var(--sand);cursor:move;touch-action:none}
.crop-img{position:absolute;top:0;left:0;width:100%;transform-origin:top left;user-select:none;-webkit-user-drag:none}
.crop-ctrls{display:flex;gap:.6rem;align-items:center;flex-wrap:wrap;margin-top:.4rem}
