/* =============================================
   WhiteWatermelon Shop — app.css
   DaisyUI Cherax theme + custom utilities
   ============================================= */

/* 1. TAILWIND CSS VARIABLE INIT
   ============================================= */
*,:before,:after{--tw-border-spacing-x:0;--tw-border-spacing-y:0;--tw-translate-x:0;--tw-translate-y:0;--tw-rotate:0;--tw-skew-x:0;--tw-skew-y:0;--tw-scale-x:1;--tw-scale-y:1;--tw-scroll-snap-strictness:proximity;--tw-ring-offset-width:0px;--tw-ring-offset-color:#fff;--tw-ring-color:rgb(59 130 246/.5);--tw-ring-offset-shadow:0 0 #0000;--tw-ring-shadow:0 0 #0000;--tw-shadow:0 0 #0000;--tw-shadow-colored:0 0 #0000}
::backdrop{--tw-border-spacing-x:0;--tw-border-spacing-y:0;--tw-translate-x:0;--tw-translate-y:0;--tw-rotate:0;--tw-skew-x:0;--tw-skew-y:0;--tw-scale-x:1;--tw-scale-y:1;--tw-ring-offset-width:0px;--tw-ring-offset-color:#fff;--tw-ring-color:rgb(59 130 246/.5);--tw-ring-offset-shadow:0 0 #0000;--tw-ring-shadow:0 0 #0000;--tw-shadow:0 0 #0000;--tw-shadow-colored:0 0 #0000}

/* 2. TAILWIND BASE RESET
   ============================================= */
*,:before,:after{box-sizing:border-box;border-width:0;border-style:solid;border-color:#e5e7eb}
:before,:after{--tw-content:""}
html,:host{line-height:1.5;-webkit-text-size-adjust:100%;tab-size:4;font-family:ui-sans-serif,system-ui,sans-serif,"Apple Color Emoji","Segoe UI Emoji","Segoe UI Symbol","Noto Color Emoji";font-feature-settings:normal;font-variation-settings:normal;-webkit-tap-highlight-color:transparent}
body{margin:0;line-height:inherit}
hr{height:0;color:inherit;border-top-width:1px}
h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}
a{color:inherit;text-decoration:inherit}
b,strong{font-weight:bolder}
code,kbd,samp,pre{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,"Liberation Mono","Courier New",monospace;font-size:1em}
small{font-size:80%}
sub,sup{font-size:75%;line-height:0;position:relative;vertical-align:baseline}
sub{bottom:-.25em}
sup{top:-.5em}
table{text-indent:0;border-color:inherit;border-collapse:collapse}
button,input,optgroup,select,textarea{font-family:inherit;font-size:100%;font-weight:inherit;line-height:inherit;letter-spacing:inherit;color:inherit;margin:0;padding:0}
button,select{text-transform:none}
button,input:where([type=button]),input:where([type=reset]),input:where([type=submit]){-webkit-appearance:button;background-color:transparent;background-image:none}
:-moz-focusring{outline:auto}
:-moz-ui-invalid{box-shadow:none}
progress{vertical-align:baseline}
::-webkit-inner-spin-button,::-webkit-outer-spin-button{height:auto}
[type=search]{-webkit-appearance:textfield;outline-offset:-2px}
::-webkit-search-decoration{-webkit-appearance:none}
::-webkit-file-upload-button{-webkit-appearance:button;font:inherit}
summary{display:list-item}
blockquote,dl,dd,h1,h2,h3,h4,h5,h6,hr,figure,p,pre{margin:0}
fieldset{margin:0;padding:0}
legend{padding:0}
ol,ul,menu{list-style:none;margin:0;padding:0}
dialog{padding:0}
textarea{resize:vertical}
input::-moz-placeholder,textarea::-moz-placeholder{opacity:1;color:#9ca3af}
input::placeholder,textarea::placeholder{opacity:1;color:#9ca3af}
button,[role=button]{cursor:pointer}
:disabled{cursor:default}
img,svg,video,canvas,audio,iframe,embed,object{display:block;vertical-align:middle}
img,video{max-width:100%;height:auto}
[hidden]:where(:not([hidden=until-found])){display:none}

/* 3. DAISY UI FALLBACKS & THEME BASE
   ============================================= */
:root,[data-theme]{background-color:var(--fallback-b1,oklch(var(--b1)/1));color:var(--fallback-bc,oklch(var(--bc)/1))}

@supports not (color:oklch(0% 0 0)){
  :root{color-scheme:light;--fallback-p:#491eff;--fallback-pc:#d4dbff;--fallback-s:#ff41c7;--fallback-sc:#fff9fc;--fallback-a:#00cfbd;--fallback-ac:#00100d;--fallback-n:#2b3440;--fallback-nc:#d7dde4;--fallback-b1:#ffffff;--fallback-b2:#e5e6e6;--fallback-b3:#e5e6e6;--fallback-bc:#1f2937;--fallback-in:#00b3f0;--fallback-inc:#000000;--fallback-su:#00ca92;--fallback-suc:#000000;--fallback-wa:#ffc22d;--fallback-wac:#000000;--fallback-er:#ff6f70;--fallback-erc:#000000}
  @media(prefers-color-scheme:dark){:root{color-scheme:dark;--fallback-p:#7582ff;--fallback-pc:#050617;--fallback-s:#ff71cf;--fallback-sc:#190211;--fallback-a:#00c7b5;--fallback-ac:#000e0c;--fallback-n:#2a323c;--fallback-nc:#a6adbb;--fallback-b1:#1d232a;--fallback-b2:#191e24;--fallback-b3:#15191e;--fallback-bc:#a6adbb;--fallback-in:#00b3f0;--fallback-inc:#000;--fallback-su:#00ca92;--fallback-suc:#000;--fallback-wa:#ffc22d;--fallback-wac:#000;--fallback-er:#ff6f70;--fallback-erc:#000}}
}

/* 4. CHERAX THEMES
   ============================================= */
:root,[data-theme=cherax]{
  --p:63.7% .237 293.4;--pc:100% 0 0;
  --s:58.7% .225 284.5;--sc:100% 0 0;
  --a:73.7% .178 294.9;--ac:100% 0 0;
  --n:15% 0 0;--nc:90% 0 0;
  --b1:0% 0 0;--b2:12% 0 0;--b3:18% 0 0;--bc:90% 0 0;
  --in:60% .19 255;--inc:100% 0 0;
  --su:65% .2 145;--suc:100% 0 0;
  --wa:80% .18 85;--wac:0% 0 0;
  --er:60% .22 25;--erc:100% 0 0;
  --rounded-box:1rem;--rounded-btn:.5rem;--rounded-badge:1.9rem;
  --animation-btn:.25s;--animation-input:.2s;
  --btn-focus-scale:.95;--border-btn:1px;--tab-border:1px;--tab-radius:.5rem
}


/* 5. BASE STYLES
   ============================================= */
html{scroll-behavior:smooth;-webkit-tap-highlight-color:transparent}
*{scrollbar-color:color-mix(in oklch,currentColor 35%,transparent) transparent}
*:hover{scrollbar-color:color-mix(in oklch,currentColor 60%,transparent) transparent}

body{
  --tw-bg-opacity:1;
  background-color:var(--fallback-b1,oklch(var(--b1)/var(--tw-bg-opacity,1)));
  --tw-text-opacity:1;
  color:var(--fallback-bc,oklch(var(--bc)/var(--tw-text-opacity,1)));
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
  background-image:radial-gradient(ellipse at top left,oklch(var(--p)/.08) 0%,transparent 50%),radial-gradient(ellipse at bottom right,oklch(var(--s)/.06) 0%,transparent 50%);
  background-attachment:fixed;
  min-height:100vh
}

/* Force LTR for inputs */
input,textarea,[contenteditable],[contenteditable=true]{direction:ltr!important;unicode-bidi:plaintext!important;text-align:left!important}

/* Scrollbar */
::-webkit-scrollbar{width:8px;height:8px}
::-webkit-scrollbar-track{background:oklch(var(--b2));border-radius:4px}
::-webkit-scrollbar-thumb{background:oklch(var(--p));border-radius:4px;border:2px solid transparent;background-clip:content-box;transition:background .2s ease;opacity:.7}
::-webkit-scrollbar-thumb:hover{opacity:1}
::-webkit-scrollbar-corner{background:oklch(var(--b2))}
.scrollbar-none{scrollbar-width:none}
.scrollbar-none::-webkit-scrollbar{display:none}

/* 6. DAISY UI COMPONENTS
   ============================================= */

/* ---- btn ---- */
.btn{display:inline-flex;height:3rem;min-height:3rem;flex-shrink:0;cursor:pointer;user-select:none;flex-wrap:wrap;align-items:center;justify-content:center;border-radius:var(--rounded-btn,.5rem);border-color:transparent;border-color:oklch(var(--btn-color,var(--b2))/var(--tw-border-opacity));padding-left:1rem;padding-right:1rem;text-align:center;font-size:.875rem;line-height:1em;gap:.5rem;font-weight:600;text-decoration-line:none;transition-duration:.2s;transition-timing-function:cubic-bezier(0,0,.2,1);border-width:var(--border-btn,1px);transition-property:color,background-color,border-color,opacity,box-shadow,transform;--tw-text-opacity:1;color:var(--fallback-bc,oklch(var(--bc)/var(--tw-text-opacity)));--tw-shadow:0 1px 2px 0 rgb(0 0 0/.05);box-shadow:var(--tw-ring-offset-shadow,0 0 #0000),var(--tw-ring-shadow,0 0 #0000),var(--tw-shadow);outline-color:var(--fallback-bc,oklch(var(--bc)/1));background-color:oklch(var(--btn-color,var(--b2))/var(--tw-bg-opacity));--tw-bg-opacity:1;--tw-border-opacity:1}
.btn-disabled,.btn[disabled],.btn:disabled{pointer-events:none}
.btn-square{height:3rem;width:3rem;padding:0}
.btn-circle{height:3rem;width:3rem;border-radius:9999px;padding:0}
.btn-xs{height:1.5rem;min-height:1.5rem;padding-left:.5rem;padding-right:.5rem;font-size:.75rem}
.btn-sm{height:2rem;min-height:2rem;padding-left:.75rem;padding-right:.75rem;font-size:.875rem}
.btn-lg{height:4rem;min-height:4rem;padding-left:1.5rem;padding-right:1.5rem;font-size:1.125rem}
.btn-xl{height:4.5rem;min-height:4.5rem;padding-left:2rem;padding-right:2rem;font-size:1.25rem}
.btn-primary{--btn-color:var(--p);--tw-text-opacity:1;color:var(--fallback-pc,oklch(var(--pc)/var(--tw-text-opacity)));outline-color:var(--fallback-p,oklch(var(--p)/1))}
.btn-secondary{--btn-color:var(--s);--tw-text-opacity:1;color:var(--fallback-sc,oklch(var(--sc)/var(--tw-text-opacity)));outline-color:var(--fallback-s,oklch(var(--s)/1))}
.btn-accent{--btn-color:var(--a);--tw-text-opacity:1;color:var(--fallback-ac,oklch(var(--ac)/var(--tw-text-opacity)));outline-color:var(--fallback-a,oklch(var(--a)/1))}
.btn-ghost{border-color:transparent;background-color:transparent;--tw-shadow:none;box-shadow:var(--tw-ring-offset-shadow,0 0 #0000),var(--tw-ring-shadow,0 0 #0000),var(--tw-shadow);outline-color:currentColor}
.btn-outline{border-color:currentColor;background-color:transparent;--tw-shadow:none;box-shadow:var(--tw-ring-offset-shadow,0 0 #0000),var(--tw-ring-shadow,0 0 #0000),var(--tw-shadow)}
.btn-outline.btn-primary{--tw-text-opacity:1;color:var(--fallback-p,oklch(var(--p)/var(--tw-text-opacity)))}
.btn-outline.btn-secondary{--tw-text-opacity:1;color:var(--fallback-s,oklch(var(--s)/var(--tw-text-opacity)))}
.btn-outline.btn-accent{--tw-text-opacity:1;color:var(--fallback-a,oklch(var(--a)/var(--tw-text-opacity)))}
.btn-success{--btn-color:var(--su);--tw-text-opacity:1;color:var(--fallback-suc,oklch(var(--suc)/var(--tw-text-opacity)))}
.btn-error{--btn-color:var(--er);--tw-text-opacity:1;color:var(--fallback-erc,oklch(var(--erc)/var(--tw-text-opacity)))}
.btn-warning{--btn-color:var(--wa);--tw-text-opacity:1;color:var(--fallback-wac,oklch(var(--wac)/var(--tw-text-opacity)))}
.btn-info{--btn-color:var(--in);--tw-text-opacity:1;color:var(--fallback-inc,oklch(var(--inc)/var(--tw-text-opacity)))}
@media(hover:hover){
  .btn:hover{--tw-border-opacity:1;border-color:var(--fallback-b3,oklch(var(--b3)/var(--tw-border-opacity)));--tw-bg-opacity:1;background-color:var(--fallback-b3,oklch(var(--b3)/var(--tw-bg-opacity)))}
  @supports(color:color-mix(in oklab,black,black)){.btn:hover{background-color:color-mix(in oklab,oklch(var(--btn-color,var(--b2))/var(--tw-bg-opacity,1)) 90%,black);border-color:color-mix(in oklab,oklch(var(--btn-color,var(--b2))/var(--tw-border-opacity,1)) 90%,black)}}
  .btn-ghost:hover{border-color:transparent;background-color:var(--fallback-bc,oklch(var(--bc)/.2))}
  .btn-outline:hover{--tw-border-opacity:1;border-color:var(--fallback-bc,oklch(var(--bc)/var(--tw-border-opacity)));--tw-bg-opacity:1;background-color:var(--fallback-bc,oklch(var(--bc)/var(--tw-bg-opacity)));--tw-text-opacity:1;color:var(--fallback-b1,oklch(var(--b1)/var(--tw-text-opacity)))}
  .btn-outline.btn-primary:hover{--tw-text-opacity:1;color:var(--fallback-pc,oklch(var(--pc)/var(--tw-text-opacity)))}
  @supports(color:color-mix(in oklab,black,black)){.btn-outline.btn-primary:hover{background-color:color-mix(in oklab,var(--fallback-p,oklch(var(--p)/1)) 90%,black);border-color:color-mix(in oklab,var(--fallback-p,oklch(var(--p)/1)) 90%,black)}}
  .btn-disabled:hover,.btn[disabled]:hover,.btn:disabled:hover{--tw-border-opacity:0;background-color:var(--fallback-n,oklch(var(--n)/var(--tw-bg-opacity)));--tw-bg-opacity:.2;color:var(--fallback-bc,oklch(var(--bc)/var(--tw-text-opacity)));--tw-text-opacity:.2}
}
.btn:focus-visible{outline:2px solid;outline-offset:2px}
.btn:active:hover,.btn:active:focus{transform:scale(var(--btn-focus-scale,.95));animation:ease-out button-pop}
@keyframes button-pop{0%{transform:scale(var(--btn-focus-scale,.95))}40%{transform:scale(1.02)}100%{transform:scale(1)}}
.btn-disabled,.btn[disabled],.btn:disabled{--tw-border-opacity:0;background-color:var(--fallback-n,oklch(var(--n)/var(--tw-bg-opacity)));--tw-bg-opacity:.2;color:var(--fallback-bc,oklch(var(--bc)/var(--tw-text-opacity)));--tw-text-opacity:.2}

/* ---- badge ---- */
.badge{display:inline-flex;align-items:center;justify-content:center;transition-property:color,background-color,border-color,text-decoration-color,fill,stroke,opacity,box-shadow,transform,filter,backdrop-filter;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.2s;height:1.25rem;font-size:.875rem;line-height:1.25rem;width:fit-content;padding-left:.563rem;padding-right:.563rem;border-radius:var(--rounded-badge,1.9rem);border-width:1px;--tw-border-opacity:1;border-color:var(--fallback-b2,oklch(var(--b2)/var(--tw-border-opacity)));--tw-bg-opacity:1;background-color:var(--fallback-b1,oklch(var(--b1)/var(--tw-bg-opacity)));--tw-text-opacity:1;color:var(--fallback-bc,oklch(var(--bc)/var(--tw-text-opacity)))}
.badge-primary{--tw-border-opacity:1;border-color:var(--fallback-p,oklch(var(--p)/var(--tw-border-opacity)));--tw-bg-opacity:1;background-color:var(--fallback-p,oklch(var(--p)/var(--tw-bg-opacity)));--tw-text-opacity:1;color:var(--fallback-pc,oklch(var(--pc)/var(--tw-text-opacity)))}
.badge-secondary{--tw-border-opacity:1;border-color:var(--fallback-s,oklch(var(--s)/var(--tw-border-opacity)));--tw-bg-opacity:1;background-color:var(--fallback-s,oklch(var(--s)/var(--tw-bg-opacity)));--tw-text-opacity:1;color:var(--fallback-sc,oklch(var(--sc)/var(--tw-text-opacity)))}
.badge-success{--tw-border-opacity:1;border-color:var(--fallback-su,oklch(var(--su)/var(--tw-border-opacity)));--tw-bg-opacity:1;background-color:var(--fallback-su,oklch(var(--su)/var(--tw-bg-opacity)));--tw-text-opacity:1;color:var(--fallback-suc,oklch(var(--suc)/var(--tw-text-opacity)))}
.badge-error{--tw-border-opacity:1;border-color:var(--fallback-er,oklch(var(--er)/var(--tw-border-opacity)));--tw-bg-opacity:1;background-color:var(--fallback-er,oklch(var(--er)/var(--tw-bg-opacity)));--tw-text-opacity:1;color:var(--fallback-erc,oklch(var(--erc)/var(--tw-text-opacity)))}
.badge-warning{--tw-border-opacity:1;border-color:var(--fallback-wa,oklch(var(--wa)/var(--tw-border-opacity)));--tw-bg-opacity:1;background-color:var(--fallback-wa,oklch(var(--wa)/var(--tw-bg-opacity)));--tw-text-opacity:1;color:var(--fallback-wac,oklch(var(--wac)/var(--tw-text-opacity)))}
.badge-info{--tw-border-opacity:1;border-color:var(--fallback-in,oklch(var(--in)/var(--tw-border-opacity)));--tw-bg-opacity:1;background-color:var(--fallback-in,oklch(var(--in)/var(--tw-bg-opacity)));--tw-text-opacity:1;color:var(--fallback-inc,oklch(var(--inc)/var(--tw-text-opacity)))}
.badge-ghost{--tw-border-opacity:1;border-color:var(--fallback-b2,oklch(var(--b2)/var(--tw-border-opacity)));--tw-bg-opacity:1;background-color:var(--fallback-b2,oklch(var(--b2)/var(--tw-bg-opacity)));--tw-text-opacity:1;color:var(--fallback-bc,oklch(var(--bc)/var(--tw-text-opacity)))}
.badge-outline{--tw-bg-opacity:0;background-color:transparent}
.badge-outline.badge-primary{--tw-text-opacity:1;color:var(--fallback-p,oklch(var(--p)/var(--tw-text-opacity)));border-color:var(--fallback-p,oklch(var(--p)/.5))}
.badge-sm{height:1rem;font-size:.75rem;padding-left:.438rem;padding-right:.438rem}
.badge-lg{height:1.5rem;font-size:1rem;padding-left:.688rem;padding-right:.688rem}

/* ---- card ---- */
.card{position:relative;display:flex;flex-direction:column;border-radius:var(--rounded-box,1rem)}
.card:focus{outline:2px solid transparent;outline-offset:2px}
.card-body{display:flex;flex:1 1 auto;flex-direction:column;padding:var(--padding-card,2rem);gap:.5rem}
.card-body :where(p){flex-grow:1}
.card figure{display:flex;align-items:center;justify-content:center}
.card-title{display:flex;align-items:center;gap:.5rem;font-size:1.25rem;font-weight:600}
.card-actions{display:flex;flex-wrap:wrap;align-items:center;gap:.5rem}
.card.image-full{display:grid}
.card.image-full:before{position:relative;content:"";z-index:10;border-radius:var(--rounded-box,1rem);--tw-bg-opacity:1;background-color:var(--fallback-n,oklch(var(--n)/var(--tw-bg-opacity)));opacity:.75}
.card.image-full:before,.card.image-full>*{grid-column-start:1;grid-row-start:1}
.card.image-full>figure img{height:100%;object-fit:cover}
.card.image-full>.card-body{position:relative;z-index:20;--tw-text-opacity:1;color:var(--fallback-nc,oklch(var(--nc)/var(--tw-text-opacity)))}
.card-compact .card-body{padding:1rem}

/* ---- input ---- */
.input{flex-shrink:1;-webkit-appearance:none;appearance:none;height:3rem;padding-left:1rem;padding-right:1rem;font-size:1rem;line-height:1.5rem;border-radius:var(--rounded-btn,.5rem);border-width:1px;border-color:transparent;--tw-bg-opacity:1;background-color:var(--fallback-b1,oklch(var(--b1)/var(--tw-bg-opacity)))}
.input:focus{outline:2px solid var(--fallback-p,oklch(var(--p)/1));outline-offset:0;border-color:transparent}
.input-bordered{--tw-border-opacity:.2;border-color:var(--fallback-bc,oklch(var(--bc)/var(--tw-border-opacity)))}
.input-sm{height:2rem;padding-left:.75rem;padding-right:.75rem;font-size:.875rem;line-height:1.25rem}
.input-lg{height:4rem;padding-left:1.5rem;padding-right:1.5rem;font-size:1.125rem;line-height:1.75rem}

/* ---- select ---- */
.select{display:inline-flex;cursor:pointer;user-select:none;-webkit-appearance:none;appearance:none;height:3rem;min-height:3rem;padding-inline-start:1rem;padding-inline-end:2.5rem;font-size:.875rem;line-height:2;border-radius:var(--rounded-btn,.5rem);border-width:1px;border-color:transparent;--tw-bg-opacity:1;background-color:var(--fallback-b1,oklch(var(--b1)/var(--tw-bg-opacity)));background-image:linear-gradient(45deg,transparent 50%,currentColor 50%),linear-gradient(135deg,currentColor 50%,transparent 50%);background-position:calc(100% - 20px) calc(1px + 50%),calc(100% - 16.1px) calc(1px + 50%);background-size:4px 4px,4px 4px;background-repeat:no-repeat}
.select:focus{outline:2px solid var(--fallback-p,oklch(var(--p)/1));outline-offset:0}
.select-bordered{--tw-border-opacity:.2;border-color:var(--fallback-bc,oklch(var(--bc)/var(--tw-border-opacity)))}
.select-sm{height:2rem;min-height:2rem;padding-left:.75rem;font-size:.875rem}

/* ---- textarea ---- */
.textarea{min-height:3rem;padding:.5rem 1rem;font-size:.875rem;line-height:2;border-radius:var(--rounded-btn,.5rem);border-width:1px;border-color:transparent;--tw-bg-opacity:1;background-color:var(--fallback-b1,oklch(var(--b1)/var(--tw-bg-opacity)))}
.textarea:focus{outline:2px solid var(--fallback-p,oklch(var(--p)/1));outline-offset:0}
.textarea-bordered{--tw-border-opacity:.2;border-color:var(--fallback-bc,oklch(var(--bc)/var(--tw-border-opacity)))}

/* ---- label / form-control ---- */
.form-control{display:flex;flex-direction:column}
.label{display:flex;user-select:none;align-items:center;justify-content:space-between;padding:.5rem .25rem}
.label-text{font-size:.875rem;--tw-text-opacity:1;color:var(--fallback-bc,oklch(var(--bc)/var(--tw-text-opacity)))}
.label-text-alt{font-size:.75rem;--tw-text-opacity:1;color:var(--fallback-bc,oklch(var(--bc)/var(--tw-text-opacity)))}

/* ---- checkbox ---- */
.checkbox{flex-shrink:0;--chkbg:var(--fallback-bc,oklch(var(--bc)/1));--chkfg:var(--fallback-b1,oklch(var(--b1)/1));height:1.5rem;width:1.5rem;cursor:pointer;-webkit-appearance:none;appearance:none;border-radius:var(--rounded-btn,.5rem);border-width:1px;border-color:var(--fallback-bc,oklch(var(--bc)/var(--tw-border-opacity)));--tw-border-opacity:.2}
.checkbox:checked,.checkbox[checked=true],[data-checked].checkbox{background-image:none;background-color:var(--chkbg);border-color:var(--chkbg);animation:checkmark var(--animation-input,.2s) ease-out}
@keyframes checkmark{0%{background-position-y:5px}50%{background-position-y:-.2rem}100%{background-position-y:0}}
.checkbox-primary{--chkbg:var(--fallback-p,oklch(var(--p)/1));--chkfg:var(--fallback-pc,oklch(var(--pc)/1))}

/* ---- radio ---- */
.radio{flex-shrink:0;height:1.5rem;width:1.5rem;cursor:pointer;-webkit-appearance:none;appearance:none;border-radius:9999px;border-width:1px;border-color:var(--fallback-bc,oklch(var(--bc)/var(--tw-border-opacity)));--tw-border-opacity:.2}
.radio:checked{box-shadow:0 0 0 4px var(--fallback-b1,oklch(var(--b1)/1)) inset,0 0 0 4px var(--fallback-b1,oklch(var(--b1)/1)) inset;background-color:var(--fallback-bc,oklch(var(--bc)/1))}
.radio-primary{--tw-border-opacity:1;border-color:var(--fallback-p,oklch(var(--p)/var(--tw-border-opacity)))}
.radio-primary:checked{background-color:var(--fallback-p,oklch(var(--p)/1))}

/* ---- toggle ---- */
.toggle{flex-shrink:0;--tglbg:var(--fallback-base-100,oklch(var(--b1)/1));--handleoffset:.5rem;--handleoffsetcalculator:calc(var(--handleoffset)*-1);--togglehandleborder:0 0;height:1.5rem;width:3rem;cursor:pointer;-webkit-appearance:none;appearance:none;border-radius:var(--rounded-badge,1.9rem);border:1px solid transparent;background-color:var(--fallback-bc,oklch(var(--bc)/.3));transition:background,box-shadow var(--animation-input,.2s) ease-out,border-color var(--animation-input,.2s) ease-out}
.toggle:checked{background-image:none;--handleoffsetcalculator:var(--handleoffset);--tw-border-opacity:1;border-color:var(--fallback-p,oklch(var(--p)/var(--tw-border-opacity)));--tw-bg-opacity:1;background-color:var(--fallback-p,oklch(var(--p)/var(--tw-bg-opacity)))}

/* ---- alert ---- */
.alert{display:grid;width:100%;grid-auto-flow:row;align-content:flex-start;align-items:center;justify-items:center;gap:1rem;text-align:center;border-radius:var(--rounded-box,1rem);border-width:1px;--tw-border-opacity:1;border-color:var(--fallback-b2,oklch(var(--b2)/var(--tw-border-opacity)));padding:1rem;--tw-text-opacity:1;color:var(--fallback-bc,oklch(var(--bc)/var(--tw-text-opacity)));--alert-bg:var(--fallback-b2,oklch(var(--b2)/1));background-color:var(--alert-bg)}
@media(min-width:640px){.alert{grid-auto-flow:column;grid-template-columns:auto minmax(auto,1fr);justify-items:start;text-align:start}}
.alert-info{--alert-bg:oklch(var(--in)/.15);border-color:oklch(var(--in)/.5)}
.alert-success{--alert-bg:oklch(var(--su)/.15);border-color:oklch(var(--su)/.5)}
.alert-warning{--alert-bg:oklch(var(--wa)/.15);border-color:oklch(var(--wa)/.5)}
.alert-error{--alert-bg:oklch(var(--er)/.15);border-color:oklch(var(--er)/.5)}

/* ---- avatar ---- */
.avatar{position:relative;display:inline-flex}
.avatar>div{display:block;aspect-ratio:1/1;overflow:hidden}
.avatar img{height:100%;width:100%;object-fit:cover}
.avatar.placeholder>div{display:flex;align-items:center;justify-content:center}

/* ---- menu ---- */
.menu{display:flex;flex-direction:column;flex-wrap:wrap;font-size:.875rem;line-height:1.25rem;padding:.5rem}
.menu :where(li:not(.menu-title)>*:not(ul,details,.menu-title,.btn)){display:grid;grid-auto-flow:column;align-content:flex-start;align-items:center;gap:.5rem;grid-auto-columns:minmax(auto,max-content) auto max-content;user-select:none}
.menu li.disabled{cursor:not-allowed;user-select:none;color:var(--fallback-bc,oklch(var(--bc)/.3))}
:where(.menu li){position:relative;display:flex;flex-shrink:0;flex-direction:column;flex-wrap:wrap;align-items:stretch}
.menu-horizontal{flex-direction:row;flex-wrap:nowrap}
.menu-horizontal>li>details>ul{position:absolute;top:100%}
.menu-horizontal>li>ul{position:absolute;top:100%}
@media(hover:hover){
  :where(.menu li:not(.menu-title,.disabled)>*:not(ul,details,.menu-title)):not(.active,.btn):hover{cursor:pointer;outline:2px solid transparent;background-color:var(--fallback-bc,oklch(var(--bc)/.1))}
}
.menu li>.active,.menu li>*:is(.active){--tw-bg-opacity:1;background-color:var(--fallback-p,oklch(var(--p)/var(--tw-bg-opacity)));--tw-text-opacity:1;color:var(--fallback-pc,oklch(var(--pc)/var(--tw-text-opacity)))}

/* ---- dropdown ---- */
.dropdown{position:relative;display:inline-block}
.dropdown .dropdown-content{position:absolute}
.dropdown:is(:not(details)) .dropdown-content{visibility:hidden;opacity:0;transform-origin:top;--tw-scale-x:.95;--tw-scale-y:.95;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y));transition-property:color,background-color,border-color,text-decoration-color,fill,stroke,opacity,box-shadow,transform,filter,backdrop-filter;transition-timing-function:cubic-bezier(0,0,.2,1);transition-duration:.2s}
.dropdown-end .dropdown-content{inset-inline-end:0}
.dropdown-bottom .dropdown-content{bottom:auto;top:100%;transform-origin:top}
.dropdown-top .dropdown-content{bottom:100%;top:auto;transform-origin:bottom}
.dropdown.dropdown-open .dropdown-content,.dropdown:focus-within .dropdown-content{visibility:visible;opacity:1;--tw-scale-x:1;--tw-scale-y:1;transform:translate(0) scaleX(1) scaleY(1)}
@media(hover:hover){.dropdown.dropdown-hover:hover .dropdown-content{visibility:visible;opacity:1;--tw-scale-x:1;--tw-scale-y:1;transform:translate(0) scaleX(1) scaleY(1)}}

/* ---- modal ---- */
.modal{pointer-events:none;position:fixed;inset:0;margin:0;display:grid;height:100%;max-height:none;width:100%;max-width:none;justify-items:center;padding:0;opacity:0;overscroll-behavior:contain;z-index:999;background-color:transparent;color:inherit;transition-duration:.2s;transition-timing-function:cubic-bezier(0,0,.2,1);transition-property:transform,opacity,visibility;overflow-y:hidden;align-items:center}
.modal-box{max-height:calc(100vh - 5em);grid-column-start:1;grid-row-start:1;width:91.667%;max-width:32rem;--tw-scale-x:.9;--tw-scale-y:.9;transform:scaleX(.9) scaleY(.9);border-radius:var(--rounded-box,1rem);--tw-bg-opacity:1;background-color:var(--fallback-b1,oklch(var(--b1)/var(--tw-bg-opacity)));padding:1.5rem;transition-property:color,background-color,border-color,opacity,box-shadow,transform,filter;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.2s;box-shadow:#00000040 0 25px 50px -12px;overflow-y:auto;overscroll-behavior:contain}
.modal-open,.modal:target,.modal-toggle:checked+.modal,.modal[open]{pointer-events:auto;visibility:visible;opacity:1}
.modal-open .modal-box,.modal:target .modal-box,.modal-toggle:checked+.modal .modal-box,.modal[open] .modal-box{--tw-scale-x:1;--tw-scale-y:1;transform:scaleX(1) scaleY(1)}
.modal-action{display:flex;margin-top:1.5rem;justify-content:flex-end;gap:.5rem}
.modal-backdrop{position:fixed;inset:0;cursor:pointer;background-color:#0000007a}
:root:has(:is(.modal-open,.modal:target,.modal-toggle:checked+.modal,.modal[open])){overflow:hidden;scrollbar-gutter:stable}

/* ---- collapse ---- */
.collapse:not(td):not(tr):not(colgroup){visibility:visible}
.collapse{position:relative;display:grid;overflow:hidden;grid-template-rows:max-content 0fr;transition:grid-template-rows .2s;width:100%;border-radius:var(--rounded-box,1rem)}
.collapse-title,.collapse>input[type=checkbox],.collapse>input[type=radio],.collapse-content{grid-column-start:1;grid-row-start:1}
.collapse-content{visibility:hidden;grid-column-start:1;grid-row-start:2;min-height:0;transition:visibility .2s,padding .2s ease-out,background-color .2s ease-out;padding-left:1rem;padding-right:1rem;cursor:unset}
.collapse[open],.collapse-open,.collapse:focus:not(.collapse-close){grid-template-rows:max-content 1fr}
.collapse[open]>.collapse-content,.collapse-open>.collapse-content,.collapse:not(.collapse-close)>input[type=checkbox]:checked~.collapse-content{visibility:visible;min-height:fit-content}
.collapse-title{padding:1rem}

/* ---- divider ---- */
.divider{display:flex;flex-direction:row;align-items:center;align-self:stretch;margin-top:1rem;margin-bottom:1rem;height:1rem;white-space:nowrap}
.divider:before,.divider:after{height:.125rem;width:100%;flex-grow:1;content:"";background-color:var(--fallback-bc,oklch(var(--bc)/.1))}
.divider:not(:empty){gap:.5rem}

/* ---- hero ---- */
.hero{display:grid;width:100%;place-items:center;background-size:cover;background-position:center}
.hero>*{grid-column-start:1;grid-row-start:1}
.hero-content{display:flex;align-items:center;justify-content:center;max-width:80rem;gap:1rem;padding:1rem}

/* ---- progress ---- */
.progress{position:relative;width:100%;-webkit-appearance:none;appearance:none;overflow:hidden;height:.5rem;border-radius:var(--rounded-box,1rem);background-color:var(--fallback-bc,oklch(var(--bc)/.2))}
.progress-primary::-webkit-progress-value{background-color:var(--fallback-p,oklch(var(--p)/1))}
.progress-primary::-moz-progress-bar{background-color:var(--fallback-p,oklch(var(--p)/1))}

/* ---- tooltip ---- */
.tooltip{position:relative;display:inline-flex;text-align:center;--tooltip-tail:0.1875rem;--tooltip-color:var(--fallback-n,oklch(var(--n)/1));--tooltip-text-color:var(--fallback-nc,oklch(var(--nc)/1));--tooltip-tail-offset:calc(100% + 1px - var(--tooltip-tail))}
.tooltip:before{position:absolute;pointer-events:none;z-index:1;content:attr(data-tip);max-width:20rem;font-size:.875rem;line-height:1.25rem;border-radius:var(--rounded-btn,.5rem);background-color:var(--tooltip-color);color:var(--tooltip-text-color);width:max-content;padding:.25rem .5rem;bottom:calc(100% + .25rem + var(--tooltip-tail,0px));left:50%;transform:translateX(-50%);opacity:0;transition:opacity .2s cubic-bezier(.4,0,.2,1) .1s}
.tooltip:hover:before{opacity:1}

/* ---- tabs / tab ---- */
.tabs{display:grid;align-items:flex-end}
.tab{position:relative;grid-row-start:1;display:inline-flex;height:2rem;cursor:pointer;user-select:none;-webkit-appearance:none;appearance:none;flex-wrap:wrap;align-items:center;justify-content:center;text-align:center;font-size:.875rem;line-height:2;--tab-padding:1rem;--tw-text-opacity:.5;--tab-color:var(--fallback-bc,oklch(var(--bc)/1));--tab-bg:var(--fallback-b1,oklch(var(--b1)/1));--tab-border-color:var(--fallback-b3,oklch(var(--b3)/1));color:var(--tab-color);padding-inline-start:var(--tab-padding,1rem);padding-inline-end:var(--tab-padding,1rem)}
@media(hover:hover){.tab:hover{--tw-text-opacity:1}}
.tab-active,[aria-selected=true]:where(.tab){--tw-text-opacity:1;color:var(--fallback-bc,oklch(var(--bc)/var(--tw-text-opacity)))}
.tabs-bordered .tab{border-style:solid;border-bottom-width:var(--tab-border,1px);border-color:var(--tab-border-color)}
.tabs-bordered .tab-active,.tabs-bordered [aria-selected=true]:where(.tab){border-color:oklch(var(--p));border-bottom-color:oklch(var(--p));color:oklch(var(--p))}

/* ---- stats ---- */
.stats{display:inline-grid;border-radius:var(--rounded-box,1rem);--tw-bg-opacity:1;background-color:var(--fallback-b1,oklch(var(--b1)/var(--tw-bg-opacity)));--tw-text-opacity:1;color:var(--fallback-bc,oklch(var(--bc)/var(--tw-text-opacity)))}
:where(.stats){grid-auto-flow:column;overflow-x:auto}
.stat{display:inline-grid;width:100%;grid-template-columns:repeat(1,1fr);column-gap:1rem;border-color:var(--fallback-bc,oklch(var(--bc)/var(--tw-border-opacity)));--tw-border-opacity:.1;padding:1rem 1.5rem}
.stat-title{grid-column-start:1;white-space:nowrap;color:var(--fallback-bc,oklch(var(--bc)/.6))}
.stat-value{grid-column-start:1;white-space:nowrap;font-size:2.25rem;line-height:2.5rem;font-weight:800}
.stat-desc{grid-column-start:1;white-space:nowrap;font-size:.75rem;color:var(--fallback-bc,oklch(var(--bc)/.6))}

/* ---- kbd ---- */
.kbd{display:inline-flex;align-items:center;justify-content:center;border-radius:var(--rounded-btn,.5rem);border-width:1px;border-color:var(--fallback-bc,oklch(var(--bc)/var(--tw-border-opacity)));--tw-border-opacity:.2;--tw-bg-opacity:1;background-color:var(--fallback-b2,oklch(var(--b2)/var(--tw-bg-opacity)));padding-left:.5rem;padding-right:.5rem;--tw-text-opacity:1;color:var(--fallback-bc,oklch(var(--bc)/var(--tw-text-opacity)));border-bottom-width:2px;min-height:2.2em;min-width:2.2em}

/* ---- link ---- */
.link{cursor:pointer;text-decoration-line:underline}
.link-hover{text-decoration-line:none}
@media(hover:hover){.link-hover:hover{text-decoration-line:underline}}
.link-primary{--tw-text-opacity:1;color:var(--fallback-p,oklch(var(--p)/var(--tw-text-opacity)))}

/* ---- join ---- */
.join{display:inline-flex;align-items:stretch;border-radius:var(--rounded-btn,.5rem)}
.join :where(.join-item){border-start-end-radius:0;border-end-end-radius:0;border-end-start-radius:0;border-start-start-radius:0}
.join .join-item:first-child:not(:last-child),:where(.join .join-item:first-child:not(:last-child)){border-end-start-radius:inherit;border-start-start-radius:inherit}
.join .join-item:last-child:not(:first-child),:where(.join .join-item:last-child:not(:first-child)){border-start-end-radius:inherit;border-end-end-radius:inherit}

/* ---- swap ---- */
.swap{position:relative;display:inline-grid;user-select:none;place-content:center;cursor:pointer}
.swap>*{grid-column-start:1;grid-row-start:1;transition-duration:.3s;transition-timing-function:cubic-bezier(0,0,.2,1);transition-property:transform,opacity}
.swap input{-webkit-appearance:none;appearance:none}
.swap .swap-on,.swap input:indeterminate~.swap-on{opacity:0}
.swap input:checked~.swap-off,.swap-active .swap-off{opacity:0}
.swap input:checked~.swap-on,.swap-active .swap-on{opacity:1}

/* ---- loading ---- */
.loading{pointer-events:none;display:inline-flex;aspect-ratio:1;width:1.5rem;background-color:currentColor;-webkit-mask-size:100%;mask-size:100%;-webkit-mask-repeat:no-repeat;mask-repeat:no-repeat;-webkit-mask-position:center;mask-position:center;-webkit-mask-image:url("data:image/svg+xml,%3Csvg width='24' height='24' stroke='%23000' viewBox='0 0 24 24' xmlns='http://www.w3.org/2000/svg'%3E%3Cstyle%3E.spinner_V8m1%7Btransform-origin:center;animation:spinner_zKoa 2s linear infinite%7D.spinner_V8m1 circle%7Bstroke-linecap:round;animation:spinner_YpZS 1.5s ease-in-out infinite%7D%40keyframes spinner_zKoa%7B100%25%7Btransform:rotate(360deg)%7D%7D%40keyframes spinner_YpZS%7B0%25%7Bstroke-dasharray:0 150;stroke-dashoffset:0%7D47.5%25%7Bstroke-dasharray:42 150;stroke-dashoffset:-16%7D95%25%2C100%25%7Bstroke-dasharray:42 150;stroke-dashoffset:-59%7D%7D%3C/style%3E%3Cg class='spinner_V8m1'%3E%3Ccircle cx='12' cy='12' r='9.5' fill='none' stroke-width='3'%3E%3C/circle%3E%3C/g%3E%3C/svg%3E");mask-image:url("data:image/svg+xml,%3Csvg width='24' height='24' stroke='%23000' viewBox='0 0 24 24' xmlns='http://www.w3.org/2000/svg'%3E%3Cstyle%3E.spinner_V8m1%7Btransform-origin:center;animation:spinner_zKoa 2s linear infinite%7D.spinner_V8m1 circle%7Bstroke-linecap:round;animation:spinner_YpZS 1.5s ease-in-out infinite%7D%40keyframes spinner_zKoa%7B100%25%7Btransform:rotate(360deg)%7D%7D%40keyframes spinner_YpZS%7B0%25%7Bstroke-dasharray:0 150;stroke-dashoffset:0%7D47.5%25%7Bstroke-dasharray:42 150;stroke-dashoffset:-16%7D95%25%2C100%25%7Bstroke-dasharray:42 150;stroke-dashoffset:-59%7D%7D%3C/style%3E%3Cg class='spinner_V8m1'%3E%3Ccircle cx='12' cy='12' r='9.5' fill='none' stroke-width='3'%3E%3C/circle%3E%3C/g%3E%3C/svg%3E")}
.loading-spinner{width:1.5rem;height:1.5rem;border:3px solid oklch(var(--bc)/.2);border-top-color:oklch(var(--p));border-radius:9999px;animation:spin .8s linear infinite;display:inline-block}
@keyframes spin{to{transform:rotate(360deg)}}

/* ---- footer ---- */
.footer{display:grid;width:100%;grid-auto-flow:row;place-items:start;column-gap:1rem;row-gap:2.5rem;font-size:.875rem;line-height:1.25rem}
.footer>*{display:grid;place-items:start;gap:.5rem}
@media(min-width:48rem){.footer{grid-auto-flow:column}}

/* 7. UTILITY CLASSES
   ============================================= */
/* Display */
.flex{display:flex}.inline-flex{display:inline-flex}.block{display:block}
.inline-block{display:inline-block}.grid{display:grid}.hidden{display:none}
@media(min-width:640px){.sm\:flex{display:flex}.sm\:block{display:block}.sm\:hidden{display:none}.sm\:inline{display:inline}}
@media(min-width:768px){.md\:flex{display:flex}.md\:block{display:block}.md\:hidden{display:none}}
@media(min-width:1024px){.lg\:flex{display:flex}.lg\:block{display:block}.lg\:hidden{display:none}}

/* Flexbox */
.flex-col{flex-direction:column}.flex-row{flex-direction:row}.flex-wrap{flex-wrap:wrap}
.flex-1{flex:1 1 0%}.flex-shrink-0{flex-shrink:0}.flex-grow{flex-grow:1}.flex-none{flex:none}
.items-center{align-items:center}.items-start{align-items:flex-start}.items-end{align-items:flex-end}.items-stretch{align-items:stretch}
.justify-center{justify-content:center}.justify-between{justify-content:space-between}
.justify-end{justify-content:flex-end}.justify-start{justify-content:flex-start}
.self-start{align-self:flex-start}.self-center{align-self:center}.self-end{align-self:flex-end}
@media(min-width:768px){.md\:flex-row{flex-direction:row}.md\:items-center{align-items:center}}

/* Grid */
.grid-cols-1{grid-template-columns:repeat(1,minmax(0,1fr))}.grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}.grid-cols-4{grid-template-columns:repeat(4,minmax(0,1fr))}
.col-span-1{grid-column:span 1/span 1}.col-span-2{grid-column:span 2/span 2}.col-span-full{grid-column:1/-1}
@media(min-width:640px){.sm\:grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}}
@media(min-width:768px){.md\:grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.md\:grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}}
@media(min-width:1024px){.lg\:grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}.lg\:grid-cols-4{grid-template-columns:repeat(4,minmax(0,1fr))}}
.place-items-center{place-items:center}.place-content-center{place-content:center}

/* Gap */
.gap-1{gap:.25rem}.gap-2{gap:.5rem}.gap-3{gap:.75rem}.gap-4{gap:1rem}.gap-5{gap:1.25rem}.gap-6{gap:1.5rem}.gap-8{gap:2rem}.gap-10{gap:2.5rem}.gap-12{gap:3rem}
.gap-x-4{column-gap:1rem}.gap-y-4{row-gap:1rem}

/* Sizing */
.w-full{width:100%}.w-auto{width:auto}.w-fit{width:fit-content}.w-screen{width:100vw}
.w-3{width:.75rem}.w-3\.5{width:.875rem}.w-4{width:1rem}.w-5{width:1.25rem}.w-6{width:1.5rem}.w-8{width:2rem}.w-10{width:2.5rem}.w-12{width:3rem}.w-16{width:4rem}.w-20{width:5rem}.w-24{width:6rem}.w-32{width:8rem}.w-48{width:12rem}.w-64{width:16rem}.w-72{width:18rem}
.h-3{height:.75rem}.h-3\.5{height:.875rem}.h-4{height:1rem}.h-5{height:1.25rem}.h-6{height:1.5rem}.h-8{height:2rem}.h-10{height:2.5rem}.h-12{height:3rem}.h-16{height:4rem}.h-full{height:100%}.h-screen{height:100vh}
.min-h-screen{min-height:100vh}.min-w-0{min-width:0}.min-w-48{min-width:12rem}
.max-w-sm{max-width:24rem}.max-w-md{max-width:28rem}.max-w-lg{max-width:32rem}.max-w-xl{max-width:36rem}.max-w-2xl{max-width:42rem}.max-w-3xl{max-width:48rem}.max-w-4xl{max-width:56rem}.max-w-5xl{max-width:64rem}.max-w-6xl{max-width:72rem}.max-w-7xl{max-width:80rem}.max-w-none{max-width:none}
.mx-auto{margin-left:auto;margin-right:auto}.ml-auto{margin-left:auto}.mr-auto{margin-right:auto}

/* Padding */
.p-0{padding:0}.p-1{padding:.25rem}.p-2{padding:.5rem}.p-3{padding:.75rem}.p-4{padding:1rem}.p-5{padding:1.25rem}.p-6{padding:1.5rem}.p-8{padding:2rem}.p-10{padding:2.5rem}
.px-2{padding-left:.5rem;padding-right:.5rem}.px-3{padding-left:.75rem;padding-right:.75rem}.px-4{padding-left:1rem;padding-right:1rem}.px-5{padding-left:1.25rem;padding-right:1.25rem}.px-6{padding-left:1.5rem;padding-right:1.5rem}.px-8{padding-left:2rem;padding-right:2rem}
.py-1{padding-top:.25rem;padding-bottom:.25rem}.py-2{padding-top:.5rem;padding-bottom:.5rem}.py-3{padding-top:.75rem;padding-bottom:.75rem}.py-4{padding-top:1rem;padding-bottom:1rem}.py-5{padding-top:1.25rem;padding-bottom:1.25rem}.py-6{padding-top:1.5rem;padding-bottom:1.5rem}.py-8{padding-top:2rem;padding-bottom:2rem}.py-10{padding-top:2.5rem;padding-bottom:2.5rem}.py-12{padding-top:3rem;padding-bottom:3rem}.py-16{padding-top:4rem;padding-bottom:4rem}.py-20{padding-top:5rem;padding-bottom:5rem}.py-24{padding-top:6rem;padding-bottom:6rem}
.pt-4{padding-top:1rem}.pt-8{padding-top:2rem}.pb-4{padding-bottom:1rem}.pb-8{padding-bottom:2rem}.pl-4{padding-left:1rem}.pr-4{padding-right:1rem}

/* Margin */
.m-0{margin:0}.mt-1{margin-top:.25rem}.mt-2{margin-top:.5rem}.mt-3{margin-top:.75rem}.mt-4{margin-top:1rem}.mt-6{margin-top:1.5rem}.mt-8{margin-top:2rem}.mt-12{margin-top:3rem}.mt-16{margin-top:4rem}
.mb-1{margin-bottom:.25rem}.mb-2{margin-bottom:.5rem}.mb-3{margin-bottom:.75rem}.mb-4{margin-bottom:1rem}.mb-6{margin-bottom:1.5rem}.mb-8{margin-bottom:2rem}.mb-12{margin-bottom:3rem}
.ml-1{margin-left:.25rem}.ml-2{margin-left:.5rem}.ml-auto{margin-left:auto}
.mr-1{margin-right:.25rem}.mr-2{margin-right:.5rem}
.-space-x-2>*+*{margin-left:-.5rem}
.space-x-2>*+*{margin-left:.5rem}.space-x-4>*+*{margin-left:1rem}
.space-y-2>*+*{margin-top:.5rem}.space-y-3>*+*{margin-top:.75rem}.space-y-4>*+*{margin-top:1rem}.space-y-6>*+*{margin-top:1.5rem}

/* Typography */
.text-xs{font-size:.75rem;line-height:1rem}.text-sm{font-size:.875rem;line-height:1.25rem}.text-base{font-size:1rem;line-height:1.5rem}.text-lg{font-size:1.125rem;line-height:1.75rem}.text-xl{font-size:1.25rem;line-height:1.75rem}.text-2xl{font-size:1.5rem;line-height:2rem}.text-3xl{font-size:1.875rem;line-height:2.25rem}.text-4xl{font-size:2.25rem;line-height:2.5rem}.text-5xl{font-size:3rem;line-height:1}.text-6xl{font-size:3.75rem;line-height:1}.text-7xl{font-size:4.5rem;line-height:1}.text-8xl{font-size:6rem;line-height:1}
.font-normal{font-weight:400}.font-medium{font-weight:500}.font-semibold{font-weight:600}.font-bold{font-weight:700}.font-extrabold{font-weight:800}.font-black{font-weight:900}
.leading-none{line-height:1}.leading-tight{line-height:1.25}.leading-snug{line-height:1.375}.leading-normal{line-height:1.5}.leading-relaxed{line-height:1.625}.leading-loose{line-height:2}
.tracking-tight{letter-spacing:-.025em}.tracking-normal{letter-spacing:0}.tracking-wide{letter-spacing:.025em}.tracking-wider{letter-spacing:.05em}.tracking-widest{letter-spacing:.1em}
.uppercase{text-transform:uppercase}.lowercase{text-transform:lowercase}.capitalize{text-transform:capitalize}.normal-case{text-transform:none}
.text-center{text-align:center}.text-left{text-align:left}.text-right{text-align:right}
.truncate{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.line-clamp-2{overflow:hidden;display:-webkit-box;-webkit-box-orient:vertical;-webkit-line-clamp:2}
.line-clamp-3{overflow:hidden;display:-webkit-box;-webkit-box-orient:vertical;-webkit-line-clamp:3}
.whitespace-nowrap{white-space:nowrap}.break-words{overflow-wrap:break-word}
.underline{text-decoration-line:underline}.no-underline{text-decoration-line:none}
.italic{font-style:italic}.not-italic{font-style:normal}
.antialiased{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}
@media(min-width:640px){.sm\:text-lg{font-size:1.125rem;line-height:1.75rem}.sm\:text-xl{font-size:1.25rem;line-height:1.75rem}}
@media(min-width:768px){.md\:text-xl{font-size:1.25rem;line-height:1.75rem}.md\:text-2xl{font-size:1.5rem;line-height:2rem}.md\:text-5xl{font-size:3rem;line-height:1}}
@media(min-width:1024px){.lg\:text-6xl{font-size:3.75rem;line-height:1}.lg\:text-7xl{font-size:4.5rem;line-height:1}}

/* Colors */
.text-primary{color:oklch(var(--p))}.text-secondary{color:oklch(var(--s))}.text-accent{color:oklch(var(--a))}
.text-base-content{color:oklch(var(--bc))}.text-neutral{color:oklch(var(--n))}.text-neutral-content{color:oklch(var(--nc))}
.text-muted{color:oklch(var(--bc)/.6)}.text-success{color:oklch(var(--su))}.text-warning{color:oklch(var(--wa))}.text-error{color:oklch(var(--er))}.text-info{color:oklch(var(--in))}
.text-white{color:#fff}.text-black{color:#000}
.text-base-content-30{color:oklch(var(--bc)/.3)}.text-base-content-50{color:oklch(var(--bc)/.5)}

.bg-base-100{background-color:oklch(var(--b1))}.bg-base-200{background-color:oklch(var(--b2))}.bg-base-300{background-color:oklch(var(--b3))}
.bg-primary{background-color:oklch(var(--p))}.bg-secondary{background-color:oklch(var(--s))}.bg-accent{background-color:oklch(var(--a))}
.bg-neutral{background-color:oklch(var(--n))}.bg-success{background-color:oklch(var(--su))}.bg-error{background-color:oklch(var(--er))}.bg-warning{background-color:oklch(var(--wa))}.bg-info{background-color:oklch(var(--in))}
.bg-transparent{background-color:transparent}

/* Border */
.border{border-width:1px}.border-0{border-width:0}.border-2{border-width:2px}
.border-b{border-bottom-width:1px}.border-t{border-top-width:1px}.border-l{border-left-width:1px}.border-r{border-right-width:1px}
.border-base-100{border-color:oklch(var(--b1))}.border-base-200{border-color:oklch(var(--b2))}.border-base-300{border-color:oklch(var(--b3))}
.border-primary{border-color:oklch(var(--p))}.border-transparent{border-color:transparent}
.border-base-content-10{border-color:oklch(var(--bc)/.1)}.border-base-content-20{border-color:oklch(var(--bc)/.2)}

/* Border radius */
.rounded{border-radius:.25rem}.rounded-md{border-radius:.375rem}.rounded-lg{border-radius:.5rem}.rounded-xl{border-radius:.75rem}.rounded-2xl{border-radius:1rem}.rounded-3xl{border-radius:1.5rem}.rounded-full{border-radius:9999px}.rounded-none{border-radius:0}

/* Position */
.relative{position:relative}.absolute{position:absolute}.fixed{position:fixed}.sticky{position:sticky}
.top-0{top:0}.right-0{right:0}.bottom-0{bottom:0}.left-0{left:0}.inset-0{inset:0}
.z-10{z-index:10}.z-20{z-index:20}.z-50{z-index:50}.z-100{z-index:100}

/* Overflow */
.overflow-hidden{overflow:hidden}.overflow-auto{overflow:auto}.overflow-x-auto{overflow-x:auto}.overflow-y-auto{overflow-y:auto}

/* Opacity */
.opacity-0{opacity:0}.opacity-30{opacity:.3}.opacity-50{opacity:.5}.opacity-60{opacity:.6}.opacity-70{opacity:.7}.opacity-100{opacity:1}

/* Shadow */
.shadow{box-shadow:0 1px 3px 0 rgba(0,0,0,.1),0 1px 2px -1px rgba(0,0,0,.1)}
.shadow-lg{box-shadow:0 10px 15px -3px rgba(0,0,0,.1),0 4px 6px -4px rgba(0,0,0,.1)}
.shadow-xl{box-shadow:0 20px 25px -5px rgba(0,0,0,.1),0 8px 10px -6px rgba(0,0,0,.1)}
.shadow-2xl{box-shadow:0 25px 50px -12px rgba(0,0,0,.25)}
.shadow-none{box-shadow:none}

/* Transitions */
.transition{transition-property:color,background-color,border-color,text-decoration-color,fill,stroke,opacity,box-shadow,transform,filter,backdrop-filter;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:150ms}
.transition-all{transition-property:all;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:150ms}
.transition-colors{transition-property:color,background-color,border-color,text-decoration-color;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:150ms}
.duration-200{transition-duration:200ms}.duration-300{transition-duration:300ms}.ease-in-out{transition-timing-function:cubic-bezier(.4,0,.2,1)}

/* Transform */
.scale-100{transform:scale(1)}.rotate-180{transform:rotate(180deg)}
@media(hover:hover){.hover\:scale-105:hover{transform:scale(1.05)}}

/* Cursor */
.cursor-pointer{cursor:pointer}.cursor-default{cursor:default}.cursor-not-allowed{cursor:not-allowed}

/* Pointer events */
.pointer-events-none{pointer-events:none}.pointer-events-auto{pointer-events:auto}

/* User select */
.select-none{user-select:none}

/* Aspect ratio */
.aspect-square{aspect-ratio:1/1}.aspect-video{aspect-ratio:16/9}.aspect-4-3{aspect-ratio:4/3}

/* Object fit */
.object-cover{object-fit:cover}.object-contain{object-fit:contain}.object-center{object-position:center}

/* Outline */
.outline-none{outline:2px solid transparent;outline-offset:2px}

/* Backdrop */
.backdrop-blur-sm{backdrop-filter:blur(4px)}.backdrop-blur{backdrop-filter:blur(8px)}.backdrop-blur-md{backdrop-filter:blur(12px)}

/* Hover utilities */
.hover\:text-primary:hover{color:oklch(var(--p))}.hover\:bg-base-200:hover{background-color:oklch(var(--b2))}.hover\:bg-base-300:hover{background-color:oklch(var(--b3))}
.hover\:opacity-80:hover{opacity:.8}.hover\:underline:hover{text-decoration-line:underline}.hover\:border-primary:hover{border-color:oklch(var(--p))}

/* Group hover */
.group{}.group:hover .group-hover\:scale-110{transform:scale(1.1)}.group:hover .group-hover\:opacity-100{opacity:1}
.group:hover .group-hover\:text-primary{color:oklch(var(--p))}

/* Focus */
.focus\:outline-none:focus{outline:2px solid transparent;outline-offset:2px}
.focus\:border-primary:focus{border-color:oklch(var(--p))}

/* Container */
.container{width:100%;margin-left:auto;margin-right:auto;padding-left:1rem;padding-right:1rem}
@media(min-width:640px){.container{max-width:640px}}
@media(min-width:768px){.container{max-width:768px}}
@media(min-width:1024px){.container{max-width:1024px}}
@media(min-width:1280px){.container{max-width:1280px}}
@media(min-width:1536px){.container{max-width:1536px}}

/* Divide */
.divide-y>*+*{border-top-width:1px;border-color:oklch(var(--bc)/.1)}

/* Padding responsive */
@media(min-width:640px){.sm\:px-6{padding-left:1.5rem;padding-right:1.5rem}}
@media(min-width:768px){.md\:px-8{padding-left:2rem;padding-right:2rem}.md\:py-12{padding-top:3rem;padding-bottom:3rem}.md\:py-20{padding-top:5rem;padding-bottom:5rem}}
@media(min-width:1024px){.lg\:px-8{padding-left:2rem;padding-right:2rem}.lg\:py-24{padding-top:6rem;padding-bottom:6rem}}

/* Sizing responsive */
@media(min-width:768px){.md\:w-1\/2{width:50%}.md\:w-1\/3{width:33.333%}.md\:w-2\/3{width:66.667%}}
@media(min-width:1024px){.lg\:w-72{width:18rem}}

/* Sticky */
@media(min-width:1024px){.lg\:sticky{position:sticky}}

/* Animations */
@keyframes fadeInUp{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}
.animate-fade-in-up{animation:fadeInUp .5s ease forwards}
.animate-fade-in{animation:fadeInUp .3s ease forwards}
@keyframes float{0%,100%{transform:translateY(0)}50%{transform:translateY(-10px)}}
.animate-float{animation:float 3s ease-in-out infinite}
@keyframes pulse-glow{0%,100%{box-shadow:0 0 15px oklch(var(--p)/.3)}50%{box-shadow:0 0 30px oklch(var(--p)/.6)}}
.animate-pulse-glow{animation:pulse-glow 2s ease-in-out infinite}

/* Misc */
.sticky-sidebar{position:sticky;top:5rem}
.list-none{list-style:none}
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border-width:0}
.not-sr-only{position:static;width:auto;height:auto;padding:0;margin:0;overflow:visible;clip:auto;white-space:normal}


/* 8. THEME-SPECIFIC COMPONENTS
   ============================================= */

/* ── Navbar ── */
.wwm-navbar{
  position:fixed;top:0;left:0;right:0;width:100%;z-index:100;
  backdrop-filter:blur(12px);
  -webkit-backdrop-filter:blur(12px);
  background-color:oklch(var(--b1)/.92);
  border-bottom:1px solid oklch(var(--bc)/.08);
  transition:box-shadow .3s,background-color .3s
}
body{padding-top:4rem}
.wwm-navbar.scrolled{
  background-color:oklch(var(--b1)/.95);
  box-shadow:0 4px 20px oklch(var(--p)/.08)
}
.nav-link{
  display:inline-flex;align-items:center;gap:.25rem;
  padding:.5rem .75rem;border-radius:var(--rounded-btn,.5rem);
  font-size:.875rem;color:oklch(var(--bc)/.8);
  transition:color .2s,background-color .2s;
  text-decoration:none
}
.nav-link:hover,.nav-link.text-primary{color:oklch(var(--p))}
.nav-link:hover{background-color:oklch(var(--bc)/.06)}
.nav-link-mobile{
  display:block;padding:.875rem 1rem;border-radius:var(--rounded-btn,.5rem);
  font-size:1rem;font-weight:500;color:oklch(var(--bc)/.85);
  text-decoration:none;transition:color .2s,background-color .2s
}
.nav-link-mobile:hover,.nav-link-mobile.active{color:oklch(var(--p));background-color:oklch(var(--p)/.08)}
.site-brand .custom-logo-link{display:flex;align-items:center}
.site-brand img,.custom-logo{height:3rem;width:auto!important;max-width:none;object-fit:contain;display:block}

/* ── Mobile menu ── */
.wwm-mobile-menu{
  position:fixed;inset:0;z-index:200;
  background:oklch(var(--b1)/.98);
  backdrop-filter:blur(16px);
  transform:translateX(-100%);
  transition:transform .3s cubic-bezier(.4,0,.2,1)
}
.wwm-mobile-menu.open{transform:translateX(0)}
.wwm-overlay{
  position:fixed;inset:0;z-index:190;
  background:rgba(0,0,0,.5);
  opacity:0;pointer-events:none;
  transition:opacity .3s
}
.wwm-overlay.active{opacity:1;pointer-events:auto}

/* ── Search bar ── */
.wwm-search-bar{
  max-height:0;overflow:hidden;
  transition:max-height .3s cubic-bezier(.4,0,.2,1)
}
.wwm-search-bar.open{max-height:5rem}

/* ── Hero section ── */
.wwm-hero{
  min-height:60vh;display:flex;align-items:center;
  position:relative;overflow:hidden
}
.wwm-hero::before{
  content:'';position:absolute;inset:0;
  background:radial-gradient(ellipse at 25% 50%,oklch(var(--p)/.12) 0%,transparent 55%),radial-gradient(ellipse at 75% 30%,oklch(var(--s)/.08) 0%,transparent 55%);
  pointer-events:none
}
.hero-inner{
  display:grid;gap:3rem;align-items:center;width:100%;
  grid-template-columns:1fr
}
@media(min-width:1024px){
  .hero-inner{grid-template-columns:1fr 1fr;gap:4rem}
}
.hero-title{
  font-size:2.5rem;font-weight:900;line-height:1.1;
  letter-spacing:-.03em;margin-bottom:1.25rem
}
@media(min-width:768px){.hero-title{font-size:3.5rem}}
@media(min-width:1024px){.hero-title{font-size:4.25rem}}
.hero-subtitle{
  font-size:1.125rem;color:oklch(var(--bc)/.7);
  line-height:1.7;margin-bottom:2rem;max-width:38rem
}
.hero-actions{display:flex;flex-wrap:wrap;gap:.75rem;margin-bottom:2rem}
.hero-proof{display:flex;align-items:center;gap:.875rem}
.hero-visual{display:none}
@media(min-width:1024px){.hero-visual{display:flex;justify-content:center;align-items:center}}

/* Mock card stack in hero */
.hero-card-stack{position:relative;width:22rem;height:16rem}
.mock-card{
  position:absolute;border-radius:1rem;
  background:oklch(var(--b2));border:1px solid oklch(var(--bc)/.1);
  overflow:hidden
}
.mock-card-back{
  width:75%;bottom:-1.5rem;right:0;height:60%;
  transform:rotate(6deg);opacity:.5
}
.mock-card-mid{
  width:80%;bottom:-.5rem;right:.5rem;height:65%;
  transform:rotate(3deg);opacity:.7
}
.mock-card-front{
  width:100%;bottom:0;left:0;height:100%;
  box-shadow:0 20px 60px oklch(var(--p)/.2),0 0 0 1px oklch(var(--p)/.15)
}
.mock-card-header{height:3rem;background:oklch(var(--b3))}
.mock-card-header.accent{background:linear-gradient(135deg,oklch(var(--p)),oklch(var(--s)))}
.mock-card-img{height:8rem;background:oklch(var(--b3));display:flex;align-items:center;justify-content:center}
.mock-img-placeholder{display:flex;align-items:center;justify-content:center;width:100%;height:100%}
.mock-lines{padding:.75rem}
.mock-line{height:.625rem;background:oklch(var(--bc)/.15);border-radius:.25rem;margin-bottom:.5rem}
.mock-line.long{width:85%}.mock-line.medium{width:65%}.mock-line.short{width:40%}

/* ── Stats bar ── */
.wwm-stats-bar{
  border-top:1px solid oklch(var(--bc)/.06);
  border-bottom:1px solid oklch(var(--bc)/.06);
  background:oklch(var(--b2)/.4);padding:1.5rem 0
}
.stats-grid{
  display:grid;gap:1.5rem;
  grid-template-columns:repeat(2,1fr)
}
@media(min-width:768px){.stats-grid{grid-template-columns:repeat(4,1fr)}}
.stat-item{display:flex;align-items:center;gap:.875rem;padding:.5rem}
.stat-icon{
  width:2.5rem;height:2.5rem;flex-shrink:0;
  background:oklch(var(--p)/.15);border-radius:.625rem;
  display:flex;align-items:center;justify-content:center;
  color:oklch(var(--p))
}
.stat-value{font-size:1.375rem;font-weight:800;line-height:1;margin-bottom:.125rem}
.stat-label{font-size:.75rem;color:oklch(var(--bc)/.6);white-space:nowrap}

/* ── Section helpers ── */
.section-pad{padding:2rem 0}
.bg-section-alt{background:oklch(var(--b2)/.4);border-top:1px solid oklch(var(--bc)/.06);border-bottom:1px solid oklch(var(--bc)/.06)}
.section-header{display:flex;align-items:flex-end;justify-content:space-between;margin-bottom:3rem;gap:1rem;flex-wrap:wrap}
.section-header.centered{text-align:center;flex-direction:column;align-items:center}
.section-eyebrow{display:inline-block;font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:oklch(var(--p));margin-bottom:.5rem}
.section-heading{font-size:2rem;font-weight:800;line-height:1.2;letter-spacing:-.02em}
@media(min-width:768px){.section-heading{font-size:2.5rem}}
.section-sub{font-size:1.0625rem;color:oklch(var(--bc)/.65);line-height:1.65;max-width:42rem;margin-top:.5rem}

/* ── Product grid ── */
.product-grid{
  display:grid;gap:1.5rem;
  grid-template-columns:repeat(1,minmax(0,1fr))
}
@media(min-width:640px){.product-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}
@media(min-width:1024px){.product-grid{grid-template-columns:repeat(3,minmax(0,1fr))}}
.product-grid-4{}
@media(min-width:1024px){.product-grid-4{grid-template-columns:repeat(4,minmax(0,1fr))}}
.product-archive-grid{
  display:grid;gap:1.5rem;list-style:none;margin:0;padding:0;
  grid-template-columns:repeat(1,minmax(0,1fr))
}
@media(min-width:640px){.product-archive-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}
@media(min-width:1024px){.product-archive-grid{grid-template-columns:repeat(3,minmax(0,1fr))}}

/* ── Product card ── */
.wwm-product-card{
  position:relative;overflow:hidden;
  border-radius:var(--rounded-box,1rem);
  border:1px solid oklch(var(--bc)/.1);
  background:oklch(var(--b2));
  transition:transform .3s cubic-bezier(.4,0,.2,1),box-shadow .3s,border-color .3s
}
.wwm-product-card:hover{
  transform:translateY(-4px);
  box-shadow:0 20px 40px oklch(var(--p)/.12),0 0 0 1px oklch(var(--p)/.2);
  border-color:oklch(var(--p)/.3)
}
.product-card-inner{display:block;height:100%;cursor:default}
.product-card-image{
  aspect-ratio:1/1;position:relative;
  background:oklch(var(--b3));
  display:flex;align-items:center;justify-content:center;
  padding:1rem
}
.product-thumb-img{
  width:100%;height:100%;
  object-fit:contain;object-position:center;
  transition:transform .3s ease
}
.wwm-product-card:hover .product-thumb-img{transform:scale(1.03)}
.product-thumb-placeholder{
  width:100%;height:100%;display:flex;
  align-items:center;justify-content:center;
  background:oklch(var(--b3))
}
.product-card-badge{
  position:absolute;top:.625rem;left:.625rem;
  display:flex;gap:.25rem
}
.product-card-type-icon{
  position:absolute;top:.625rem;right:.625rem;
  background:oklch(var(--b1)/.7);backdrop-filter:blur(4px);
  border-radius:.375rem;padding:.25rem .4rem;
  color:oklch(var(--p));display:flex;align-items:center;
  font-size:.625rem;font-weight:600;gap:.2rem
}
.product-card-body{padding:1rem;display:flex;flex-direction:column;gap:.375rem}
.product-card-cat{
  font-size:.625rem;font-weight:700;text-transform:uppercase;
  letter-spacing:.08em;color:oklch(var(--p))
}
.product-card-title{
  font-size:.9375rem;font-weight:700;line-height:1.35;
  color:oklch(var(--bc));overflow:hidden;
  display:-webkit-box;-webkit-box-orient:vertical;-webkit-line-clamp:2
}
.product-card-rating{display:flex;align-items:center;gap:.375rem}
.stars{display:flex;gap:.125rem}
/* Stock indicator */
.product-stock{
  display:inline-flex;align-items:center;gap:.375rem;
  font-size:.75rem;font-weight:600
}
.stock-dot{
  width:.4375rem;height:.4375rem;border-radius:9999px;flex-shrink:0
}
.stock-ok{color:oklch(var(--su))}
.stock-ok .stock-dot{background:oklch(var(--su));box-shadow:0 0 5px oklch(var(--su)/.5)}
.stock-low{color:oklch(var(--wa))}
.stock-low .stock-dot{background:oklch(var(--wa));box-shadow:0 0 5px oklch(var(--wa)/.5)}
.stock-critical{color:oklch(var(--er))}
.stock-critical .stock-dot{background:oklch(var(--er));box-shadow:0 0 5px oklch(var(--er)/.5)}
.stock-out{color:oklch(var(--bc)/.4)}
.stock-out .stock-dot{background:oklch(var(--bc)/.25)}

.product-card-footer{
  display:flex;align-items:center;justify-content:space-between;
  margin-top:.5rem;gap:.5rem
}
.product-card-price{
  font-size:1.125rem;font-weight:800;color:oklch(var(--p));line-height:1
}
.product-card-price.price-free{color:oklch(var(--su))}
del{color:oklch(var(--bc)/.4);font-weight:400;font-size:.875rem}
ins{text-decoration:none}

/* ── Category grid ── */
.category-grid{
  display:grid;gap:1rem;
  grid-template-columns:repeat(2,minmax(0,1fr))
}
@media(min-width:640px){.category-grid{grid-template-columns:repeat(3,minmax(0,1fr))}}
@media(min-width:1024px){.category-grid{grid-template-columns:repeat(6,minmax(0,1fr))}}
.category-card{
  border-radius:var(--rounded-box,1rem);overflow:hidden;
  text-decoration:none;color:oklch(var(--bc));
  border:1px solid oklch(var(--bc)/.1);
  background:oklch(var(--b2));
  transition:all .3s ease
}
.category-card:hover{border-color:oklch(var(--p)/.4);transform:translateY(-2px)}
.category-card-inner{position:relative;overflow:hidden}
.category-img{width:100%;aspect-ratio:1/1;object-fit:cover;transition:transform .5s}
.category-card:hover .category-img{transform:scale(1.08)}
.category-img-placeholder{
  width:100%;aspect-ratio:1/1;
  display:flex;align-items:center;justify-content:center;
  background:oklch(var(--b3))
}
.category-info{padding:.875rem;background:linear-gradient(0deg,oklch(var(--b1)/.9) 0%,transparent 100%)}
.category-name{font-size:.9375rem;font-weight:700}
.category-count{font-size:.75rem;color:oklch(var(--bc)/.5)}

/* ── Features grid ── */
.features-grid{
  display:grid;gap:1.5rem;
  grid-template-columns:repeat(1,minmax(0,1fr))
}
@media(min-width:640px){.features-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}
@media(min-width:1024px){.features-grid{grid-template-columns:repeat(3,minmax(0,1fr))}}
.feature-card{
  padding:1.5rem;background:oklch(var(--b2));
  border:1px solid oklch(var(--bc)/.08);
  border-radius:var(--rounded-box,1rem);
  transition:border-color .3s,background .3s
}
.feature-card:hover{border-color:oklch(var(--p)/.3);background:oklch(var(--b3))}
.feature-icon{
  width:2.75rem;height:2.75rem;
  background:oklch(var(--p)/.15);border-radius:.75rem;
  display:flex;align-items:center;justify-content:center;
  margin-bottom:1rem;color:oklch(var(--p))
}

/* ── CTA section ── */
.wwm-cta-section{padding:5rem 0}
.cta-card{
  position:relative;overflow:hidden;
  border-radius:var(--rounded-box,1rem);
  background:linear-gradient(135deg,oklch(var(--b2)) 0%,oklch(var(--b3)) 100%);
  border:1px solid oklch(var(--p)/.2);
  padding:4rem 2rem;text-align:center
}
@media(min-width:768px){.cta-card{padding:5rem 4rem}}
.cta-glow{
  position:absolute;inset:0;pointer-events:none;
  background:radial-gradient(ellipse at 50% 0%,oklch(var(--p)/.15) 0%,transparent 60%)
}
.cta-content{position:relative;z-index:1;max-width:42rem;margin:0 auto}
.cta-title{font-size:2rem;font-weight:900;letter-spacing:-.02em;margin-bottom:1rem}
@media(min-width:768px){.cta-title{font-size:2.75rem}}
.cta-sub{font-size:1.0625rem;color:oklch(var(--bc)/.7);line-height:1.65;margin-bottom:2rem}
.cta-actions{display:flex;flex-wrap:wrap;gap:.75rem;justify-content:center}

/* ── Verified Reseller Badge ── */
.verified-reseller-badge{
  display:inline-flex;align-items:center;gap:.625rem;
  padding:.875rem 1.5rem;
  background:oklch(var(--p)/.1);
  border:1px solid oklch(var(--p)/.35);
  border-radius:var(--rounded-box,1rem);
  backdrop-filter:blur(8px)
}
.verified-check{
  display:flex;align-items:center;justify-content:center;
  color:oklch(var(--p));flex-shrink:0
}
.verified-text{
  font-size:1.125rem;font-weight:700;
  letter-spacing:.01em;color:oklch(var(--bc))
}
@media(min-width:768px){.verified-text{font-size:1.375rem}}
@media(min-width:1024px){.verified-text{font-size:1.625rem}}

/* ── Footer ── */
.wwm-footer{
  border-top:1px solid oklch(var(--bc)/.08);
  padding:0
}
.footer-bottom{
  display:flex;align-items:center;justify-content:space-between;
  flex-wrap:wrap;gap:.75rem;
  padding:.625rem 0
}
.footer-discord{
  font-size:.8125rem;font-weight:700;
  color:oklch(var(--p));letter-spacing:.03em
}
.footer-legal-links{
  display:flex;align-items:center;gap:1.5rem
}
.footer-legal-links a{
  font-size:.8125rem;color:oklch(var(--bc)/.45);
  text-decoration:none;transition:color .2s
}
.footer-legal-links a:hover{color:oklch(var(--p))}
.text-muted{color:oklch(var(--bc)/.6)}
.hover\:text-primary:hover{color:oklch(var(--p))}

/* ── Page header ── */
.wwm-page-header{
  padding:3rem 0 2rem;
  background:linear-gradient(135deg,oklch(var(--b2)) 0%,oklch(var(--b1)) 100%);
  border-bottom:1px solid oklch(var(--bc)/.08)
}

/* ── Hero social proof avatars ── */
.avatar-placeholder{
  width:2rem;height:2rem;border-radius:9999px;
  display:flex;align-items:center;justify-content:center;
  font-size:.625rem;font-weight:800;color:#fff;
  border:2px solid oklch(var(--b1))
}

/* ── Gradient text ── */
.gradient-text{
  background:linear-gradient(135deg,oklch(var(--p)) 0%,oklch(var(--s)) 100%);
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;
  background-clip:text
}

/* ── Category pill ── */
.category-pill{
  display:inline-flex;align-items:center;
  padding:.1875rem .625rem;border-radius:9999px;
  font-size:.6875rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;
  background:oklch(var(--p)/.12);color:oklch(var(--p));
  border:1px solid oklch(var(--p)/.25);text-decoration:none;
  transition:background .2s,border-color .2s
}
.category-pill:hover{background:oklch(var(--p)/.2);border-color:oklch(var(--p)/.4)}

/* ── Cart count badge ── */
.cart-count{
  position:absolute;top:-.25rem;right:-.25rem;
  min-width:1.125rem;height:1.125rem;
  background:oklch(var(--p));color:oklch(var(--pc));
  border-radius:9999px;font-size:.5625rem;font-weight:800;
  display:flex;align-items:center;justify-content:center;
  padding:0 .2rem
}

/* ── Blog grid ── */
.blog-grid{
  display:grid;gap:1.5rem;
  grid-template-columns:1fr
}
@media(min-width:640px){.blog-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}
@media(min-width:1024px){.blog-grid{grid-template-columns:repeat(3,minmax(0,1fr))}}
.blog-card{
  border-radius:var(--rounded-box,1rem);overflow:hidden;
  border:1px solid oklch(var(--bc)/.1);background:oklch(var(--b2));
  transition:border-color .3s,transform .3s
}
.blog-card:hover{border-color:oklch(var(--p)/.3);transform:translateY(-2px)}
.blog-card-image{display:block;overflow:hidden;aspect-ratio:16/9}
.blog-thumb-img{width:100%;height:100%;object-fit:cover;transition:transform .5s}
.blog-card:hover .blog-thumb-img{transform:scale(1.05)}
.blog-card-body{padding:1.25rem}
.blog-card-title{font-size:1rem;font-weight:700;line-height:1.4;margin-bottom:.25rem}
.blog-card-title a{color:oklch(var(--bc));text-decoration:none;transition:color .2s}
.blog-card-title a:hover{color:oklch(var(--p))}

/* ── Post navigation ── */
.post-nav-link{
  display:flex;flex-direction:column;
  text-decoration:none;color:oklch(var(--bc));
  padding:.875rem 1.25rem;border-radius:var(--rounded-box,1rem);
  border:1px solid oklch(var(--bc)/.1);background:oklch(var(--b2));
  transition:border-color .2s;max-width:20rem
}
.post-nav-link:hover{border-color:oklch(var(--p)/.4)}

/* ── Shop archive ── */
.shop-filter-bar{margin-top:1.5rem}
.shop-sort-bar{
  display:flex;align-items:center;justify-content:space-between;
  margin-bottom:1.5rem;gap:1rem;flex-wrap:wrap
}
.shop-sidebar{width:100%}
@media(min-width:1024px){.shop-sidebar{width:16rem;flex-shrink:0}}
.sidebar-widget{background:oklch(var(--b2));border-radius:var(--rounded-box,1rem);padding:1.5rem;margin-bottom:1rem}

/* ── Single product ── */
.product-single-grid{
  display:grid;gap:3rem;align-items:start;
  grid-template-columns:1fr
}
@media(min-width:768px){.product-single-grid{grid-template-columns:1fr 1fr}}
@media(min-width:1024px){.product-single-grid{grid-template-columns:1.1fr .9fr}}
.product-gallery{position:sticky;top:5rem}
.product-gallery-main{
  border-radius:var(--rounded-box,1rem);overflow:hidden;
  background:oklch(var(--b2));aspect-ratio:4/3;position:relative;
  display:flex;align-items:center;justify-content:center;
  border:1px solid oklch(var(--bc)/.1)
}
.product-main-image{width:100%;height:100%;object-fit:cover}
.product-no-image{display:flex;align-items:center;justify-content:center;width:100%;height:100%}
.product-hero-badge{position:absolute;top:.875rem;left:.875rem;display:flex;gap:.375rem}
.product-gallery-thumbs{display:flex;gap:.5rem;margin-top:.75rem;flex-wrap:wrap}
.product-gallery-thumb{
  width:4.5rem;height:4.5rem;border-radius:.625rem;overflow:hidden;
  cursor:pointer;border:2px solid transparent;transition:border-color .2s;
  padding:0;background:none;flex-shrink:0
}
.product-gallery-thumb img{width:100%;height:100%;object-fit:cover}
.product-gallery-thumb.active,.product-gallery-thumb:hover{border-color:oklch(var(--p))}
.product-info{display:flex;flex-direction:column;gap:1rem}
.product-title{font-size:1.75rem;font-weight:800;line-height:1.2;letter-spacing:-.02em}
@media(min-width:768px){.product-title{font-size:2rem}}
.product-price-block{display:flex;align-items:baseline;gap:.75rem;flex-wrap:wrap}
.product-price{font-size:1.75rem;font-weight:900;color:oklch(var(--p))}
.product-price .amount{font-size:1.75rem;font-weight:900;color:oklch(var(--p))}
.product-price del .amount,.product-price del{color:oklch(var(--bc)/.4);font-size:1rem;font-weight:400}
.product-short-desc{font-size:.9375rem;color:oklch(var(--bc)/.8);line-height:1.65}

/* Add to cart area */
.cart{display:flex;flex-direction:column;gap:.75rem;margin:1rem 0}
.cart .qty-wrap,.quantity{display:flex;align-items:center;gap:.75rem}
.qty-input-wrap,.quantity{display:flex;align-items:center;border:1px solid oklch(var(--bc)/.2);border-radius:var(--rounded-btn,.5rem);overflow:hidden;background:oklch(var(--b2))}
.quantity input[type=number]{
  width:3rem;height:2.5rem;text-align:center;
  background:transparent;border:none;outline:none;
  font-weight:700;font-size:1rem;color:oklch(var(--bc))
}
.single_add_to_cart_button{
  height:3rem;min-height:3rem;display:inline-flex;align-items:center;
  justify-content:center;border-radius:var(--rounded-btn,.5rem);
  padding-left:1.5rem;padding-right:1.5rem;
  font-size:.9375rem;font-weight:700;gap:.5rem;cursor:pointer;
  background:oklch(var(--p));color:oklch(var(--pc));border:none;
  transition:opacity .2s,transform .2s;text-decoration:none;width:100%
}
.single_add_to_cart_button:hover{opacity:.9}
.single_add_to_cart_button:active{transform:scale(.98)}

/* Trust badges */
.trust-badges{
  display:flex;flex-wrap:wrap;gap:1rem;
  padding:1rem;border-radius:.75rem;
  background:oklch(var(--b3)/.5);
  border:1px solid oklch(var(--bc)/.06)
}
.trust-item{display:flex;align-items:center;gap:.4rem;font-size:.8125rem;color:oklch(var(--bc)/.7)}

/* Product meta */
.product-meta{display:flex;flex-direction:column;gap:.625rem;padding-top:.75rem;border-top:1px solid oklch(var(--bc)/.08)}
.product-meta-row{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap;font-size:.875rem}
.meta-label{font-weight:600;color:oklch(var(--bc)/.6);flex-shrink:0}
.meta-value{color:oklch(var(--bc)/.8)}

/* Product tabs */
.product-tabs-section{margin-top:4rem}
.wwm-tabs{display:flex;gap:0;border-bottom:1px solid oklch(var(--bc)/.1);margin-bottom:2rem;flex-wrap:wrap}
.wwm-tab{
  padding:.75rem 1.5rem;cursor:pointer;
  border-bottom:2px solid transparent;margin-bottom:-1px;
  font-weight:500;color:oklch(var(--bc)/.55);
  transition:all .2s;background:none;border-top:none;border-left:none;border-right:none;
  font-size:.9375rem
}
.wwm-tab:hover{color:oklch(var(--bc))}
.wwm-tab.active{border-bottom-color:oklch(var(--p));color:oklch(var(--p))}
.wwm-tab-panel{display:none;padding-top:.5rem}
.wwm-tab-panel.active{display:block}

/* Product attributes table */
.product-attributes-table{width:100%;border-collapse:collapse}
.product-attributes-table th,.product-attributes-table td{padding:.75rem 1rem;text-align:left;font-size:.875rem;border-bottom:1px solid oklch(var(--bc)/.08)}
.product-attributes-table th{font-weight:600;color:oklch(var(--bc)/.6);width:35%;background:oklch(var(--b2))}
.product-attributes-table td{color:oklch(var(--bc)/.85)}
.product-attributes-table tr:last-child th,.product-attributes-table tr:last-child td{border-bottom:none}

/* ── WooCommerce notices ── */

.woocommerce-notices-wrapper,.woocommerce-error,.woocommerce-message,.woocommerce-info{margin-bottom:1rem}
.woocommerce-error,.woocommerce-message,.woocommerce-info{
  padding:1rem 1.5rem;border-radius:var(--rounded-box,1rem);
  border-left:4px solid;list-style:none;display:flex;align-items:center;gap:.75rem
}
.woocommerce-message{background:oklch(var(--su)/.1);border-color:oklch(var(--su));color:oklch(var(--bc))}
.woocommerce-info{background:oklch(var(--in)/.1);border-color:oklch(var(--in));color:oklch(var(--bc))}
.woocommerce-error{background:oklch(var(--er)/.1);border-color:oklch(var(--er));color:oklch(var(--bc))}
.woocommerce-error a,.woocommerce-message a,.woocommerce-info a{color:oklch(var(--p))}

/* ── WooCommerce cart / checkout page wrapper ── */
.woo-page-content{max-width:56rem;margin-left:auto;margin-right:auto}

/* ── Cart layout ── */
.wwm-cart-layout{
  display:grid;gap:2rem;align-items:start;
  grid-template-columns:1fr
}
@media(min-width:1024px){
  .wwm-cart-layout{grid-template-columns:1fr 22rem}
}

/* Cart items column */
.wwm-cart-items{display:flex;flex-direction:column;gap:.75rem}

/* Single cart item row */
.wwm-cart-item{
  display:grid;align-items:center;gap:1rem;
  grid-template-columns:5rem 1fr auto auto auto;
  background:oklch(var(--b2));
  border:1px solid oklch(var(--bc)/.08);
  border-radius:var(--rounded-box,1rem);
  padding:1rem;
  transition:border-color .2s
}
@media(max-width:639px){
  .wwm-cart-item{grid-template-columns:4rem 1fr;grid-template-rows:auto auto auto}
}

/* Thumbnail */
.wwm-cart-item-img{
  width:5rem;height:5rem;flex-shrink:0;
  background:oklch(var(--b3));
  border-radius:.625rem;overflow:hidden;
  display:flex;align-items:center;justify-content:center
}
.wwm-cart-item-img img{
  width:100%;height:100%;
  object-fit:contain;object-position:center;padding:.375rem
}

/* Details */
.wwm-cart-item-details{min-width:0}
.wwm-cart-item-name{
  font-weight:700;font-size:.9375rem;
  color:oklch(var(--bc));margin:0 0 .25rem;
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis
}
.wwm-cart-item-price{
  font-size:.875rem;color:oklch(var(--p));
  font-weight:600;margin:0
}

/* Quantity */
.wwm-cart-item-qty .quantity{
  display:flex;align-items:center;
  border:1px solid oklch(var(--bc)/.15);
  border-radius:var(--rounded-btn,.5rem);
  overflow:hidden;background:oklch(var(--b3))
}
.wwm-cart-item-qty .quantity input[type=number]{
  width:2.75rem;height:2.25rem;text-align:center;
  background:transparent;border:none;outline:none;
  font-weight:700;font-size:.9375rem;color:oklch(var(--bc))
}
.wwm-cart-item-qty .qty-btn,
.wwm-cart-item-qty .quantity .minus,
.wwm-cart-item-qty .quantity .plus{
  width:2rem;height:2.25rem;display:flex;align-items:center;
  justify-content:center;background:oklch(var(--b3));
  cursor:pointer;font-size:1rem;font-weight:700;
  border:none;color:oklch(var(--bc)/.7);transition:background .2s
}
.wwm-cart-item-qty .quantity .minus:hover,
.wwm-cart-item-qty .quantity .plus:hover{background:oklch(var(--p)/.15);color:oklch(var(--p))}

/* Subtotal */
.wwm-cart-item-subtotal{
  font-weight:800;font-size:1rem;
  color:oklch(var(--p));white-space:nowrap;
  text-align:right;min-width:4rem
}
.wwm-cart-item-subtotal .amount{font-weight:800;color:oklch(var(--p))}

/* Remove */
.wwm-cart-item-remove a.remove{
  display:flex;align-items:center;justify-content:center;
  width:2rem;height:2rem;border-radius:9999px;
  color:oklch(var(--bc)/.35)!important;
  transition:color .2s,background .2s;text-decoration:none
}
.wwm-cart-item-remove a.remove:hover{
  color:oklch(var(--er))!important;
  background:oklch(var(--er)/.1)
}

/* Actions row (coupon + update) */
.wwm-cart-actions{
  display:flex;align-items:center;justify-content:space-between;
  gap:1rem;flex-wrap:wrap;padding-top:.5rem
}
.wwm-coupon{display:flex;align-items:center;gap:.5rem;flex:1;min-width:0}
.wwm-coupon .input{
  flex:1;min-width:0;height:2.5rem;
  background:oklch(var(--b2));
  border:1px solid oklch(var(--bc)/.2);
  border-radius:var(--rounded-btn,.5rem);
  padding:0 .875rem;font-size:.875rem;color:oklch(var(--bc));
  outline:none;transition:border-color .2s
}
.wwm-coupon .input:focus{border-color:oklch(var(--p))}
.wwm-coupon .btn,.wwm-cart-actions .btn{
  height:2.5rem;min-height:2.5rem;
  font-size:.8125rem;white-space:nowrap
}

/* Cart summary sidebar */
.wwm-cart-summary{
  position:sticky;top:5rem
}
.wwm-cart-summary .cart_totals{
  background:oklch(var(--b2));
  border:1px solid oklch(var(--bc)/.1);
  border-radius:var(--rounded-box,1rem);
  padding:1.5rem
}
.wwm-cart-summary .cart_totals h2{
  font-size:1.125rem;font-weight:800;
  margin-bottom:1.25rem;padding-bottom:.875rem;
  border-bottom:1px solid oklch(var(--bc)/.08)
}
.wwm-cart-summary .shop_table{width:100%;border-collapse:collapse}
.wwm-cart-summary .shop_table tr{border-bottom:1px solid oklch(var(--bc)/.06)}
.wwm-cart-summary .shop_table tr:last-child{border-bottom:none}
.wwm-cart-summary .shop_table th,
.wwm-cart-summary .shop_table td{padding:.625rem 0;font-size:.9375rem;vertical-align:middle}
.wwm-cart-summary .shop_table th{color:oklch(var(--bc)/.6);font-weight:500;width:55%}
.wwm-cart-summary .shop_table td{text-align:right;font-weight:600}
.wwm-cart-summary .order-total th{color:oklch(var(--bc));font-weight:700}
.wwm-cart-summary .order-total td{font-size:1.25rem;font-weight:900;color:oklch(var(--p))}
.wwm-cart-summary .order-total .amount{color:oklch(var(--p))}

/* Checkout button */
.wwm-cart-summary .wc-proceed-to-checkout{margin-top:1.25rem}
.wwm-cart-summary .wc-proceed-to-checkout .checkout-button{
  display:flex;align-items:center;justify-content:center;width:100%;
  padding:.875rem 1.5rem;background:oklch(var(--p));color:oklch(var(--pc));
  border:none;border-radius:var(--rounded-btn,.5rem);
  font-weight:700;font-size:1rem;cursor:pointer;
  text-decoration:none;transition:opacity .2s;gap:.5rem
}
.wwm-cart-summary .wc-proceed-to-checkout .checkout-button:hover{opacity:.85}

/* Shipping calculator */
.wwm-cart-summary .shipping-calculator-button{
  font-size:.8125rem;color:oklch(var(--p));cursor:pointer;
  background:none;border:none;padding:0;text-decoration:underline
}
.wwm-cart-summary .shipping-calculator-form{margin-top:.75rem}
.wwm-cart-summary .shipping-calculator-form p{margin-bottom:.5rem}
.wwm-cart-summary .shipping-calculator-form select,
.wwm-cart-summary .shipping-calculator-form input{
  width:100%;padding:.5rem .75rem;
  background:oklch(var(--b3));border:1px solid oklch(var(--bc)/.2);
  border-radius:var(--rounded-btn,.5rem);color:oklch(var(--bc));
  font-size:.875rem;outline:none;margin-bottom:.5rem
}
.wwm-cart-summary .shipping-calculator-form .button{
  padding:.5rem 1rem;background:oklch(var(--b3));color:oklch(var(--bc));
  border:1px solid oklch(var(--bc)/.2);border-radius:var(--rounded-btn,.5rem);
  font-size:.875rem;font-weight:600;cursor:pointer;transition:background .2s
}

/* Shipping options */
.wwm-cart-summary .woocommerce-shipping-methods{list-style:none;padding:0;margin:.5rem 0}
.wwm-cart-summary .woocommerce-shipping-methods li{
  padding:.375rem 0;font-size:.875rem;display:flex;align-items:center;gap:.5rem
}

/* Empty cart */
.empty-cart-page{display:flex;flex-direction:column;align-items:center;gap:1rem}
.empty-cart-icon{
  width:5rem;height:5rem;display:flex;align-items:center;justify-content:center;
  background:oklch(var(--p)/.1);border-radius:9999px;color:oklch(var(--p));
  margin-bottom:.5rem
}
.empty-cart-heading{font-size:1.5rem;font-weight:800;margin:0}
.empty-cart-sub{color:oklch(var(--bc)/.5);margin:0}
.empty-cart-page .btn{margin-top:.5rem}

.woocommerce-cart .cart-empty{
  text-align:center;padding:4rem 1rem;color:oklch(var(--bc)/.5);
  font-size:1.125rem
}
.woocommerce-cart .return-to-shop{text-align:center;margin-top:1rem}
.woocommerce-cart .return-to-shop .button{
  display:inline-flex;align-items:center;gap:.5rem;
  padding:.75rem 1.5rem;background:oklch(var(--p));color:oklch(var(--pc));
  border-radius:var(--rounded-btn,.5rem);font-weight:700;
  text-decoration:none;transition:opacity .2s
}
.woocommerce-cart .return-to-shop .button:hover{opacity:.85}

/* ══════════════════════════════════════════
   CART PAGE — WooCommerce Cart Block + classic
   ══════════════════════════════════════════ */

/* Cart page wrapper — no max-width so block layout fills naturally */
.wwm-cart-wrap{width:100%}

/* ── Suppress cart notices + update cart button (all forms) ── */
.woocommerce-cart .woocommerce-message,
.woocommerce-cart .woocommerce-info,
.wc-block-components-notice-banner:not(.wc-block-components-notice-banner--error),
.wc-block-components-snackbar-list__container,
.wc-block-cart__notices .wc-block-components-notice-banner,
/* "Update cart" button — hidden, JS auto-updates instead */
button[name=update_cart],
input[name=update_cart],
.wc-block-cart-items__footer,
.woocommerce-cart-form .actions{display:none!important}

/* ── blockUI overlay — dark not white ── */
.blockUI.blockOverlay{background:oklch(var(--b1))!important;opacity:.55!important}
.blockUI.blockMsg{display:none!important}

/* ════════════════════════════════════════
   CART BLOCK items table — card rows
   ════════════════════════════════════════ */

/* Strip loading skeleton opacity */
.wp-block-woocommerce-cart.is-loading{opacity:1!important}

/* Hide column headers */
.wc-block-cart-items__header{display:none!important}

/* Table: separate borders so we can round each row */
.wc-block-cart-items{
  width:100%;border-collapse:separate;
  border-spacing:0 .75rem;background:transparent
}

/* Each row — card */
.wc-block-cart-items__row td{
  background:oklch(var(--b2));
  border-top:1px solid oklch(var(--bc)/.08);
  border-bottom:1px solid oklch(var(--bc)/.08);
  padding:.875rem .75rem;vertical-align:middle
}
.wc-block-cart-items__row td:first-child{
  border-left:1px solid oklch(var(--bc)/.08);
  border-radius:var(--rounded-box,1rem) 0 0 var(--rounded-box,1rem);
  padding-left:1rem
}
.wc-block-cart-items__row td:last-child{
  border-right:1px solid oklch(var(--bc)/.08);
  border-radius:0 var(--rounded-box,1rem) var(--rounded-box,1rem) 0;
  padding-right:1rem
}

/* Thumbnail cell */
.wc-block-cart-item__image a,.wc-block-cart-item__image img{display:block}
.wc-block-cart-item__image img{
  width:5rem;height:5rem;
  object-fit:contain;object-position:center;
  border-radius:.625rem;
  background:oklch(var(--b3));
  padding:.375rem
}

/* Product info cell */
.wc-block-cart-item__product-name,.wc-block-cart-item__product-name a{
  font-weight:700;font-size:.9375rem;
  color:oklch(var(--bc));text-decoration:none
}
.wc-block-cart-item__product-name a:hover{color:oklch(var(--p))}

.wc-block-cart-item__individual-price,
.wc-block-cart-item__product-metadata{
  font-size:.8125rem;color:oklch(var(--bc)/.45);margin:.2rem 0
}

/* Remove link — red pill */
.wc-block-cart-item__remove-link{
  display:inline-flex;align-items:center;gap:.25rem;
  margin-top:.5rem;padding:.25rem .625rem;
  background:oklch(var(--er)/.12);color:oklch(var(--er))!important;
  border-radius:9999px;font-size:.75rem;font-weight:600;
  text-decoration:none!important;cursor:pointer;
  border:none;transition:background .2s
}
.wc-block-cart-item__remove-link:hover{background:oklch(var(--er)/.22)!important}
.wc-block-cart-item__remove-link svg{display:none}

/* Quantity selector — target both old and new WooCommerce Block class names */
.wc-block-quantity-selector,
.wc-block-components-quantity-selector{
  display:inline-flex!important;align-items:center!important;
  border:1px solid oklch(var(--bc)/.15)!important;
  border-radius:.625rem!important;overflow:hidden!important;
  background:oklch(var(--b3))!important;margin:.5rem 0!important
}
.wc-block-quantity-selector input,
.wc-block-quantity-selector input[type=number],
.wc-block-components-quantity-selector input,
.wc-block-components-quantity-selector input[type=number],
.wc-block-components-quantity-selector__value{
  width:2.75rem!important;height:2.25rem!important;text-align:center!important;
  background:oklch(var(--b2))!important;border:none!important;outline:none!important;
  font-weight:700!important;font-size:.9375rem!important;
  color:oklch(var(--bc))!important;
  -moz-appearance:textfield!important;appearance:textfield!important;
  box-shadow:none!important
}
/* Kill ALL native number spinners */
.wc-block-quantity-selector input::-webkit-inner-spin-button,
.wc-block-quantity-selector input::-webkit-outer-spin-button,
.wc-block-components-quantity-selector input::-webkit-inner-spin-button,
.wc-block-components-quantity-selector input::-webkit-outer-spin-button,
.wc-block-components-quantity-selector__value::-webkit-inner-spin-button,
.wc-block-components-quantity-selector__value::-webkit-outer-spin-button{
  -webkit-appearance:none!important;appearance:none!important;margin:0!important;display:none!important
}
.wc-block-quantity-selector__button,
.wc-block-quantity-selector button,
.wc-block-components-quantity-selector__button,
.wc-block-components-quantity-selector button{
  width:2rem!important;height:2.25rem!important;background:transparent!important;
  border:none!important;color:oklch(var(--bc)/.7)!important;cursor:pointer!important;
  font-size:1.125rem!important;font-weight:700!important;display:flex!important;
  align-items:center!important;justify-content:center!important;
  transition:color .2s,background .2s!important;padding:0!important;line-height:1!important;
  box-shadow:none!important
}
.wc-block-quantity-selector__button:hover,
.wc-block-quantity-selector button:hover,
.wc-block-components-quantity-selector__button:hover,
.wc-block-components-quantity-selector button:hover{
  color:oklch(var(--p))!important;background:oklch(var(--p)/.1)!important
}
/* max hint below qty */
.wc-block-cart-item__quantity::after{
  content:'max 10';display:block;
  font-size:.625rem;color:oklch(var(--bc)/.3);
  text-transform:uppercase;letter-spacing:.04em;
  margin-top:.125rem
}

/* Total cell */
.wc-block-cart-item__total,
.wc-block-cart-item__prices{
  font-weight:800;font-size:1rem;
  color:oklch(var(--p));white-space:nowrap;text-align:right
}
.wc-block-cart-item__total .woocommerce-Price-amount,
.wc-block-cart-item__prices .woocommerce-Price-amount{
  font-weight:800;color:oklch(var(--p))
}

/* ── Sidebar / order summary ── */
.wc-block-components-totals-wrapper{
  background:oklch(var(--b2));
  border:1px solid oklch(var(--bc)/.1);
  border-radius:var(--rounded-box,1rem);
  padding:1.5rem;margin-top:0
}
.wc-block-components-order-summary-item,
.wc-block-components-totals-item{
  display:flex;align-items:center;
  justify-content:space-between;
  padding:.625rem 0;
  border-bottom:1px solid oklch(var(--bc)/.06);
  font-size:.9375rem
}
.wc-block-components-totals-item:last-child,
.wc-block-components-totals-footer-item{border-bottom:none}

.wc-block-components-totals-item__label,
.wc-block-components-totals-footer-item .wc-block-components-totals-item__label{
  color:oklch(var(--bc)/.55);font-weight:500
}
.wc-block-components-totals-footer-item .wc-block-components-totals-item__label{
  color:oklch(var(--bc));font-weight:700;font-size:1rem
}
.wc-block-components-totals-footer-item .wc-block-components-totals-item__value,
.wc-block-components-totals-footer-item .wc-block-components-totals-footer-item-tax-value{
  font-size:1.375rem;font-weight:900;color:oklch(var(--p))
}
.wc-block-components-totals-footer-item .woocommerce-Price-amount{
  font-size:1.375rem;font-weight:900;color:oklch(var(--p))
}

/* Coupon toggle */
.wc-block-components-totals-coupon__button,
.wc-block-components-panel__button{
  font-size:.875rem;color:oklch(var(--p));
  background:none;border:none;cursor:pointer;padding:.5rem 0
}

/* Coupon input */
.wc-block-components-totals-coupon__form{display:flex;gap:.5rem;margin-top:.5rem}
.wc-block-components-totals-coupon__form input{
  flex:1;height:2.5rem;padding:0 .875rem;
  background:oklch(var(--b3));border:1px solid oklch(var(--bc)/.2);
  border-radius:.625rem;color:oklch(var(--bc));font-size:.875rem;outline:none
}
.wc-block-components-totals-coupon__form input:focus{border-color:oklch(var(--p))}
.wc-block-components-totals-coupon__form button{
  height:2.5rem;padding:0 1rem;
  background:oklch(var(--b3));color:oklch(var(--bc)/.7);
  border:1px solid oklch(var(--bc)/.15);border-radius:.625rem;
  font-weight:600;font-size:.8125rem;cursor:pointer;transition:all .2s
}
.wc-block-components-totals-coupon__form button:hover{background:oklch(var(--b2))}

/* Checkout button */
.wc-block-cart__submit-container{margin-top:1.25rem}
.wc-block-cart__submit-button,
.wc-block-cart .checkout-button{
  display:flex!important;align-items:center;justify-content:center;
  width:100%!important;padding:.875rem 1.5rem!important;
  background:oklch(var(--p))!important;color:oklch(var(--pc))!important;
  border:none!important;border-radius:.75rem!important;
  font-weight:700!important;font-size:1rem!important;
  cursor:pointer;text-decoration:none!important;
  transition:opacity .2s,transform .15s
}
.wc-block-cart__submit-button:hover,.wc-block-cart .checkout-button:hover{
  opacity:.88;transform:translateY(-1px)
}

/* ── Checkout form (page.php) ── */
.woocommerce-checkout .col2-set{display:grid;gap:2rem;grid-template-columns:1fr}
@media(min-width:768px){.woocommerce-checkout .col2-set{grid-template-columns:1fr 1fr}}
.woocommerce-checkout #order_review_heading{
  font-size:1.125rem;font-weight:700;margin-bottom:1rem;margin-top:2rem
}
.woocommerce-checkout #order_review{
  background:oklch(var(--b2));border-radius:var(--rounded-box,1rem);
  padding:1.5rem;border:1px solid oklch(var(--bc)/.1)
}
.woocommerce #payment{
  background:oklch(var(--b2));border-radius:var(--rounded-box,1rem);
  padding:1.5rem;border:1px solid oklch(var(--bc)/.1);margin-top:1.5rem
}
.woocommerce #payment ul.payment_methods{list-style:none;padding:0;margin:0 0 1.5rem}
.woocommerce #payment ul.payment_methods li{
  padding:.75rem 0;border-bottom:1px solid oklch(var(--bc)/.08)
}
.woocommerce #payment ul.payment_methods li:last-child{border-bottom:none}
.woocommerce #payment .payment_box{
  background:oklch(var(--b3));border-radius:.5rem;padding:1rem;margin-top:.5rem;font-size:.875rem
}
.woocommerce #payment #place_order{
  display:block;width:100%;padding:.875rem;
  background:oklch(var(--p));color:oklch(var(--pc));
  border:none;border-radius:.75rem;font-weight:700;font-size:1rem;
  cursor:pointer;transition:opacity .2s
}
.woocommerce #payment #place_order:hover{opacity:.88}

/* Classic cart fallback (shortcode) */
.woocommerce a.remove{
  display:inline-flex;align-items:center;justify-content:center;
  width:1.875rem;height:1.875rem;border-radius:9999px;
  color:oklch(var(--er))!important;background:oklch(var(--er)/.12);
  font-size:1.125rem;font-weight:700;text-decoration:none;
  transition:background .2s,transform .15s;line-height:1
}
.woocommerce a.remove:hover{background:oklch(var(--er)/.25)!important;transform:scale(1.15)}

/* My account */
.woocommerce-account .woocommerce{display:grid;gap:2rem}
@media(min-width:768px){.woocommerce-account .woocommerce{grid-template-columns:14rem 1fr}}
.woocommerce-MyAccount-navigation ul{
  list-style:none;padding:0;margin:0;
  background:oklch(var(--b2));border-radius:var(--rounded-box,1rem);
  overflow:hidden;border:1px solid oklch(var(--bc)/.1)
}
.woocommerce-MyAccount-navigation li a{
  display:block;padding:.75rem 1.25rem;font-size:.9375rem;
  color:oklch(var(--bc)/.75);text-decoration:none;
  transition:color .2s,background .2s;
  border-bottom:1px solid oklch(var(--bc)/.06)
}
.woocommerce-MyAccount-navigation li a:hover,
.woocommerce-MyAccount-navigation li.is-active a{
  color:oklch(var(--p));background:oklch(var(--p)/.08)
}
.woocommerce-MyAccount-navigation li:last-child a{border-bottom:none}
.woocommerce-MyAccount-content{min-width:0}

/* My account page */
.woocommerce-account .woocommerce{display:grid;gap:2rem}
@media(min-width:768px){.woocommerce-account .woocommerce{grid-template-columns:14rem 1fr}}
.woocommerce-MyAccount-navigation ul{list-style:none;padding:0;margin:0;background:oklch(var(--b2));border-radius:var(--rounded-box,1rem);overflow:hidden;border:1px solid oklch(var(--bc)/.1)}
.woocommerce-MyAccount-navigation li a{display:block;padding:.75rem 1.25rem;font-size:.9375rem;color:oklch(var(--bc)/.75);text-decoration:none;transition:color .2s,background .2s;border-bottom:1px solid oklch(var(--bc)/.06)}
.woocommerce-MyAccount-navigation li a:hover,.woocommerce-MyAccount-navigation li.is-active a{color:oklch(var(--p));background:oklch(var(--p)/.08)}
.woocommerce-MyAccount-navigation li:last-child a{border-bottom:none}
.woocommerce-MyAccount-content{min-width:0}

/* WooCommerce form */
.woocommerce-input-wrapper input,.woocommerce-input-wrapper select,.woocommerce-input-wrapper textarea,
.woocommerce form .input-text,.woocommerce form select,.woocommerce form input{
  width:100%;padding:.75rem 1rem;
  background:oklch(var(--b2));border:1px solid oklch(var(--bc)/.2);
  border-radius:var(--rounded-btn,.5rem);color:oklch(var(--bc));
  transition:border-color .2s;outline:none;font-size:.9375rem
}
.woocommerce-input-wrapper input:focus,.woocommerce-input-wrapper select:focus,.woocommerce-input-wrapper textarea:focus,
.woocommerce form .input-text:focus{border-color:oklch(var(--p))}
.woocommerce form .form-row{margin-bottom:1.25rem}
.woocommerce form label{display:block;font-size:.875rem;font-weight:600;margin-bottom:.375rem;color:oklch(var(--bc)/.8)}
.woocommerce-page .woocommerce{padding:0}

/* WooCommerce ordering select */
.woocommerce-ordering select{
  background:oklch(var(--b2));border:1px solid oklch(var(--bc)/.2);
  border-radius:var(--rounded-btn,.5rem);color:oklch(var(--bc));
  padding:.5rem 2rem .5rem .75rem;font-size:.875rem;cursor:pointer;outline:none;
  appearance:none;-webkit-appearance:none;
  background-image:linear-gradient(45deg,transparent 50%,currentColor 50%),linear-gradient(135deg,currentColor 50%,transparent 50%);
  background-position:calc(100% - 14px) 50%,calc(100% - 10px) 50%;
  background-size:4px 4px,4px 4px;background-repeat:no-repeat
}
.woocommerce-result-count{font-size:.875rem;color:oklch(var(--bc)/.6)}

/* WooCommerce pagination */
.woocommerce-pagination ul{display:flex;gap:.5rem;list-style:none;padding:0;margin:2.5rem 0 0;justify-content:center}
.woocommerce-pagination ul li a,.woocommerce-pagination ul li span{
  display:inline-flex;align-items:center;justify-content:center;
  width:2.5rem;height:2.5rem;border-radius:var(--rounded-btn,.5rem);
  font-size:.875rem;font-weight:600;text-decoration:none;
  color:oklch(var(--bc)/.7);background:oklch(var(--b2));
  border:1px solid oklch(var(--bc)/.1);transition:all .2s
}
.woocommerce-pagination ul li a:hover{background:oklch(var(--b3));border-color:oklch(var(--p)/.3)}
.woocommerce-pagination ul li span.current{background:oklch(var(--p));border-color:oklch(var(--p));color:oklch(var(--pc))}

/* WooCommerce breadcrumb */
.woocommerce-breadcrumb{display:flex;align-items:center;flex-wrap:wrap;gap:.375rem;font-size:.8125rem;color:oklch(var(--bc)/.55);margin-bottom:1rem}
.woocommerce-breadcrumb a{color:oklch(var(--bc)/.55);text-decoration:none;transition:color .2s}
.woocommerce-breadcrumb a:hover{color:oklch(var(--p))}

/* ── Prose (rich text) ── */
.prose{font-size:1rem;line-height:1.75;color:oklch(var(--bc)/.85)}
.prose h1,.prose h2,.prose h3,.prose h4{font-weight:700;line-height:1.25;margin:1.5em 0 .75em;color:oklch(var(--bc))}
.prose h1{font-size:2rem}.prose h2{font-size:1.5rem}.prose h3{font-size:1.25rem}.prose h4{font-size:1.0625rem}
.prose p{margin:0 0 1em}
.prose ul,.prose ol{margin:1em 0;padding-left:1.5em}
.prose ul{list-style-type:disc}.prose ol{list-style-type:decimal}
.prose li{margin-bottom:.375em}
.prose a{color:oklch(var(--p));text-decoration:underline}
.prose a:hover{opacity:.8}
.prose strong{font-weight:700;color:oklch(var(--bc))}
.prose code{background:oklch(var(--b3));padding:.125rem .375rem;border-radius:.25rem;font-size:.875em;font-family:ui-monospace,monospace}
.prose pre{background:oklch(var(--b2));padding:1.5rem;border-radius:.75rem;overflow-x:auto;margin:1.5em 0}
.prose pre code{background:transparent;padding:0}
.prose blockquote{border-left:4px solid oklch(var(--p));padding:.5rem 1rem;color:oklch(var(--bc)/.7);font-style:italic;background:oklch(var(--p)/.05);border-radius:0 .5rem .5rem 0;margin:1.5em 0}
.prose table{width:100%;border-collapse:collapse;margin:1.5em 0;font-size:.9375rem}
.prose th,.prose td{border:1px solid oklch(var(--bc)/.1);padding:.625rem .875rem;text-align:left}
.prose th{background:oklch(var(--b2));font-weight:600}
.prose img{border-radius:.75rem;max-width:100%}
.prose hr{border:none;border-top:1px solid oklch(var(--bc)/.1);margin:2em 0}
.prose-lg{font-size:1.125rem;line-height:1.8}

/* ── Toast ── */
.wwm-toast{position:fixed;bottom:1.5rem;right:1.5rem;z-index:9999;display:flex;flex-direction:column;gap:.5rem;pointer-events:none}
.wwm-toast>*{pointer-events:auto}

/* ── Search form ── */
.search-form{display:flex;gap:.5rem;margin-top:1rem;max-width:28rem;margin-left:auto;margin-right:auto}
.search-form input[type=search]{
  flex:1;padding:.75rem 1rem;background:oklch(var(--b2));
  border:1px solid oklch(var(--bc)/.2);border-radius:var(--rounded-btn,.5rem);
  color:oklch(var(--bc));outline:none;transition:border-color .2s;font-size:.9375rem
}
.search-form input[type=search]:focus{border-color:oklch(var(--p))}
.search-form button{
  padding:.75rem 1.25rem;background:oklch(var(--p));color:oklch(var(--pc));
  border:none;border-radius:var(--rounded-btn,.5rem);font-weight:600;
  cursor:pointer;transition:opacity .2s;font-size:.9375rem
}
.search-form button:hover{opacity:.85}

/* ── Misc ── */
.woocommerce-loop-product__title{font-size:1rem!important;font-weight:700!important;padding:0!important}
.woocommerce ul.products li.product{float:none!important;width:auto!important;margin:0!important}
.woocommerce ul.products{display:contents!important}
.woocommerce .woocommerce-page{padding:0}
.w-full.add_to_cart_button{width:100%}

/* ── Skip to content ── */
.skip-link{
  position:absolute;top:-999px;left:1rem;z-index:9999;
  background:oklch(var(--p));color:oklch(var(--pc));
  padding:.5rem 1rem;border-radius:0 0 .5rem .5rem;
  font-weight:600;text-decoration:none;transition:top .2s
}
.skip-link:focus{top:0}

/* ── Responsive padding for container ── */
@media(max-width:639px){
  .section-pad{padding:3rem 0}
  .hero-title{font-size:2.125rem}
  .product-title{font-size:1.375rem}
  .cta-card{padding:2.5rem 1.25rem}
}
