/* ==========================================================================
   ORNAMAE - main stylesheet
   CaratLane-grade visual identity: deep purple primary, lavender bg,
   white cards with soft halo shadow, purple-to-pink gradient CTAs.
   Type stack:
     - DM Sans              -> all upright body + headings + UI
     - Cormorant Garamond   -> all italic display headlines (--font-italic)
     - Allura               -> collection tile titles only (--font-script)
   ========================================================================== */

/* Fonts are enqueued dynamically by inc/brand.php (driven by Customizer choices). */

/* ---- 1. Tokens (matched to CaratLane's measured palette) ---- */
:root{
  /* ===== BRAND PALETTE: Rose-Gold & Champagne (warm feminine luxe, "for her") =====
   * Same light-dominant CaratLane skeleton, but a warm rose family laddered
   * instead of purple. Blush + champagne do the soft-luxury layering; rose-
   * gold is the accent; muted rose-maroon the primary; gold + black anchor it.
   * The --orn-purple* names stay live but resolve to the rose system. */
  --orn-purple:#7A2A3A;        /* PRIMARY    - muted rose-maroon (buttons, price, active) */
  --orn-purple-deep:#4E1B26;   /* DEEP       - nav bar, mega menu, hover depth */
  --orn-purple-mid:#B76E79;    /* ACCENT     - rose-gold (links, hover, highlights, sale) */
  --orn-purple-soft:#F5E9E4;   /* BLUSH      - section bg, filters, chips, card-hover */
  --orn-purple-pale:#FCF6F3;   /* ultra-light blush-white */

  /* Semantic aliases (preferred names going forward) */
  --orn-rose-maroon:#7A2A3A;
  --orn-rose-maroon-deep:#4E1B26;
  --orn-rose-gold:#B76E79;
  --orn-blush:#F5E9E4;
  --orn-blush-pale:#FCF6F3;
  --orn-rich-black:#0A0908;     /* luxury contrast (footer/announce) */
  --orn-umber:#5E503F;          /* warm-brown accent (minor) */
  --orn-grullo:#A9927D;         /* soft warm neutral */
  --orn-stone:#EAE2D6;          /* warm stone - secondary soft section */
  --orn-champagne:#E3D5C3;
  --orn-sale:#B76E79;           /* rose-gold - sale %/urgency, used sparingly */

  /* Action accents */
  --orn-gold:#C9A44C;          /* refined gold - premium/coins/badges/offers (~5%) */
  --orn-gold-soft:#D9BE7E;     /* lighter gold for subtle highlights */
  --orn-green:#1F7A4D;         /* offers + verified */
  --orn-rose:#B76E79;          /* wishlist heart / Clear All / sale -> rose-gold */
  --orn-cream:#E3D5C3;         /* CHAMPAGNE BEIGE - announce bar, collection highlights */
  --orn-sand:#EAE2D6;          /* warm stone secondary surface */

  /* Surfaces & ink */
  --orn-bg:#FFFFFF;            /* canvas white; dusty-rose/champagne tint the sections */
  --orn-white:#FFFFFF;
  --orn-ink:#33363E;
  --orn-ink-strong:#2E2326;    /* warm charcoal text (modern, not pure black) */
  --orn-ink-soft:#6B6258;      /* warm grey */
  --orn-grey-400:#B7AFA6;
  --orn-grey-500:#8A8079;
  --orn-line:#EAE4DD;          /* warm hairline (not cold grey) */

  /* Signature CTA gradient - deep rose-maroon -> dusty rose-gold (matches the
     "SHARE YOUR STORY" button). THE uniform gradient for every primary button. */
  --orn-cta-gradient:linear-gradient(120deg,#5E1E29 0%,#7A2A3A 48%,#A85C68 100%);

  /* Typography */
  --font:'Plus Jakarta Sans','Noto Sans Devanagari','Helvetica Neue',Helvetica,Arial,sans-serif;
  --font-italic:'Cormorant Garamond','Times New Roman',Georgia,serif;  /* the ONE editorial italic accent */
  --font-script:'Allura','Cormorant Garamond',cursive;

  /* ---- FLUID TYPE SCALE ----------------------------------------------
   * Every step is a clamp(MIN, fluid, MAX) that scales SMOOTHLY between a
   * ~360px phone and a ~1280px desktop. No breakpoint jumps - text grows
   * and shrinks continuously with the viewport. This is the single source
   * of truth: change a step here and the whole site responds.
   *
   *   token        phone -> desktop   used for
   *   --fs-2xs      10px  -> 11.5px    eyebrows, pill chips, tiny labels
   *   --fs-xs       11px  -> 12.5px    dates, captions, meta
   *   --fs-sm       12.5px-> 14px      small body, sub-labels, accordions
   *   --fs-base     14px  -> 16px      body copy
   *   --fs-md       15px  -> 18px      emphasized body, variant value
   *   --fs-lg       17px  -> 22px      sub-headings
   *   --fs-xl       20px  -> 28px      section headings
   *   --fs-2xl      24px  -> 34px      price
   *   --fs-3xl      26px  -> 42px      product title
   *   --fs-display  28px  -> 52px      brand-band hero
   * ------------------------------------------------------------------- */
  --fs-3xs:     clamp(0.5rem,   0.451rem + 0.217vw, 0.625rem); /* 8 -> 10px  tiny badges */
  --fs-2xs:     clamp(0.625rem, 0.588rem + 0.163vw, 0.719rem);
  --fs-xs:      clamp(0.688rem, 0.651rem + 0.163vw, 0.781rem);
  --fs-sm:      clamp(0.781rem, 0.745rem + 0.163vw, 0.875rem);
  --fs-base:    clamp(0.875rem, 0.826rem + 0.217vw, 1rem);
  --fs-md:      clamp(0.938rem, 0.864rem + 0.326vw, 1.125rem);
  --fs-lg:      clamp(1.063rem, 0.940rem + 0.543vw, 1.375rem);
  --fs-xl:      clamp(1.25rem,  1.054rem + 0.870vw, 1.75rem);
  --fs-2xl:     clamp(1.5rem,   1.255rem + 1.087vw, 2.125rem);
  --fs-3xl:     clamp(1.625rem, 1.234rem + 1.739vw, 2.625rem);
  --fs-display: clamp(1.75rem,  1.163rem + 2.609vw, 3.25rem);

  /* Layout */
  --wrap:1840px;
  --radius:12px;
  --radius-card:14px;
  --radius-pill:999px;
  --shadow-card:0 0 10px rgba(153,152,163,.35);
  --shadow-card-hover:0 6px 24px -8px rgba(33,36,62,.18);
  --shadow-header:0 6px 24px -16px rgba(33,36,62,.25);

  /* Spacing */
  --space-1:4px;--space-2:8px;--space-3:12px;--space-4:16px;
  --space-5:24px;--space-6:32px;--space-7:48px;--space-8:64px;--space-9:96px;
}

/* ---- 2. Reset & base ---- */
*,*::before,*::after{box-sizing:border-box;}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%;}
html{ background:#ffffff; }
body{
  margin:0;
  font-family:var(--font);
  font-size:var(--fs-md);
  line-height:1.55;
  color:var(--orn-ink-strong);
  background:#ffffff;
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
}
/* Universal white surface for the main content wrapper on every template
   (home, shop, PLP, cart, checkout, account, blog). Tinted sections still
   set their own background; this only fills the page canvas. */
.orn-main,
#orn-main,
.woocommerce-page .orn-main{
  background:#ffffff;
}
img,svg,video{max-width:100%;height:auto;display:block;}
a{color:var(--orn-purple);text-decoration:none;transition:color .15s ease;}
a:hover{color:var(--orn-purple-mid);}
button{font-family:inherit;cursor:pointer;}
ul,ol{margin:0;padding:0;list-style:none;}
h1,h2,h3,h4,h5{
  font-family:var(--font);
  color:var(--orn-ink-strong);
  font-weight:600;
  line-height:1.25;
  margin:0 0 .5em;
  letter-spacing:-.005em;
}
h1{font-size:clamp(2rem,4vw,2.8rem);}
h2{font-size:clamp(1.6rem,2.8vw,2.2rem);}
h3{font-size:clamp(1.15rem,1.6vw,1.4rem);}
p{margin:0 0 1em;}

/* ---- 3. Layout utilities ---- */
.orn-wrap{max-width:var(--wrap);margin-inline:auto;padding-inline:clamp(16px,1.5vw,32px);}
.orn-section{padding-block:clamp(36px,5vw,72px);}
.orn-section--alt{background:var(--orn-purple-soft);}
.orn-section--ink{background:var(--orn-purple-deep);color:#D9C4A9;}
.orn-section--ink h1,.orn-section--ink h2,.orn-section--ink h3{color:#fff;}
.orn-eyebrow{
  font-family:var(--font);
  font-size:var(--fs-sm);
  font-weight:500;
  letter-spacing:.04em;
  color:var(--orn-purple);
  text-align:center;
  display:block;
  margin-bottom:6px;
}
.orn-section-head{text-align:center;margin-bottom:clamp(20px,3.5vw,40px);}
.orn-text-center{text-align:center;}
.orn-mt-6{margin-top:32px;}

/* ---- 4. Buttons ---- */
.orn-btn,
.orn-btn:visited,
input[type="submit"].button,
button.button,
a.button,
.button{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:8px;
  font-family:var(--font);
  font-weight:600;
  font-size:var(--fs-sm);
  letter-spacing:.02em;
  text-decoration:none;
  border-radius:var(--radius);
  padding:13px 28px;
  border:none;
  background:var(--orn-cta-gradient);   /* uniform rose CTA gradient */
  color:#fff;
  line-height:1;
  transition:all .2s ease;
  cursor:pointer;
}
.orn-btn:hover,.button:hover,button.button:hover,a.button:hover{
  filter:brightness(1.06);
  color:#fff;
}
.orn-btn--gradient{
  background:var(--orn-cta-gradient);
  border:none;
  color:#fff;
}
.orn-btn--gradient:hover{filter:brightness(1.05);}
.orn-btn--ghost{background:transparent;border-color:var(--orn-purple);color:var(--orn-purple);}
.orn-btn--ghost:hover{background:var(--orn-purple);color:#fff;}
.orn-btn--gold{background:var(--orn-gold);border-color:var(--orn-gold);color:var(--orn-purple);}
.orn-btn--gold:hover{background:#C9A44C;border-color:#C9A44C;}
.orn-btn--sm{padding:10px 20px;font-size:var(--fs-sm);}

/* ---- 5. Top promo strip (above logo) ---- */
.orn-announce{
  background:var(--orn-purple-deep);
  color:#fff;
  font-family:var(--font);
  font-size:var(--fs-sm);
  font-weight:500;
  text-align:center;
  padding:8px 16px;
  letter-spacing:.01em;
}
.orn-announce a{color:#fff;text-decoration:underline;}

/* ---- 6. Header (CaratLane: white top + purple sub-nav) ---- */
.orn-header{
  background:var(--orn-white);
  position:sticky;
  top:0;
  z-index:200;
  transition:box-shadow .2s ease;
}
.orn-header.is-scrolled{box-shadow:var(--shadow-header);}
.orn-header__top{
  display:flex;
  align-items:center;
  gap:30px;
  padding-block:22px;
  transition:padding .25s ease;
}
.orn-header.is-scrolled .orn-header__top{padding-block:14px;}

.orn-logo{flex:0 0 auto;}
.orn-logo a{
  display:inline-block;
  font-family:var(--font);
  font-size:var(--fs-3xl);
  font-weight:700;
  letter-spacing:.04em;
  color:var(--orn-purple);
  line-height:1;
}
.orn-logo a:hover{color:var(--orn-purple-deep);}

.orn-search{flex:1 1 auto;position:relative;max-width:720px;}
.orn-search input[type="search"]{
  width:100%;
  border:1px solid var(--orn-line);
  background:var(--orn-purple-soft);
  border-radius:var(--radius-pill);
  padding:14px 64px 14px 26px;
  font-family:var(--font);
  font-size:var(--fs-md);
  color:var(--orn-ink);
  transition:border-color .15s ease;
}
.orn-search input[type="search"]::placeholder{color:var(--orn-grey-500);}
.orn-search input[type="search"]:focus{
  outline:none;
  border-color:var(--orn-purple);
  box-shadow:0 0 0 3px rgba(79,50,103,.08);
}
.orn-search button{
  position:absolute;
  right:4px;top:50%;
  transform:translateY(-50%);
  width:36px;height:36px;
  border:none;
  border-radius:50%;
  background:var(--orn-purple);
  color:#fff;
  display:inline-flex;align-items:center;justify-content:center;
}
.orn-search button:hover{background:var(--orn-purple-deep);}

.orn-header__actions{display:flex;align-items:center;gap:18px;flex:0 0 auto;}
.orn-header__actions > a{
  position:relative;
  display:inline-flex;
  align-items:center;
  gap:6px;
  color:var(--orn-ink-strong);
  font-family:var(--font);
  font-size:var(--fs-sm);
  font-weight:500;
}
.orn-header__actions > a:hover{color:var(--orn-purple);}
.orn-header__actions svg{width:22px;height:22px;}
.orn-cart-badge{
  position:absolute;
  top:-6px;right:-10px;
  min-width:18px;height:18px;
  border-radius:9px;
  background:var(--orn-purple);
  color:#fff;
  font-size:var(--fs-2xs);
  font-weight:600;
  display:inline-flex;align-items:center;justify-content:center;
  padding:0 5px;
}

/* Purple sub-nav (CaratLane signature dark purple strip) */
.orn-nav{background:var(--orn-purple);}
.orn-nav__inner{display:flex;justify-content:center;}
.orn-nav ul{display:flex;gap:36px;flex-wrap:wrap;}
.orn-nav a{
  display:block;
  padding:14px 0;
  color:#fff;
  font-family:var(--font);
  font-size:var(--fs-base);
  font-weight:500;
  letter-spacing:.005em;
  position:relative;
}
.orn-nav a:hover{color:#fff;}
.orn-nav a::after{
  content:"";
  position:absolute;
  left:0;right:0;bottom:8px;
  height:2px;
  background:#fff;
  transform:scaleX(0);
  transition:transform .15s ease;
}
.orn-nav a:hover::after{transform:scaleX(1);}
.orn-nav .menu-item-has-children > a::before{
  content:"";
  display:inline-block;
  width:5px;height:5px;
  margin-right:6px;
  border-right:1.5px solid currentColor;
  border-bottom:1.5px solid currentColor;
  transform:rotate(45deg) translateY(-3px);
  opacity:.55;
}
.orn-nav .sub-menu{
  position:absolute;
  top:100%;left:50%;
  transform:translateX(-50%);
  min-width:220px;
  background:#fff;
  border-radius:12px;
  box-shadow:0 12px 32px -12px rgba(33,36,62,.18);
  padding:10px 0;
  display:none;
  z-index:50;
}
.orn-nav li{position:relative;}
.orn-nav li:hover > .sub-menu{display:block;}
.orn-nav .sub-menu a{
  display:block;
  padding:10px 22px;
  color:var(--orn-ink);
  font-weight:400;
  font-size:var(--fs-base);
}
.orn-nav .sub-menu a:hover{color:var(--orn-purple);background:var(--orn-purple-soft);}
.orn-nav .sub-menu a::after{display:none;}

/* ---- 7. Hero ---- */
.orn-hero{position:relative;background:var(--orn-purple-soft);}
.orn-hero__slide{
  position:relative;
  min-height:clamp(420px,55vw,620px);
  display:flex;
  align-items:center;
  overflow:hidden;
}
.orn-hero__bg{
  position:absolute;inset:0;
  background:linear-gradient(135deg,#FBF6EA 0%, #F5E9E4 55%, #EAD0D8 100%);
  z-index:0;
}
.orn-hero__decor{
  position:absolute;
  right:-120px;top:50%;
  transform:translateY(-50%);
  width:min(58vw,720px);
  height:min(58vw,720px);
  border-radius:50%;
  background:radial-gradient(circle at 35% 30%, rgba(255,255,255,.6) 0%, rgba(142,99,183,.18) 45%, rgba(142,99,183,.04) 70%, transparent 100%);
  z-index:1;
}
.orn-hero__inner{
  position:relative;
  z-index:2;
  max-width:600px;
  padding:48px 0;
}
.orn-hero__eyebrow{
  font-family:var(--font);
  font-size:var(--fs-sm);
  font-weight:500;
  color:var(--orn-purple);
  margin-bottom:14px;
}
.orn-hero h1{
  color:var(--orn-ink-strong);
  margin:0 0 14px;
  font-size:clamp(2.2rem,4.2vw,3.4rem);
  font-weight:700;
  letter-spacing:-.01em;
}
.orn-hero h1 em{font-style:italic;color:var(--orn-purple);}
.orn-hero__sub{
  font-size:clamp(15px,1.3vw,17px);
  max-width:480px;
  margin-bottom:28px;
  color:var(--orn-ink-soft);
}
.orn-hero__ctas{display:flex;gap:12px;flex-wrap:wrap;}

/* ---- 8. Trust strip ---- */
.orn-trustbar{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  background:var(--orn-purple-soft);
  padding:32px 0;
}
.orn-trustbar__item{
  text-align:center;
  padding:0 16px;
  display:flex;
  flex-direction:column;
  align-items:center;
}
.orn-trustbar__ico{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  width:44px;height:44px;
  border-radius:50%;
  background:var(--orn-purple-pale);
  color:var(--orn-purple);
  font-size:var(--fs-lg);
  margin-bottom:10px;
}
.orn-trustbar__t{
  font-family:var(--font);
  font-weight:500;
  font-size:var(--fs-base);
  color:var(--orn-ink-strong);
}
.orn-trustbar__s{
  font-size:var(--fs-sm);
  color:var(--orn-ink-soft);
  margin-top:2px;
}

/* ---- 9. Three-pillar editorial cards ---- */
.orn-pillars{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:20px;
}
.orn-pillar{
  position:relative;
  border-radius:18px;
  overflow:hidden;
  aspect-ratio:3/4;
  background:var(--orn-purple-soft);
  display:block;
  text-decoration:none;
  color:inherit;
  isolation:isolate;
}
.orn-pillar--gold{background:linear-gradient(155deg,#fff7e3 0%,#D9BE7E 55%,#b88a3e 100%);}
.orn-pillar--silver{background:linear-gradient(155deg,#f6f7f9 0%,#cdd2da 55%,#7a8290 100%);}
.orn-pillar--demi{background:linear-gradient(155deg,#fff3eb 0%,#f0d3b7 55%,#b76e79 100%);}
.orn-pillar__inner{
  position:absolute;
  inset:0;
  display:flex;
  flex-direction:column;
  justify-content:flex-end;
  padding:28px;
  color:#fff;
  background:linear-gradient(to top, rgba(78,27,38,.7) 0%, rgba(78,27,38,0) 55%);
}
.orn-pillar h3{
  color:#fff;
  font-size:clamp(1.8rem,2.6vw,2.4rem);
  margin:0 0 4px;
  font-weight:700;
  letter-spacing:-.01em;
}
.orn-pillar__sub{
  font-family:var(--font);
  font-size:var(--fs-sm);
  font-weight:500;
  opacity:.95;
  margin-bottom:14px;
}
.orn-pillar__link{
  display:inline-flex;
  align-items:center;
  gap:6px;
  font-family:var(--font);
  font-size:var(--fs-sm);
  font-weight:600;
  color:#fff;
}
.orn-pillar__link::after{content:"→";transition:transform .2s ease;}
.orn-pillar:hover .orn-pillar__link::after{transform:translateX(4px);}

/* ---- 10. Product card grid (no border + soft halo shadow) ---- */
.orn-products,
.woocommerce ul.products{
  display:grid !important;
  /* Auto-fill = boxes stay a sensible ~230-270px and the grid packs MORE
     per row on wide screens (5-6 cols), so each box is smaller - matches
     CaratLane density. Fewer cols only on narrow screens. */
  grid-template-columns:repeat(auto-fill, minmax(220px, 1fr)) !important;
  gap:20px 18px;
  list-style:none;
  margin:0;
  padding:0;
}
.orn-product,
.woocommerce ul.products li.product{
  position:relative;
  background:transparent;        /* CaratLane look: no card chrome */
  border-radius:0;
  overflow:visible;
  box-shadow:none;
  transition:transform .2s ease;
  list-style:none;
  margin:0 !important;
  width:auto !important;
  float:none !important;
  text-align:left !important;
}
.orn-product:hover,
.woocommerce ul.products li.product:hover{
  transform:none;
  box-shadow:none;
}
.orn-product__media,
.woocommerce ul.products li.product > a:first-child{
  display:block;
  position:relative;
  background:#FCF6F3;            /* very faint tint, not a heavy box */
  aspect-ratio:1/1;
  overflow:hidden;
  border-radius:10px;            /* rounded image only, not the whole card */
  transition:box-shadow .2s ease;
}
/* No border on the card; shadow appears ONLY on hover, on the image. */
.woocommerce ul.products li.product:hover > a:first-child,
.orn-product:hover .orn-product__media{
  box-shadow:0 8px 24px -10px rgba(33,36,62,0.22);
}
.orn-product__media img,
.woocommerce ul.products li.product img{
  width:100%;
  height:100%;
  object-fit:cover;
}

.orn-product__cat,
.woocommerce ul.products li.product .orn-product__cat{
  font-family:var(--font);
  font-size:var(--fs-xs);
  font-weight:500;
  color:var(--orn-grey-500);
  padding:10px 2px 0;
  display:block;
}
/* CaratLane order: PRICE first (bold), product NAME under it (grey, smaller).
   No side padding - text aligns to the image's left edge. */
.orn-product__price,
.woocommerce ul.products li.product .price{
  font-family:var(--font);
  font-size:var(--fs-sm);
  font-weight:700;
  color:var(--orn-ink-strong);
  padding:8px 2px 1px;
  display:block;
  margin:0;
  order:1;
}
.orn-product__price del,
.woocommerce ul.products li.product .price del{ font-size:var(--fs-xs); }
.orn-product__title,
.woocommerce ul.products li.product .woocommerce-loop-product__title,
.woocommerce ul.products li.product h2.woocommerce-loop-product__title{
  font-family:var(--font) !important;
  font-weight:400 !important;
  font-size:var(--fs-xs) !important;
  color:var(--orn-ink-soft) !important;
  margin:0 0 2px !important;
  padding:0 2px !important;
  line-height:1.35;
  order:2;
}
/* Make the card body a flex column so order: works (price above name). */
.woocommerce ul.products li.product{ display:flex; flex-direction:column; }
.woocommerce ul.products li.product > a:first-child{ order:0; }
.orn-product__wish,
.woocommerce ul.products li.product .onsale,
.orn-product__badge{ order:initial; }

/* Belt-and-braces: if any loop add-to-cart button / view-cart link still
   renders, hide it so it can't reserve empty space or show raw text. */
.woocommerce ul.products li.product .button.add_to_cart_button,
.woocommerce ul.products li.product a.add_to_cart_button,
.woocommerce ul.products li.product a.added_to_cart{
  display:none !important;
}
.orn-product__price ins,
.woocommerce ul.products li.product .price ins{
  font-weight:700;
  text-decoration:none;
  color:var(--orn-ink-strong);
  background:transparent;
}
.orn-product__price del,
.woocommerce ul.products li.product .price del{
  color:var(--orn-grey-500);
  font-weight:400;
  font-size:var(--fs-base);
  margin-right:8px;
  opacity:1;
}
.orn-product__price .orn-pct{
  color:var(--orn-green);
  font-weight:600;
  font-size:var(--fs-sm);
  margin-left:6px;
}

/* sale badge */
.woocommerce ul.products li.product .onsale,
.orn-product__badge{
  position:absolute;
  top:12px;left:12px;
  min-height:auto;
  background:var(--orn-gold) !important;
  color:var(--orn-purple) !important;
  font-family:var(--font);
  font-weight:600;
  font-size:var(--fs-xs);
  border-radius:var(--radius-pill);
  padding:4px 10px;
  margin:0 !important;
  line-height:1;
  border:none !important;
}

/* wishlist heart (visible on hover) */
.orn-product__wish{
  position:absolute;
  top:12px;right:12px;
  width:34px;height:34px;
  border-radius:50%;
  background:rgba(255,255,255,.9);
  border:none;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  color:var(--orn-ink);
  cursor:pointer;
  opacity:0;
  transition:opacity .2s ease, color .2s ease;
}
.orn-product:hover .orn-product__wish,
.woocommerce ul.products li.product:hover .orn-product__wish{opacity:1;}
.orn-product__wish:hover{color:var(--orn-rose);}
.orn-product__wish.is-active{color:var(--orn-rose);opacity:1;}
.orn-product__wish svg{width:18px;height:18px;}

/* Add to bag button in loop */
.woocommerce ul.products li.product .button{
  display:block;
  width:calc(100% - 32px) !important;
  margin:0 16px 16px !important;
  padding:11px 16px !important;
  background:var(--orn-purple) !important;
  color:#fff !important;
  border:1px solid var(--orn-purple) !important;
  border-radius:var(--radius) !important;
  font-family:var(--font) !important;
  font-weight:500 !important;
  font-size:var(--fs-sm) !important;
}
.woocommerce ul.products li.product .button:hover{
  background:var(--orn-purple-deep) !important;
  border-color:var(--orn-purple-deep) !important;
}

/* ---- 11. Brand promise band ---- */
.orn-promise{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:34px;
  text-align:center;
}
.orn-promise__item h3{margin:14px 0 8px;color:#fff;font-size:1.4rem;}
.orn-promise__item p{color:#D9C4A9;font-size:var(--fs-base);max-width:36ch;margin-inline:auto;}
.orn-promise__ico{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  width:54px;height:54px;
  border-radius:50%;
  border:2px solid var(--orn-gold);
  color:var(--orn-gold);
  font-family:var(--font);
  font-size:var(--fs-lg);
  font-weight:700;
}

/* ---- 12. Reviews (homepage testimonials) ---- */
.orn-reviews{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:20px;
}
.orn-review{
  background:#fff;
  border-radius:var(--radius-card);
  padding:24px;
  box-shadow:var(--shadow-card);
}
.orn-review__stars{
  color:var(--orn-gold);
  font-size:var(--fs-md);
  margin-bottom:10px;
}
.orn-review p{
  font-size:var(--fs-md);
  color:var(--orn-ink);
  line-height:1.6;
  margin:0 0 14px;
}
.orn-review__name{
  font-family:var(--font);
  font-weight:600;
  color:var(--orn-purple);
  font-size:var(--fs-sm);
}

/* ---- 13. Newsletter ---- */
.orn-news{
  text-align:center;
  max-width:560px;
  margin-inline:auto;
}
.orn-news form{display:flex;gap:8px;margin-top:18px;flex-wrap:wrap;justify-content:center;}
.orn-news input[type="email"]{
  flex:1 1 240px;
  border:1px solid var(--orn-line);
  background:#fff;
  border-radius:var(--radius-pill);
  padding:12px 22px;
  font-family:var(--font);
  font-size:var(--fs-base);
}
.orn-news input[type="email"]:focus{
  outline:none;border-color:var(--orn-purple);
  box-shadow:0 0 0 3px rgba(79,50,103,.08);
}

/* ---- 14. Footer ---- */
.orn-footer{background:var(--orn-purple-deep);color:rgba(255,255,255,.86);padding-block:60px 0;font-family:var(--font);}
.orn-footer a{color:rgba(255,255,255,.86);}
.orn-footer a:hover{color:#fff;}
.orn-footer__cols{
  display:grid;
  grid-template-columns:1.4fr 1fr 1fr 1fr;
  gap:32px;
}
.orn-footer__title{
  font-family:var(--font);
  font-weight:600;
  font-size:var(--fs-sm);
  color:#fff;
  margin:0 0 16px;
}
.orn-footer ul{display:flex;flex-direction:column;gap:9px;font-size:var(--fs-base);}
.orn-footer__intro{font-size:var(--fs-base);max-width:34ch;margin:0 0 16px;}
.orn-footer__contact{font-size:var(--fs-base);line-height:1.7;color:#fff;}
.orn-footer__social{display:flex;gap:10px;margin-top:18px;}
.orn-footer__social a{
  width:36px;height:36px;
  border:1px solid rgba(255,255,255,.18);
  border-radius:50%;
  display:inline-flex;align-items:center;justify-content:center;
  font-size:var(--fs-sm);
}
.orn-footer__social a:hover{border-color:#fff;background:rgba(255,255,255,.08);}
.orn-footer__bar{
  border-top:1px solid rgba(255,255,255,.08);
  margin-top:40px;
  padding:20px 0;
  text-align:center;
  font-size:var(--fs-sm);
}
.orn-payicons{
  display:flex;gap:10px;
  justify-content:center;
  margin-top:10px;
  font-size:var(--fs-xs);
  opacity:.7;
}
.orn-payicons span{
  border:1px solid rgba(255,255,255,.18);
  border-radius:4px;
  padding:3px 8px;
}

/* ---- 15. Responsive ---- */
@media (max-width:1024px){
  .orn-products,.woocommerce ul.products{grid-template-columns:repeat(3,1fr);}
  .orn-footer__cols{grid-template-columns:1fr 1fr;}
}
@media (max-width:782px){
  .orn-header__top{flex-wrap:wrap;gap:14px;}
  .orn-search{order:3;flex-basis:100%;max-width:none;}
  .orn-nav ul{gap:18px;overflow-x:auto;flex-wrap:nowrap;padding:0 16px 4px;}
  .orn-products,.woocommerce ul.products{grid-template-columns:repeat(2,1fr);gap:14px;}
  .orn-pillars{grid-template-columns:1fr;}
  .orn-trustbar{grid-template-columns:1fr 1fr;gap:20px;}
  .orn-promise,.orn-reviews{grid-template-columns:1fr;}
}
@media (max-width:520px){
  .orn-products,.woocommerce ul.products{grid-template-columns:repeat(2,1fr);}
  .orn-header__actions > a span{display:none;}
}

/* ==========================================================================
   18. Mega-menu (Batch 3) - 11-item nav, full-width 4-column dropdowns,
       2 promo tiles per panel, For Her/Him/Kids recipient bar
   ========================================================================== */
.orn-nav--mega .orn-nav__inner{position:relative;}

.orn-mega-nav{
  display:flex;
  gap:26px;
  flex-wrap:nowrap;
  justify-content:center;
  align-items:center;
  list-style:none;
  margin:0;
  padding:0;
}
.orn-mega-item{position:static;}
.orn-mega-item.is-simple{position:relative;}

.orn-nav .orn-mega-item__link,
.orn-mega-item__link{
  display:inline-flex;
  align-items:center;
  gap:4px;
  padding:14px 0;
  color:#fff;
  font-size:var(--fs-md);
  font-weight:600;
  letter-spacing:.03em;
  position:relative;
  transition:color .15s ease;
  text-transform:none;
}
.orn-nav .orn-mega-item__link::after,
.orn-mega-item__link::after{display:none !important;}
.orn-mega-item__link:hover,
.orn-mega-item:hover > .orn-mega-item__link,
.orn-mega-item:focus-within > .orn-mega-item__link{color:#fff;}
.orn-mega-item__caret{
  font-size:var(--fs-3xs);
  opacity:.7;
  transform:translateY(-1px);
  transition:transform .2s ease,opacity .2s ease;
}
.orn-mega-item:hover > .orn-mega-item__link .orn-mega-item__caret{transform:translateY(0) rotate(180deg);opacity:1;}

/* Active item underline (hover state) */
.orn-mega-item:hover > .orn-mega-item__link::before{
  content:"";
  position:absolute;
  left:0;right:0;
  bottom:0;
  height:2px;
  background:#fff;
  border-radius:2px;
}

/* Dropdown panel - full-width below the nav */
.orn-mega-panel{
  position:absolute;
  left:0;right:0;
  top:100%;
  background:#fff;
  color:var(--orn-ink);
  box-shadow:0 24px 48px -16px rgba(33,36,62,.22);
  border-top:1px solid var(--orn-line);
  opacity:0;
  visibility:hidden;
  transform:translateY(4px);
  transition:opacity .15s ease,transform .15s ease,visibility .15s ease;
  z-index:50;
  pointer-events:none;
}
.orn-mega-item.has-mega:hover > .orn-mega-panel,
.orn-mega-item.has-mega:focus-within > .orn-mega-panel{
  opacity:1;
  visibility:visible;
  transform:translateY(0);
  pointer-events:auto;
}

.orn-mega-panel__inner{
  display:grid;
  grid-template-columns:minmax(0,1fr) 260px;
  gap:36px;
  padding-block:34px 26px;
}

.orn-mega-panel__cols{
  display:grid;
  grid-template-columns:repeat(4,minmax(0,1fr));
  gap:32px;
}
.orn-mega-col__title{
  font-size:var(--fs-base);
  letter-spacing:.08em;
  text-transform:uppercase;
  color:var(--orn-purple);
  font-weight:600;
  margin:0 0 14px;
  line-height:1.2;
}
.orn-mega-col__list{
  display:flex;
  flex-direction:column;
  gap:2px;
  margin:0;padding:0;
  list-style:none;
}
.orn-mega-col__list li{margin:0;}
.orn-mega-col__list a{
  display:block;
  padding:5px 0;
  color:var(--orn-ink);
  font-size:var(--fs-md);
  font-weight:400;
  line-height:1.35;
  text-decoration:none;
  transition:color .12s ease,padding-left .12s ease;
}
.orn-mega-col__list a:hover{
  color:var(--orn-purple);
  padding-left:4px;
}

/* Right column - 2 promo tiles */
.orn-mega-panel__promos{
  display:grid;
  grid-template-columns:1fr;
  gap:12px;
  align-content:start;
}
.orn-mega-promo{
  display:flex;
  flex-direction:column;
  gap:4px;
  padding:18px 20px;
  border-radius:var(--radius-card);
  color:var(--orn-ink-strong);
  text-decoration:none;
  transition:transform .15s ease,box-shadow .15s ease;
  min-height:108px;
}
.orn-mega-promo:hover{
  transform:translateY(-2px);
  box-shadow:var(--shadow-card-hover);
  color:var(--orn-ink-strong);
}
.orn-mega-promo__title{
  font-size:var(--fs-md);
  font-weight:600;
  line-height:1.25;
  color:var(--orn-ink-strong);
}
.orn-mega-promo__sub{
  font-size:var(--fs-sm);
  color:var(--orn-ink-soft);
  line-height:1.4;
  margin-top:2px;
}
.orn-mega-promo__cta{
  font-size:var(--fs-sm);
  font-weight:600;
  color:var(--orn-purple);
  margin-top:auto;
  letter-spacing:.02em;
}

/* Bottom recipient pill bar (For Her / For Him / For Kids) */
.orn-mega-panel__recipients{
  grid-column:1 / -1;
  display:flex;
  flex-wrap:wrap;
  gap:8px;
  padding-top:18px;
  margin-top:4px;
  border-top:1px solid var(--orn-line);
}
.orn-mega-recipient{
  display:inline-flex;
  align-items:center;
  padding:8px 18px;
  background:var(--orn-purple-soft);
  color:var(--orn-purple);
  border-radius:var(--radius-pill);
  font-size:var(--fs-base);
  font-weight:600;
  letter-spacing:.03em;
  text-decoration:none;
  transition:background .15s ease,color .15s ease;
}
.orn-mega-recipient:hover{
  background:var(--orn-purple);
  color:#fff;
}

/* Simple "More" dropdown - narrow link list, right-aligned */
.orn-mega-panel--simple{
  position:absolute;
  left:auto;right:0;top:100%;
  width:240px;
  border-top:none;
  border-radius:0 0 var(--radius-card) var(--radius-card);
  padding:10px 0;
  box-shadow:0 16px 32px -10px rgba(33,36,62,.18);
}
.orn-mega-item.is-simple:hover > .orn-mega-panel--simple,
.orn-mega-item.is-simple:focus-within > .orn-mega-panel--simple{
  opacity:1;
  visibility:visible;
  transform:translateY(0);
  pointer-events:auto;
}
.orn-mega-simple{
  list-style:none;
  margin:0;padding:0;
}
.orn-mega-simple a{
  display:block;
  padding:9px 22px;
  color:var(--orn-ink);
  font-size:var(--fs-sm);
  text-decoration:none;
}
.orn-mega-simple a:hover{
  background:var(--orn-purple-soft);
  color:var(--orn-purple);
}

/* Tablet: condense */
@media (max-width:1100px){
  .orn-mega-nav{gap:18px;}
  .orn-mega-item__link{font-size:var(--fs-base);}
  .orn-mega-panel__inner{grid-template-columns:1fr;gap:24px;}
  .orn-mega-panel__promos{grid-template-columns:repeat(2,1fr);}
}

/* Mobile: hide mega panels, keep nav scrollable */
@media (max-width:782px){
  .orn-mega-nav{
    gap:18px;
    overflow-x:auto;
    flex-wrap:nowrap;
    -webkit-overflow-scrolling:touch;
    padding:0 16px 4px;
    justify-content:flex-start;
  }
  .orn-mega-item__caret{display:none;}
  .orn-mega-panel,
  .orn-mega-panel--simple{display:none;}
}

/* ==========================================================================
   19. PLP (Batch 4) - faceted shop listing
   ========================================================================== */

.orn-plp{padding-block:clamp(20px,3vw,40px);}
.orn-plp-head{margin-bottom:18px;}
.orn-plp-breadcrumb{
  font-size:var(--fs-sm);
  color:var(--orn-ink-soft);
  letter-spacing:.02em;
  margin-bottom:10px;
}
.orn-plp-breadcrumb a{color:var(--orn-ink-soft);}
.orn-plp-breadcrumb a:hover{color:var(--orn-purple);}
.orn-plp-breadcrumb__sep{margin:0 6px;opacity:.5;}
/* Title + design-count on one baseline (CaratLane "Jewellery 11484 Designs") */
.orn-plp-title-row{
  display:flex;
  align-items:baseline;
  gap:10px;
  flex-wrap:wrap;
  margin:0 0 12px;
}
.orn-plp-title{
  font-size:var(--fs-xl);
  font-weight:600;
  margin:0;
  letter-spacing:-.01em;
}
.orn-plp-designs{
  font-size:var(--fs-sm);
  font-weight:500;
  color:var(--orn-ink-soft);
}
/* facet option count, right-aligned + muted */
.orn-plp-facet__count{
  font-size:var(--fs-xs);
  color:var(--orn-grey-500);
  margin-left:auto;
  flex-shrink:0;
}

/* Quick chip rail (All / New / Bestseller / Fast Delivery / Sale) */
.orn-plp-chips{
  display:flex;
  flex-wrap:wrap;
  gap:8px;
  padding:6px 0 4px;
  margin-bottom:8px;
}
.orn-plp-chip{
  display:inline-flex;
  align-items:center;
  padding:7px 16px;
  border-radius:var(--radius-pill);
  background:var(--orn-white);
  border:1px solid var(--orn-line);
  color:var(--orn-ink);
  font-size:var(--fs-sm);
  font-weight:500;
  letter-spacing:.02em;
  text-decoration:none;
  transition:background .12s ease,border-color .12s ease,color .12s ease;
}
.orn-plp-chip:hover{border-color:var(--orn-purple-mid);color:var(--orn-purple);}
.orn-plp-chip.is-active{
  background:var(--orn-purple);
  border-color:var(--orn-purple);
  color:#fff;
}

/* Selected filters bar (below chips) */
.orn-plp-selected{
  display:flex;
  flex-wrap:wrap;
  gap:8px;
  padding:12px 14px;
  background:var(--orn-purple-soft);
  border-radius:var(--radius-card);
  margin-bottom:18px;
}
.orn-plp-selected__chip{
  display:inline-flex;
  align-items:center;
  gap:6px;
  padding:6px 12px;
  background:#fff;
  border:1px solid var(--orn-line);
  border-radius:var(--radius-pill);
  color:var(--orn-ink);
  font-size:var(--fs-sm);
  font-weight:500;
  text-decoration:none;
}
.orn-plp-selected__chip:hover{border-color:var(--orn-rose);color:var(--orn-rose);}
.orn-plp-selected__x{font-size:var(--fs-xs);opacity:.6;}
.orn-plp-selected__clear{
  margin-left:auto;
  color:var(--orn-rose);
  font-size:var(--fs-sm);
  font-weight:600;
  align-self:center;
  text-decoration:none;
}
.orn-plp-selected__clear:hover{text-decoration:underline;}

/* Body - 2 col. Filter rail wider (+~10%), product area absorbs the rest. */
.orn-plp-body{
  display:grid;
  grid-template-columns:290px minmax(0,1fr);
  gap:40px;
  align-items:start;
}

/* Sidebar */
.orn-plp-sidebar{
  background:var(--orn-white);
  border:1px solid var(--orn-line);
  border-radius:var(--radius-card);
  padding:6px 0;
  position:sticky;
  top:80px;
  max-height:calc(100vh - 100px);
  overflow:auto;
}
.orn-plp-sidebar__head{
  display:flex;
  justify-content:space-between;
  align-items:center;
  padding:14px 18px 10px;
  border-bottom:1px solid var(--orn-line);
}
.orn-plp-sidebar__title{
  font-size:var(--fs-xs);
  font-weight:700;
  letter-spacing:.1em;
  color:var(--orn-ink);
}
.orn-plp-sidebar__clear{
  font-size:var(--fs-xs);
  font-weight:600;
  color:var(--orn-rose);
  text-transform:uppercase;
  letter-spacing:.05em;
  text-decoration:none;
}

.orn-plp-facet{
  border-bottom:1px solid var(--orn-line);
  padding:0 4px;
}
.orn-plp-facet:last-child{border-bottom:none;}
.orn-plp-facet__head{
  display:flex;
  justify-content:space-between;
  align-items:center;
  padding:14px 14px;
  font-size:var(--fs-sm);
  font-weight:600;
  color:var(--orn-ink);
  cursor:pointer;
  list-style:none;
  user-select:none;
}
.orn-plp-facet__head::-webkit-details-marker{display:none;}
.orn-plp-facet__toggle{
  font-size:var(--fs-lg);
  font-weight:300;
  color:var(--orn-grey-500);
  width:14px;
  text-align:center;
  transition:transform .15s ease;
}
.orn-plp-facet[open] .orn-plp-facet__toggle{transform:rotate(45deg);}
.orn-plp-facet__list{
  list-style:none;
  margin:0;
  padding:0 14px 12px;
}
.orn-plp-facet__opt{
  display:flex;
  align-items:center;
  gap:10px;
  padding:6px 4px;
  border-radius:6px;
  color:var(--orn-ink);
  text-decoration:none;
  font-size:var(--fs-sm);
  transition:background .12s ease;
}
.orn-plp-facet__opt:hover{background:var(--orn-purple-soft);}
.orn-plp-facet__check{
  width:16px;
  height:16px;
  border:1.5px solid var(--orn-grey-400);
  border-radius:4px;
  flex-shrink:0;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  transition:background .12s ease,border-color .12s ease;
}
.orn-plp-facet__opt.is-active .orn-plp-facet__check{
  background:var(--orn-purple);
  border-color:var(--orn-purple);
}
.orn-plp-facet__opt.is-active .orn-plp-facet__check::after{
  content:"✓";
  color:#fff;
  font-size:var(--fs-xs);
  line-height:1;
}
.orn-plp-facet__opt.is-active{font-weight:600;color:var(--orn-purple);}
.orn-plp-facet__label{flex:1;line-height:1.3;}

/* Right column toolbar */
.orn-plp-toolbar{
  display:flex;
  justify-content:space-between;
  align-items:center;
  margin-bottom:18px;
  gap:12px;
}
.orn-plp-count{
  font-size:var(--fs-sm);
  color:var(--orn-ink-soft);
  font-weight:500;
}
.orn-plp-toolbar__filter-btn{
  display:none;
  align-items:center;
  gap:8px;
  padding:8px 14px;
  background:var(--orn-white);
  border:1px solid var(--orn-line);
  border-radius:var(--radius-pill);
  font-size:var(--fs-sm);
  font-weight:600;
  color:var(--orn-ink);
}
.orn-plp-sort{display:flex;align-items:center;gap:8px;}
.orn-plp-sort__label{
  font-size:var(--fs-sm);
  color:var(--orn-ink-soft);
  font-weight:500;
}
.orn-plp-sort__select{
  font-family:var(--font);
  font-size:var(--fs-sm);
  font-weight:500;
  color:var(--orn-ink);
  background:#fff;
  border:1px solid var(--orn-line);
  border-radius:var(--radius-pill);
  padding:8px 32px 8px 14px;
  cursor:pointer;
  appearance:none;
  -webkit-appearance:none;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6' viewBox='0 0 10 6'%3E%3Cpath fill='%234E555E' d='M0 0l5 6 5-6z'/%3E%3C/svg%3E");
  background-repeat:no-repeat;
  background-position:right 14px center;
}
.orn-plp-sort__select:hover{border-color:var(--orn-purple-mid);}

/* Empty state */
.orn-plp-empty{
  background:#fff;
  border:1px dashed var(--orn-line);
  border-radius:var(--radius-card);
  padding:48px 24px;
  text-align:center;
}
.orn-plp-empty h2{
  font-size:var(--fs-lg);
  font-weight:600;
  margin:0 0 8px;
}
.orn-plp-empty p{color:var(--orn-ink-soft);margin:0;}
.orn-plp-empty a{color:var(--orn-purple);font-weight:600;}

/* Mobile filter drawer */
@media (max-width:960px){
  .orn-plp-body{grid-template-columns:1fr;gap:0;}
  .orn-plp-toolbar__filter-btn{display:inline-flex;}
  .orn-plp-sidebar{
    position:fixed;
    inset:0 25% 0 0;
    z-index:200;
    border-radius:0;
    max-height:none;
    top:0;
    transform:translateX(-100%);
    transition:transform .25s ease;
    box-shadow:8px 0 32px -8px rgba(33,36,62,.18);
  }
  .orn-plp-sidebar.is-open{transform:translateX(0);}
  body.orn-plp-drawer-open{overflow:hidden;}
  body.orn-plp-drawer-open::after{
    content:"";
    position:fixed;inset:0;
    background:rgba(33,36,62,.4);
    z-index:150;
  }
}
@media (max-width:520px){
  .orn-plp-sidebar{inset:0 0 0 0;}
  .orn-plp-toolbar{flex-wrap:wrap;}
}

/* ==========================================================================
   20. Cart (Batch 6) - slide-in drawer + tabbed cart page + countdown badge
   ========================================================================== */

/* --- 20.1 Drawer + scrim --- */
.orn-cart-drawer{
  position:fixed;
  top:0;right:0;
  width:min(420px,100vw);
  height:100dvh;
  background:#fff;
  z-index:300;
  display:flex;
  flex-direction:column;
  box-shadow:-12px 0 32px -8px rgba(33,36,62,.18);
  transform:translateX(100%);
  transition:transform .25s cubic-bezier(.22,.61,.36,1);
  visibility:hidden;
}
.orn-cart-drawer.is-open{
  transform:translateX(0);
  visibility:visible;
}
.orn-cart-drawer-scrim{
  position:fixed;
  inset:0;
  background:rgba(33,36,62,.4);
  z-index:250;
  opacity:0;
  visibility:hidden;
  transition:opacity .2s ease;
}
.orn-cart-drawer-scrim.is-open{
  opacity:1;
  visibility:visible;
}
body.orn-cart-drawer-open{overflow:hidden;}

.orn-cart-drawer__head{
  display:flex;
  justify-content:space-between;
  align-items:center;
  padding:18px 20px;
  border-bottom:1px solid var(--orn-line);
  flex-shrink:0;
}
.orn-cart-drawer__title{
  font-size:var(--fs-md);
  font-weight:600;
  margin:0;
  letter-spacing:.01em;
}
.orn-cart-drawer__count{
  color:var(--orn-ink-soft);
  font-weight:500;
  margin-left:4px;
}
.orn-cart-drawer__close{
  background:transparent;
  border:none;
  font-size:var(--fs-3xl);
  line-height:1;
  color:var(--orn-ink);
  cursor:pointer;
  padding:0 4px;
  font-weight:300;
}
.orn-cart-drawer__close:hover{color:var(--orn-purple);}
.orn-cart-drawer__body{
  flex:1;
  overflow-y:auto;
  padding:0;
}

/* --- 20.2 Mini-cart list --- */
.orn-mini-cart{
  list-style:none;
  margin:0;padding:0;
}
.orn-mini-cart__item{
  display:grid;
  grid-template-columns:64px 1fr auto;
  gap:14px;
  padding:18px 20px;
  border-bottom:1px solid var(--orn-line);
  align-items:start;
  position:relative;
}
.orn-mini-cart__thumb{
  display:block;
  width:64px;
  height:64px;
  border-radius:8px;
  overflow:hidden;
  background:var(--orn-purple-soft);
}
.orn-mini-cart__thumb img{width:100%;height:100%;object-fit:cover;}
.orn-mini-cart__body{display:flex;flex-direction:column;gap:4px;min-width:0;}
.orn-mini-cart__name{
  font-size:var(--fs-base);
  font-weight:600;
  color:var(--orn-ink);
  line-height:1.35;
  text-decoration:none;
  overflow:hidden;
  display:-webkit-box;
  -webkit-line-clamp:2;
  -webkit-box-orient:vertical;
}
.orn-mini-cart__name:hover{color:var(--orn-purple);}
.orn-mini-cart__meta{
  display:flex;
  justify-content:space-between;
  align-items:center;
  font-size:var(--fs-sm);
  color:var(--orn-ink-soft);
}
.orn-mini-cart__price{
  font-weight:600;
  color:var(--orn-ink-strong);
}
.orn-mini-cart__remove{
  position:absolute;
  top:14px;right:18px;
  background:transparent;
  border:none;
  color:var(--orn-grey-500);
  font-size:var(--fs-lg);
  cursor:pointer;
  text-decoration:none;
  line-height:1;
}
.orn-mini-cart__remove:hover{color:var(--orn-rose);}

/* --- 20.3 Lock countdown badge --- */
.orn-cart-lock{
  display:flex;
  align-items:center;
  gap:6px;
  margin-top:6px;
  padding:5px 9px;
  background:var(--orn-cream);
  border-radius:6px;
  font-size:var(--fs-xs);
  font-weight:500;
  color:#8A6D2A;
  line-height:1.2;
}
.orn-cart-lock.is-expired{
  background:#fdecee;
  color:var(--orn-rose);
}
.orn-cart-lock__icon{font-size:var(--fs-xs);}

/* --- 20.4 Mini-cart totals + actions --- */
.orn-mini-cart__totals{
  display:flex;
  justify-content:space-between;
  align-items:center;
  padding:16px 20px 12px;
  border-bottom:1px solid var(--orn-line);
}
.orn-mini-cart__subtotal-label{
  font-size:var(--fs-sm);
  color:var(--orn-ink-soft);
  font-weight:500;
}
.orn-mini-cart__subtotal-value{
  font-size:var(--fs-md);
  font-weight:700;
  color:var(--orn-ink-strong);
}
.orn-mini-cart__actions{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:10px;
  padding:14px 20px 20px;
  flex-shrink:0;
}
.orn-mini-cart__btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding:13px 16px;
  border-radius:var(--radius-pill);
  font-size:var(--fs-sm);
  font-weight:600;
  letter-spacing:.03em;
  text-decoration:none;
  cursor:pointer;
  border:1px solid transparent;
  transition:transform .12s ease,box-shadow .12s ease;
}
.orn-mini-cart__btn--ghost{
  background:#fff;
  border-color:var(--orn-purple);
  color:var(--orn-purple);
}
.orn-mini-cart__btn--ghost:hover{background:var(--orn-purple-soft);}
.orn-mini-cart__btn--primary{
  background:var(--orn-cta-gradient);
  color:#fff;
}
.orn-mini-cart__btn--primary:hover{
  transform:translateY(-1px);
  box-shadow:0 8px 20px -10px rgba(88,50,187,.6);
  color:#fff;
}

/* --- 20.5 Empty drawer state --- */
.orn-mini-cart__empty{
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  padding:60px 24px;
  text-align:center;
  flex:1;
  min-height:300px;
}
.orn-mini-cart__empty-icon{font-size:var(--fs-display);margin-bottom:12px;}
.orn-mini-cart__empty-title{
  font-size:var(--fs-md);
  font-weight:600;
  margin:0 0 6px;
}
.orn-mini-cart__empty-sub{
  font-size:var(--fs-sm);
  color:var(--orn-ink-soft);
  margin:0 0 20px;
}
.orn-mini-cart__empty .orn-mini-cart__btn{padding:12px 28px;}

/* --- 20.6 Full cart page --- */
.orn-cart-page__head{
  text-align:left;
  margin-bottom:18px;
}
.orn-cart-page__title{
  font-size:clamp(1.4rem,2.4vw,2rem);
  font-weight:600;
  margin:0 0 6px;
  letter-spacing:-.01em;
}
.orn-cart-page__sub{
  font-size:var(--fs-sm);
  color:var(--orn-ink-soft);
  margin:0;
}

.orn-cart-page__tabs{
  display:flex;
  gap:6px;
  border-bottom:1px solid var(--orn-line);
  margin-bottom:24px;
  overflow-x:auto;
}
.orn-cart-tab{
  background:transparent;
  border:none;
  padding:14px 22px;
  font-family:var(--font);
  font-size:var(--fs-sm);
  font-weight:600;
  letter-spacing:.03em;
  color:var(--orn-ink-soft);
  cursor:pointer;
  border-bottom:2px solid transparent;
  transition:color .12s ease,border-color .12s ease;
  white-space:nowrap;
}
.orn-cart-tab:hover{color:var(--orn-purple);}
.orn-cart-tab.is-active{
  color:var(--orn-purple);
  border-bottom-color:var(--orn-purple);
}
.orn-cart-tab__count{
  margin-left:4px;
  color:var(--orn-ink-soft);
  font-weight:500;
}

.orn-cart-panel{display:none;}
.orn-cart-panel.is-active{display:block;}

.orn-cart-page__body{
  display:grid;
  grid-template-columns:minmax(0,1fr) 360px;
  gap:32px;
  align-items:start;
}
.orn-cart-page__body .orn-cart-panel:not(.is-active){display:none;}
.orn-cart-panel[data-panel="summary"]{grid-column:1;}
.orn-cart-summary{
  grid-column:2;
  position:sticky;
  top:80px;
}

/* --- 20.7 Cart item card --- */
.orn-cart-items{display:flex;flex-direction:column;gap:14px;}
.orn-cart-item{
  display:grid;
  grid-template-columns:96px minmax(0,1fr) 110px 140px;
  gap:18px;
  background:#fff;
  border:1px solid var(--orn-line);
  border-radius:var(--radius-card);
  padding:18px;
  align-items:start;
}
.orn-cart-item__thumb{
  display:block;
  width:96px;height:96px;
  border-radius:8px;
  overflow:hidden;
  background:var(--orn-purple-soft);
}
.orn-cart-item__thumb img{width:100%;height:100%;object-fit:cover;}
.orn-cart-item__body{display:flex;flex-direction:column;gap:6px;min-width:0;}
.orn-cart-item__name{
  font-size:var(--fs-md);
  font-weight:600;
  color:var(--orn-ink-strong);
  line-height:1.3;
  text-decoration:none;
}
.orn-cart-item__name:hover{color:var(--orn-purple);}
.orn-cart-item__sku{
  font-size:var(--fs-xs);
  color:var(--orn-ink-soft);
  letter-spacing:.02em;
}
.orn-cart-item__actions{
  display:flex;
  gap:14px;
  margin-top:8px;
}
.orn-cart-item__action{
  background:transparent;
  border:none;
  padding:0;
  font-family:var(--font);
  font-size:var(--fs-sm);
  font-weight:500;
  color:var(--orn-ink-soft);
  cursor:pointer;
  text-decoration:none;
}
.orn-cart-item__action:hover{color:var(--orn-purple);}
.orn-cart-item__action--danger:hover{color:var(--orn-rose);}
.orn-cart-item__action:disabled{opacity:.4;cursor:not-allowed;}

.orn-cart-item__qty{align-self:center;}
.orn-cart-item__qty .quantity{display:inline-flex;align-items:center;}
.orn-cart-item__qty input.qty{
  width:60px;
  padding:8px 10px;
  border:1px solid var(--orn-line);
  border-radius:var(--radius-pill);
  font-family:var(--font);
  font-size:var(--fs-sm);
  text-align:center;
}
.orn-cart-item__price{
  text-align:right;
  align-self:center;
  font-size:var(--fs-md);
  font-weight:700;
  color:var(--orn-ink-strong);
}

.orn-cart-form__actions{
  display:flex;
  justify-content:flex-end;
  margin-top:16px;
}
.orn-cart-update{
  background:#fff !important;
  border:1px solid var(--orn-purple) !important;
  color:var(--orn-purple) !important;
  border-radius:var(--radius-pill) !important;
  padding:10px 24px !important;
  font-size:var(--fs-sm) !important;
  font-weight:600 !important;
}
.orn-cart-update:hover{background:var(--orn-purple-soft) !important;}

/* --- 20.8 Summary card (Woo collateral) --- */
.orn-cart-summary{
  background:#fff;
  border:1px solid var(--orn-line);
  border-radius:var(--radius-card);
  padding:22px;
}
.orn-cart-summary h2{
  font-size:var(--fs-md);
  font-weight:600;
  letter-spacing:.05em;
  text-transform:uppercase;
  color:var(--orn-ink);
  margin:0 0 16px;
}
.orn-cart-summary .cart_totals table{
  width:100%;
  border-collapse:collapse;
}
.orn-cart-summary .cart_totals th,
.orn-cart-summary .cart_totals td{
  padding:10px 0;
  font-size:var(--fs-base);
  border-bottom:1px solid var(--orn-line);
}
.orn-cart-summary .cart_totals th{
  text-align:left;
  font-weight:500;
  color:var(--orn-ink-soft);
}
.orn-cart-summary .cart_totals td{text-align:right;font-weight:600;}
.orn-cart-summary .order-total th,
.orn-cart-summary .order-total td{
  font-size:var(--fs-md);
  font-weight:700;
  border-bottom:none;
  padding-top:14px;
}
.orn-cart-summary .wc-proceed-to-checkout{margin-top:18px;}
.orn-cart-summary .checkout-button,
.orn-cart-summary a.checkout-button{
  display:block;
  width:100%;
  background:var(--orn-cta-gradient) !important;
  color:#fff !important;
  text-align:center;
  padding:14px 16px !important;
  border-radius:var(--radius-pill) !important;
  font-size:var(--fs-base) !important;
  font-weight:700 !important;
  letter-spacing:.05em;
  text-transform:uppercase;
  border:none !important;
}
.orn-cart-summary .checkout-button:hover{
  transform:translateY(-1px);
  box-shadow:0 8px 20px -10px rgba(88,50,187,.6);
}
.orn-cart-summary .coupon{
  display:flex;
  gap:8px;
  margin-bottom:14px;
}
.orn-cart-summary .coupon input{
  flex:1;
  padding:10px 14px;
  border:1px solid var(--orn-line);
  border-radius:var(--radius-pill);
  font-family:var(--font);
  font-size:var(--fs-sm);
}
.orn-cart-summary .coupon button{
  background:#fff;
  border:1px solid var(--orn-purple);
  color:var(--orn-purple);
  border-radius:var(--radius-pill);
  padding:10px 18px;
  font-size:var(--fs-sm);
  font-weight:600;
}

/* --- 20.9 Cart empty state --- */
.orn-cart-empty-state{
  text-align:center;
  padding:60px 24px;
  background:#fff;
  border:1px dashed var(--orn-line);
  border-radius:var(--radius-card);
}
.orn-cart-empty-state__icon{font-size:var(--fs-display);margin-bottom:14px;}
.orn-cart-empty-state h3{
  font-size:var(--fs-lg);
  font-weight:600;
  margin:0 0 6px;
}
.orn-cart-empty-state p{
  color:var(--orn-ink-soft);
  margin:0 0 18px;
  font-size:var(--fs-base);
}

/* --- 20.10 Mobile cart page --- */
@media (max-width:900px){
  .orn-cart-page__body{grid-template-columns:1fr;}
  .orn-cart-summary{position:static;}
  .orn-cart-item{grid-template-columns:80px minmax(0,1fr) 90px;grid-template-areas:"thumb body qty" "thumb body price";gap:12px 14px;}
  .orn-cart-item__thumb{grid-area:thumb;width:80px;height:80px;}
  .orn-cart-item__body{grid-area:body;}
  .orn-cart-item__qty{grid-area:qty;align-self:start;}
  .orn-cart-item__price{grid-area:price;align-self:end;}
}
@media (max-width:520px){
  .orn-cart-drawer{width:100vw;}
}

/* ==========================================================================
   21. Checkout (Batch 7) - 3-step flow + gifting + sticky summary
   ========================================================================== */

.orn-checkout-page__head{margin-bottom:14px;}
.orn-checkout-page__title{
  font-size:clamp(1.4rem,2.4vw,2rem);
  font-weight:600;
  margin:0;
  letter-spacing:-.01em;
}

/* --- 21.1 Step nav --- */
.orn-checkout-steps{
  display:flex;
  align-items:center;
  justify-content:center;
  gap:10px;
  margin:8px 0 28px;
  flex-wrap:wrap;
}
.orn-checkout-step{
  display:inline-flex;
  align-items:center;
  gap:10px;
  background:transparent;
  border:none;
  padding:8px 10px;
  cursor:pointer;
  font-family:var(--font);
  font-size:var(--fs-sm);
  font-weight:600;
  color:var(--orn-ink-soft);
  transition:color .12s ease;
}
.orn-checkout-step:hover{color:var(--orn-purple);}
.orn-checkout-step__num{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  width:28px;height:28px;
  border-radius:50%;
  background:var(--orn-purple-soft);
  color:var(--orn-purple);
  font-size:var(--fs-sm);
  font-weight:700;
}
.orn-checkout-step.is-active .orn-checkout-step__num,
.orn-checkout-step.is-complete .orn-checkout-step__num{
  background:var(--orn-purple);
  color:#fff;
}
.orn-checkout-step.is-active{color:var(--orn-ink-strong);}
.orn-checkout-step__sep{
  width:48px;height:2px;
  background:var(--orn-line);
  border-radius:2px;
}

/* --- 21.2 Layout --- */
.orn-checkout-grid{
  display:grid;
  grid-template-columns:minmax(0,1fr) 360px;
  gap:32px;
  align-items:start;
}
.orn-checkout-main{min-width:0;}
.orn-checkout-panel{display:none;background:#fff;border:1px solid var(--orn-line);border-radius:var(--radius-card);padding:28px;}
.orn-checkout-panel.is-active{display:block;}
.orn-checkout-panel__title{
  font-size:var(--fs-lg);
  font-weight:600;
  margin:0 0 6px;
}
.orn-checkout-panel__sub{
  font-size:var(--fs-sm);
  color:var(--orn-ink-soft);
  margin:0 0 22px;
}

/* --- 21.3 Form rows (Woo's standard fields override) --- */
.orn-checkout-form .form-row{
  display:flex;
  flex-direction:column;
  gap:6px;
  margin:0 0 14px;
}
.orn-checkout-form .form-row label{
  font-size:var(--fs-sm);
  font-weight:500;
  color:var(--orn-ink);
}
.orn-checkout-form .form-row .required{color:var(--orn-rose);text-decoration:none;}
.orn-checkout-form .form-row .input-text,
.orn-checkout-form .form-row select,
.orn-checkout-form input[type="text"],
.orn-checkout-form input[type="email"],
.orn-checkout-form input[type="tel"],
.orn-checkout-form input[type="date"],
.orn-checkout-form textarea,
.orn-form-row textarea,
.orn-form-row input[type="date"]{
  width:100%;
  padding:12px 14px;
  background:#fff;
  border:1px solid var(--orn-line);
  border-radius:8px;
  font-family:var(--font);
  font-size:var(--fs-base);
  color:var(--orn-ink-strong);
  transition:border-color .12s ease,box-shadow .12s ease;
}
.orn-checkout-form .form-row .input-text:focus,
.orn-checkout-form .form-row select:focus,
.orn-checkout-form input:focus,
.orn-checkout-form textarea:focus,
.orn-form-row textarea:focus,
.orn-form-row input[type="date"]:focus{
  border-color:var(--orn-purple);
  outline:none;
  box-shadow:0 0 0 3px rgba(79,50,103,.12);
}
.orn-checkout-form .col2-set{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:24px;
}
@media (max-width:760px){
  .orn-checkout-form .col2-set{grid-template-columns:1fr;}
}
.orn-checkout-form .form-row-first,
.orn-checkout-form .form-row-last{width:auto;float:none;}

/* --- 21.4 Step nav buttons --- */
.orn-checkout-nav{
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:12px;
  margin-top:24px;
}
.orn-checkout-next,
.orn-checkout-back{
  font-family:var(--font);
  font-size:var(--fs-sm);
  font-weight:600;
  letter-spacing:.03em;
  padding:13px 24px;
  border-radius:var(--radius-pill);
  cursor:pointer;
  border:1px solid transparent;
  transition:transform .12s ease,box-shadow .12s ease;
}
.orn-checkout-next{
  background:var(--orn-cta-gradient);
  color:#fff;
  border:none;
  margin-left:auto;
}
.orn-checkout-next:hover{
  transform:translateY(-1px);
  box-shadow:0 8px 20px -10px rgba(88,50,187,.6);
}
.orn-checkout-back{
  background:#fff;
  border-color:var(--orn-line);
  color:var(--orn-ink);
}
.orn-checkout-back:hover{border-color:var(--orn-purple);color:var(--orn-purple);}

/* --- 21.5 Gifting section --- */
.orn-checkout-gifting{display:flex;flex-direction:column;gap:18px;}
.orn-gift-toggle{
  display:flex;
  align-items:flex-start;
  gap:14px;
  padding:18px;
  border:1px solid var(--orn-line);
  border-radius:var(--radius-card);
  cursor:pointer;
  background:#fff;
  transition:border-color .12s ease,background .12s ease;
}
.orn-gift-toggle:hover{border-color:var(--orn-purple-mid);}
.orn-gift-toggle input{position:absolute;opacity:0;pointer-events:none;}
.orn-gift-toggle__swatch{
  width:20px;height:20px;
  border:2px solid var(--orn-grey-400);
  border-radius:6px;
  flex-shrink:0;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  transition:background .12s ease,border-color .12s ease;
}
.orn-gift-toggle input:checked + .orn-gift-toggle__swatch{
  background:var(--orn-purple);
  border-color:var(--orn-purple);
}
.orn-gift-toggle input:checked + .orn-gift-toggle__swatch::after{
  content:"✓";color:#fff;font-size:var(--fs-sm);line-height:1;
}
.orn-gift-toggle input:checked ~ .orn-gift-toggle__body{color:var(--orn-purple);}
.orn-gift-toggle__body{display:flex;flex-direction:column;gap:2px;}
.orn-gift-toggle__title{font-size:var(--fs-base);font-weight:600;color:var(--orn-ink-strong);}
.orn-gift-toggle__sub{font-size:var(--fs-sm);color:var(--orn-ink-soft);}

.orn-form-row{display:flex;flex-direction:column;gap:6px;}
.orn-form-row__label{font-size:var(--fs-sm);font-weight:500;color:var(--orn-ink);}
.orn-form-row__hint{font-weight:400;color:var(--orn-ink-soft);}

/* --- 21.6 Payment section (Woo gateways) --- */
.orn-checkout-payment{margin-top:8px;}
.orn-checkout-payment .wc_payment_methods{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:10px;}
.orn-checkout-payment .wc_payment_method{
  background:#fff;
  border:1px solid var(--orn-line);
  border-radius:var(--radius-card);
  padding:16px 18px;
  transition:border-color .12s ease;
}
.orn-checkout-payment .wc_payment_method:has(input:checked){border-color:var(--orn-purple);background:var(--orn-purple-soft);}
.orn-checkout-payment .wc_payment_method label{
  font-weight:600;
  font-size:var(--fs-base);
  cursor:pointer;
  display:flex;
  align-items:center;
  gap:10px;
}
.orn-checkout-payment .payment_box{
  font-size:var(--fs-sm);
  color:var(--orn-ink-soft);
  margin-top:10px;
}
.orn-checkout-payment #place_order,
.orn-checkout-payment button#place_order{
  display:block;
  width:100%;
  background:var(--orn-cta-gradient) !important;
  color:#fff !important;
  text-align:center;
  padding:16px 16px !important;
  border-radius:var(--radius-pill) !important;
  font-size:var(--fs-base) !important;
  font-weight:700 !important;
  letter-spacing:.06em;
  text-transform:uppercase;
  border:none !important;
  margin-top:20px;
  cursor:pointer;
}
.orn-checkout-payment #place_order:hover{
  transform:translateY(-1px);
  box-shadow:0 8px 20px -10px rgba(88,50,187,.6);
}

/* --- 21.7 Sticky summary sidebar --- */
.orn-checkout-summary{
  position:sticky;
  top:80px;
  background:#fff;
  border:1px solid var(--orn-line);
  border-radius:var(--radius-card);
  padding:22px;
}
.orn-checkout-summary__title{
  font-size:var(--fs-sm);
  font-weight:700;
  letter-spacing:.08em;
  text-transform:uppercase;
  color:var(--orn-ink);
  margin:0 0 16px;
}
.orn-checkout-summary__body{
  display:flex;
  flex-direction:column;
  gap:12px;
  padding-bottom:14px;
  border-bottom:1px solid var(--orn-line);
}
.orn-checkout-summary__item{
  display:grid;
  grid-template-columns:56px minmax(0,1fr) auto;
  gap:12px;
  align-items:center;
}
.orn-checkout-summary__thumb img{width:56px;height:56px;border-radius:6px;object-fit:cover;background:var(--orn-purple-soft);}
.orn-checkout-summary__meta{display:flex;flex-direction:column;min-width:0;}
.orn-checkout-summary__name{
  font-size:var(--fs-sm);
  font-weight:600;
  color:var(--orn-ink);
  line-height:1.3;
  overflow:hidden;
  text-overflow:ellipsis;
  display:-webkit-box;
  -webkit-line-clamp:2;
  -webkit-box-orient:vertical;
}
.orn-checkout-summary__qty{font-size:var(--fs-xs);color:var(--orn-ink-soft);}
.orn-checkout-summary__price{font-size:var(--fs-sm);font-weight:600;}

.orn-checkout-summary__totals{
  display:flex;
  flex-direction:column;
  gap:8px;
  padding:14px 0;
  border-bottom:1px solid var(--orn-line);
}
.orn-checkout-summary__row{
  display:flex;
  justify-content:space-between;
  font-size:var(--fs-sm);
  color:var(--orn-ink);
}
.orn-checkout-summary__row--total{
  font-size:var(--fs-md);
  font-weight:700;
  color:var(--orn-ink-strong);
  margin-top:6px;
  padding-top:10px;
  border-top:1px solid var(--orn-line);
}
.orn-checkout-summary__note{
  font-size:var(--fs-xs);
  color:var(--orn-ink-soft);
  margin:14px 0 0;
  line-height:1.5;
}

/* --- 21.8 Mobile checkout --- */
@media (max-width:900px){
  .orn-checkout-grid{grid-template-columns:1fr;}
  .orn-checkout-summary{position:static;}
  .orn-checkout-step__sep{width:24px;}
  .orn-checkout-step__label{display:none;}
}

/* ==========================================================================
   22. Account + Login (Batch 8) - OTP login form + My Account dashboard card
   ========================================================================== */

/* --- 22.1 Login page --- */
.orn-login{padding-block:clamp(40px,8vw,80px);}
.orn-login-card{
  max-width:440px;
  margin:0 auto;
  background:#fff;
  border:1px solid var(--orn-line);
  border-radius:var(--radius-card);
  padding:36px 32px;
  box-shadow:var(--shadow-card);
}
.orn-login-card__head{text-align:center;margin-bottom:26px;}
.orn-login-card__title{
  font-size:var(--fs-xl);
  font-weight:600;
  margin:0 0 6px;
}
.orn-login-card__sub{
  font-size:var(--fs-sm);
  color:var(--orn-ink-soft);
  margin:0;
}
.orn-login-form{display:flex;flex-direction:column;gap:14px;}
.orn-login-form[hidden]{display:none;}
.orn-login-form__label{
  font-size:var(--fs-sm);
  font-weight:500;
  color:var(--orn-ink);
}
.orn-login-form input[type="text"],
.orn-login-form input[type="password"],
.orn-login-form input.orn-otp-code-input{
  width:100%;
  padding:14px 16px;
  background:#fff;
  border:1px solid var(--orn-line);
  border-radius:8px;
  font-family:var(--font);
  font-size:var(--fs-md);
  color:var(--orn-ink-strong);
  transition:border-color .12s ease,box-shadow .12s ease;
}
.orn-login-form input.orn-otp-code-input{
  letter-spacing:.6em;
  text-align:center;
  font-size:var(--fs-xl);
  font-weight:600;
  padding-left:24px;
}
.orn-login-form input:focus{
  outline:none;
  border-color:var(--orn-purple);
  box-shadow:0 0 0 3px rgba(79,50,103,.12);
}
.orn-login-form__cta{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding:14px 20px;
  background:var(--orn-cta-gradient);
  color:#fff;
  border:none;
  border-radius:var(--radius-pill);
  font-family:var(--font);
  font-size:var(--fs-base);
  font-weight:700;
  letter-spacing:.04em;
  text-transform:uppercase;
  cursor:pointer;
  transition:transform .12s ease,box-shadow .12s ease;
}
.orn-login-form__cta:hover{
  transform:translateY(-1px);
  box-shadow:0 8px 20px -10px rgba(88,50,187,.6);
}
.orn-login-form__cta:disabled{opacity:.6;cursor:not-allowed;transform:none;box-shadow:none;}
.orn-login-form__row{
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:8px;
}
.orn-login-form__linkbtn{
  background:transparent;
  border:none;
  padding:6px 0;
  color:var(--orn-purple);
  font-family:var(--font);
  font-size:var(--fs-sm);
  font-weight:600;
  cursor:pointer;
}
.orn-login-form__linkbtn:hover{text-decoration:underline;}
.orn-login-form__linkbtn:disabled{opacity:.5;cursor:default;}
.orn-login-form__masked{
  font-size:var(--fs-sm);
  color:var(--orn-ink-soft);
  text-align:center;
  margin-bottom:4px;
}
.orn-login-form__msg{
  font-size:var(--fs-sm);
  text-align:center;
  margin:0;
  min-height:1em;
  color:var(--orn-ink-soft);
}
.orn-login-form__msg.is-error{color:var(--orn-rose);}
.orn-login-form__msg.is-success{color:var(--orn-green);}

.orn-login-fallback{
  margin-top:24px;
  padding-top:18px;
  border-top:1px solid var(--orn-line);
}
.orn-login-fallback summary{
  font-size:var(--fs-sm);
  color:var(--orn-purple);
  font-weight:600;
  cursor:pointer;
  list-style:none;
  text-align:center;
}
.orn-login-fallback summary::-webkit-details-marker{display:none;}
.orn-login-fallback summary:hover{text-decoration:underline;}
.orn-login-fallback[open] summary{margin-bottom:16px;}
.orn-login-fallback .form-row{margin:0 0 12px;}
.orn-login-fallback input[type="text"],
.orn-login-fallback input[type="password"]{
  width:100%;
  padding:11px 14px;
  border:1px solid var(--orn-line);
  border-radius:8px;
  font-family:var(--font);
  font-size:var(--fs-base);
}
.orn-login-fallback button[type="submit"]{
  background:var(--orn-purple);
  color:#fff;
  border:none;
  padding:11px 22px;
  border-radius:var(--radius-pill);
  font-size:var(--fs-sm);
  font-weight:600;
  cursor:pointer;
}

.orn-login-card__terms{
  font-size:var(--fs-xs);
  color:var(--orn-ink-soft);
  text-align:center;
  margin:18px 0 0;
  line-height:1.5;
}

/* --- 22.1b Auth page: Login / Sign Up (CaratLane-style) --- */
.orn-auth{
  padding-block:clamp(40px,7vw,96px);
  display:flex;align-items:center;justify-content:center;
  min-height:60vh;            /* let it breathe, vertically centred */
}
.orn-auth__wrap{display:flex;justify-content:center;width:100%;}
/* No box: the card merges into the white page. */
.orn-auth-card{
  width:100%;
  max-width:460px;
  background:transparent;
  border:none;
  border-radius:0;
  box-shadow:none;
  padding:0 16px;
}
.orn-auth-tabs{
  display:flex;
  gap:6px;
  background:var(--orn-purple-pale);
  border-radius:999px;
  padding:5px;
  margin-bottom:24px;
}
.orn-auth-tab{
  flex:1 1 50%;
  border:none;
  background:transparent;
  border-radius:999px;
  padding:10px 14px;
  font-family:var(--font);
  font-size:var(--fs-sm);
  font-weight:600;
  color:var(--orn-ink-soft);
  cursor:pointer;
  transition:background .15s ease,color .15s ease;
}
.orn-auth-tab.is-active{background:#fff;color:var(--orn-purple);box-shadow:0 2px 8px rgba(31,19,48,.08);}
.orn-auth-pane{display:none;}
.orn-auth-pane.is-active{display:block;}
.orn-auth-head{text-align:center;margin-bottom:20px;}
.orn-auth-title{font-family:var(--font);font-size:var(--fs-2xl);font-weight:700;color:var(--orn-ink-strong);margin:0 0 6px;letter-spacing:-.01em;}
.orn-auth-sub{font-size:var(--fs-sm);color:var(--orn-ink-soft);margin:0;line-height:1.5;}
.orn-auth-social{display:flex;justify-content:center;margin-bottom:16px;}
.orn-auth-social .nsl-container{margin:0 !important;width:100%;}
.orn-auth-google{
  display:inline-flex;align-items:center;justify-content:center;gap:10px;
  width:100%;
  border:1px solid var(--orn-line);
  border-radius:999px;
  padding:11px 18px;
  background:#fff;
  color:var(--orn-ink-strong);
  font-family:var(--font);font-size:var(--fs-sm);font-weight:600;
  text-decoration:none;cursor:pointer;
  transition:border-color .15s ease,background .15s ease;
}
.orn-auth-google:hover{border-color:var(--orn-purple);background:var(--orn-purple-pale);}
.orn-auth-google__g{
  display:inline-flex;align-items:center;justify-content:center;
  width:22px;height:22px;border-radius:50%;
  background:conic-gradient(from -45deg,#ea4335 0 25%,#fbbc05 0 50%,#34a853 0 75%,#4285f4 0);
  color:#fff;font-weight:800;font-size:12px;
}
.orn-auth-or{
  display:flex;align-items:center;gap:12px;
  margin:16px 0;
  color:var(--orn-ink-soft);font-size:var(--fs-xs);
}
.orn-auth-or::before,.orn-auth-or::after{content:"";flex:1;height:1px;background:var(--orn-line);}
.orn-auth-switch{text-align:center;margin:18px 0 0;font-size:var(--fs-sm);color:var(--orn-ink-soft);}
.orn-auth-switch__btn{
  background:none;border:none;padding:0;
  color:var(--orn-purple);font-family:var(--font);font-size:var(--fs-sm);font-weight:700;
  cursor:pointer;
}
.orn-auth-switch__btn:hover{text-decoration:underline;}

/* Signup form */
.orn-signup-form{display:flex;flex-direction:column;gap:14px;}
.orn-signup-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px;}
.orn-field{margin:0;display:flex;flex-direction:column;gap:6px;}
.orn-field--full{grid-column:1 / -1;}
.orn-field label{font-size:var(--fs-xs);font-weight:600;color:var(--orn-ink-strong);}
.orn-req{color:var(--orn-rose);margin-left:2px;}
.orn-field input,
.orn-phone input{
  width:100%;
  padding:11px 14px;
  border:1px solid var(--orn-line);
  border-radius:10px;
  font-family:var(--font);font-size:var(--fs-base);
  color:var(--orn-ink-strong);
}
.orn-field input:focus,.orn-phone input:focus{outline:none;border-color:var(--orn-purple);}
.orn-phone{display:flex;align-items:stretch;border:1px solid var(--orn-line);border-radius:10px;overflow:hidden;}
.orn-phone:focus-within{border-color:var(--orn-purple);}
.orn-phone__cc{
  display:flex;align-items:center;padding:0 12px;
  background:var(--orn-purple-pale);color:var(--orn-ink-strong);
  font-size:var(--fs-sm);font-weight:600;border-right:1px solid var(--orn-line);
}
.orn-phone input{border:none;border-radius:0;}
.orn-gender{border:none;padding:0;margin:2px 0;display:flex;gap:18px;align-items:center;}
.orn-gender legend{font-size:var(--fs-xs);font-weight:600;color:var(--orn-ink-strong);float:left;margin-right:14px;}
.orn-gender label{display:inline-flex;align-items:center;gap:6px;font-size:var(--fs-sm);color:var(--orn-ink);cursor:pointer;}
.orn-wa,.orn-terms{display:flex;gap:10px;align-items:flex-start;font-size:var(--fs-xs);color:var(--orn-ink-soft);line-height:1.45;cursor:pointer;}
.orn-wa input,.orn-terms input{margin-top:2px;flex:0 0 auto;}
.orn-wa span{display:flex;flex-direction:column;}
.orn-wa strong{font-size:var(--fs-sm);color:var(--orn-ink-strong);font-weight:600;}
.orn-wa small{color:var(--orn-ink-soft);}
.orn-terms a{color:var(--orn-purple);}
.orn-signup-cta{margin-top:4px;}
@media (max-width:520px){
  .orn-signup-grid{grid-template-columns:1fr;}
}

/* --- 22.1c Dedicated /login + /signup pages (CaratLane layout) --- */
.orn-auth-card--login{max-width:420px;}
.orn-auth-card--signup{max-width:560px;}
.orn-auth-mark{
  display:flex;align-items:center;justify-content:center;
  width:54px;height:54px;margin:0 auto 14px;
  border-radius:50%;
  background:var(--orn-purple-pale);
  color:var(--orn-purple);
}
.orn-auth-mark .orn-uicon{color:var(--orn-purple);}
.orn-cta--block{width:100%;text-transform:uppercase;letter-spacing:.04em;}
.orn-terms--login{margin:14px 0 4px;}
/* Social icons row (round icons, centered) */
.orn-auth-social--icons{display:flex;justify-content:center;gap:14px;margin:6px 0 0;}
.orn-auth-social--icons .nsl-container{margin:0 !important;display:inline-flex !important;}
.orn-auth-social--icons .nsl-container-block .nsl-button{margin:0 !important;}
/* inline validation errors */
.orn-field__err{display:none;color:var(--orn-rose);font-size:var(--fs-2xs);margin-top:4px;}
.orn-field.has-error input,
.orn-field.has-error .orn-phone{border-color:var(--orn-rose) !important;}
.orn-field.has-error .orn-field__err{display:block;}
.orn-auth-loggedin{max-width:420px;margin:60px auto;text-align:center;display:flex;flex-direction:column;gap:16px;align-items:center;}
/* Clean, focused auth pages: drop the footer + announcement bar so the form breathes. */
body.orn-auth-page .orn-footer,
body.orn-auth-page .orn-announce,
body.orn-auth-page .orn-announcement,
body.orn-auth-page .orn-topbar{display:none !important;}

/* Password field with show/hide (eye) toggle */
.orn-pwd{position:relative;display:block;}
.orn-pwd input{width:100%;padding-right:44px !important;}
.orn-pwd__eye{
  position:absolute;top:50%;right:8px;transform:translateY(-50%);
  display:flex;align-items:center;justify-content:center;
  width:32px;height:32px;padding:0;
  background:none;border:none;cursor:pointer;
  color:var(--orn-grey-500);
}
.orn-pwd__eye:hover{color:var(--orn-purple);}
.orn-pwd__eye.is-shown{color:var(--orn-purple);}
.orn-signup-otp .orn-login-form__masked,
.orn-login-form__masked{font-size:var(--fs-sm);color:var(--orn-ink-soft);margin-bottom:4px;text-align:center;}

/* --- Plain content pages (Terms, Privacy, Refund, Sitemap, About…) --- */
.orn-page{padding-block:clamp(28px,5vw,64px);}
.orn-prose{max-width:760px;margin:0 auto;padding:0 20px;color:var(--orn-ink);}
.orn-prose__title{
  font-family:var(--font);
  font-size:var(--fs-3xl);
  font-weight:700;
  color:var(--orn-ink-strong);
  letter-spacing:-.01em;
  line-height:1.2;
  margin:0 0 20px;
}
.orn-prose__body{font-size:var(--fs-base);line-height:1.75;color:var(--orn-ink);}
.orn-prose__body h2{font-size:var(--fs-xl);font-weight:700;color:var(--orn-ink-strong);margin:30px 0 8px;line-height:1.3;}
.orn-prose__body h3{font-size:var(--fs-lg);font-weight:600;color:var(--orn-ink-strong);margin:24px 0 6px;}
.orn-prose__body p{margin:0 0 14px;}
.orn-prose__body a{color:var(--orn-purple);text-decoration:underline;}
.orn-prose__body a:hover{color:var(--orn-purple-deep);}
.orn-prose__body ul,.orn-prose__body ol{margin:0 0 16px;padding-left:22px;}
.orn-prose__body li{margin:5px 0;}
.orn-prose__body em{color:var(--orn-ink-soft);font-style:italic;}
.orn-prose__body strong{color:var(--orn-ink-strong);}

/* --- 22.1d My Account layout (CaratLane-style: white, sidebar + content) --- */
.woocommerce-account .woocommerce{
  display:grid;
  grid-template-columns:250px minmax(0,1fr);   /* narrow menu + wide content */
  gap:40px;
  align-items:start;
  /* Match the site wrapper (.orn-wrap) exactly so the page margins line up
     with the header / nav: same max-width + same horizontal padding. */
  max-width:1840px;
  margin:0 auto;
  padding:clamp(28px,4vw,48px) 32px;
}
.woocommerce-account .woocommerce::before,
.woocommerce-account .woocommerce::after{content:none !important;display:none !important;}

/* Sidebar */
.orn-acct-nav{
  background:#fff;
  border:1px solid var(--orn-line);
  border-radius:16px;
  padding:22px 18px;
  position:sticky;
  top:96px;
  /* WooCommerce floats the nav left with its own width, collapsing it inside
     the grid cell. Force it to fill the grid track. */
  float:none !important;
  width:100% !important;
  margin:0 !important;
}
.orn-acct-nav__profile{
  display:flex;align-items:center;gap:12px;
  padding-bottom:18px;margin-bottom:8px;
  border-bottom:1px solid var(--orn-line);
}
.orn-acct-nav__avatar{
  flex:0 0 auto;
  width:46px;height:46px;border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  background:var(--orn-purple);color:#fff;
  font-family:var(--font);font-weight:700;font-size:var(--fs-lg);
}
.orn-acct-nav__id{display:flex;flex-direction:column;min-width:0;}
.orn-acct-nav__name{font-size:var(--fs-lg);font-weight:700;color:var(--orn-ink-strong);line-height:1.2;}
.orn-acct-nav__email{font-size:var(--fs-xs);color:var(--orn-ink-soft);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}
.orn-acct-nav__edit{font-size:var(--fs-sm);font-weight:600;color:var(--orn-purple);margin-top:3px;text-decoration:none;}
.orn-acct-nav__edit:hover{text-decoration:underline;}
.orn-acct-nav__group{margin-top:16px;}
.orn-acct-nav__label{
  display:block;
  font-size:var(--fs-2xs);font-weight:700;letter-spacing:.08em;
  color:var(--orn-grey-500);text-transform:uppercase;
  padding:0 8px 7px;
}
.orn-acct-nav ul{list-style:none;margin:0;padding:0;}
.orn-acct-nav li{margin:0;}
.orn-acct-nav li a{
  display:block;
  padding:10px 12px;border-radius:9px;
  font-size:var(--fs-base);font-weight:500;
  color:var(--orn-ink);text-decoration:none;
  transition:background .12s ease,color .12s ease;
}
.orn-acct-nav li a:hover{background:var(--orn-purple-pale);color:var(--orn-purple);}
.orn-acct-nav li.is-active a{background:var(--orn-purple-pale);color:var(--orn-purple);font-weight:700;}
.orn-acct-nav__group--logout{margin-top:18px;border-top:1px solid var(--orn-line);padding-top:8px;}
.orn-acct-nav__group--logout a{color:var(--orn-ink-soft);}

/* Content area */
.woocommerce-account .woocommerce-MyAccount-content{
  background:#fff;
  border:none;
  border-radius:16px;
  padding:clamp(20px,3vw,34px) 0;
  min-width:0;
  float:none !important;width:auto !important;
}
.woocommerce-account .woocommerce-MyAccount-content > p:first-child{margin-top:0;}
.woocommerce-account .woocommerce-MyAccount-content a{color:var(--orn-purple);}

/* My Profile (edit-account) + Addresses: content area is transparent so the
   inner section cards become the cards (no double border). */
.woocommerce-edit-account .woocommerce-MyAccount-content,
.woocommerce-edit-address .woocommerce-MyAccount-content,
.woocommerce-MyAccount-content:has(.orn-profile){
  background:none !important;border:none !important;border-radius:0 !important;padding:0 !important;
}

/* ---- WooCommerce notices: replace the default grey box + odd icon with a
       clean branded card (used on account, cart, checkout, etc.) ---- */
.woocommerce-info,
.woocommerce-message,
.woocommerce-error,
.woocommerce-noreviews,
.woocommerce-Message{
  background:var(--orn-purple-pale) !important;
  border:none !important;
  border-radius:10px !important;
  color:var(--orn-ink-strong) !important;
  padding:14px 18px !important;
  margin:0 0 18px !important;
  font-size:var(--fs-sm) !important;
  line-height:1.5 !important;
  list-style:none !important;
  display:flex !important;align-items:center;gap:12px;flex-wrap:wrap;
}
.woocommerce-info::before,
.woocommerce-message::before,
.woocommerce-error::before,
.woocommerce-Message::before{content:none !important;display:none !important;}
.woocommerce-message{background:#EEF7EE !important;border-color:#CBE7CB !important;}
.woocommerce-error{background:#FDEEF0 !important;border-color:#F3C9D2 !important;color:var(--orn-rose) !important;}
.woocommerce-info a,.woocommerce-message a,.woocommerce-error a{color:var(--orn-purple) !important;font-weight:600;}
.woocommerce-info .button,.woocommerce-message .button{margin-left:auto !important;}

/* ---- Custom date field + calendar (CaratLane-style) ---- */
.orn-datefield{position:relative;display:block;}
.orn-datefield__display{
  width:100%;padding:11px 42px 11px 14px;
  border:1px solid var(--orn-line);border-radius:10px;
  font-family:var(--font);font-size:var(--fs-base);color:var(--orn-ink-strong);
  background:#fff;cursor:pointer;
}
.orn-datefield__display:focus{outline:none;border-color:var(--orn-purple);}
.orn-datefield__icon{
  position:absolute;top:50%;right:10px;transform:translateY(-50%);
  background:none;border:none;color:var(--orn-grey-500);cursor:pointer;padding:4px;display:flex;
}
.orn-datefield__icon:hover{color:var(--orn-purple);}
.orn-cal{
  position:absolute;top:calc(100% + 6px);left:0;z-index:1300;
  width:380px;max-width:calc(100vw - 32px);
  background:#fff;border:1px solid var(--orn-line);border-radius:14px;
  box-shadow:0 18px 48px rgba(31,19,48,.16);padding:16px 18px;
}
.orn-cal[hidden]{display:none;}
.orn-cal__head{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:12px;}
.orn-cal__step{display:flex;align-items:center;gap:4px;}
.orn-cal__step-label{min-width:64px;text-align:center;font-size:var(--fs-base);font-weight:700;color:var(--orn-ink-strong);}
.orn-cal__nav{
  width:30px;height:30px;border:none;background:none;border-radius:8px;
  font-size:20px;line-height:1;color:var(--orn-ink-strong);cursor:pointer;
  display:flex;align-items:center;justify-content:center;flex:0 0 auto;
}
.orn-cal__nav:hover{background:var(--orn-purple-pale);color:var(--orn-purple);}
.orn-cal__dow{display:grid;grid-template-columns:repeat(7,1fr);margin-bottom:6px;}
.orn-cal__dow span{text-align:center;font-size:var(--fs-xs);font-weight:500;color:var(--orn-grey-500);padding:6px 0;}
.orn-cal__grid{display:grid;grid-template-columns:repeat(7,1fr);gap:2px;}
.orn-cal__day{
  aspect-ratio:1/1;border:none;background:none;border-radius:50%;
  font-family:var(--font);font-size:var(--fs-sm);color:var(--orn-ink);cursor:pointer;
  display:flex;align-items:center;justify-content:center;
}
.orn-cal__day--empty{visibility:hidden;cursor:default;}
.orn-cal__day:hover:not(.is-disabled):not(.is-selected){background:var(--orn-purple-pale);color:var(--orn-purple);}
.orn-cal__day.is-today{box-shadow:inset 0 0 0 1.5px var(--orn-purple);color:var(--orn-purple);font-weight:700;}
.orn-cal__day.is-selected{background:var(--orn-purple);color:#fff;font-weight:700;}
.orn-cal__day.is-disabled{color:var(--orn-grey-400);cursor:default;opacity:.45;}
.orn-cal__foot{display:flex;justify-content:space-between;margin-top:8px;padding-top:8px;border-top:1px solid var(--orn-line);}
.orn-cal__link{background:none;border:none;color:var(--orn-purple);font-family:var(--font);font-size:var(--fs-sm);font-weight:600;cursor:pointer;}
.orn-cal__link:hover{text-decoration:underline;}

/* ---- My Profile ---- */
.orn-profile__head{font-size:var(--fs-2xl);font-weight:700;color:var(--orn-ink-strong);margin:0 0 18px;letter-spacing:-.01em;}
.orn-profile-form{display:flex;flex-direction:column;gap:18px;}
.orn-profile-card{background:#fff;border:1px solid var(--orn-line);border-radius:14px;overflow:visible;}
.orn-profile-card__head{display:flex;align-items:center;justify-content:space-between;padding:15px 20px;border-bottom:1px solid var(--orn-line);background:var(--orn-purple-pale);border-radius:14px 14px 0 0;cursor:default;}
.orn-profile-card__head h2{margin:0;font-size:var(--fs-base);font-weight:700;color:var(--orn-ink-strong);}
.orn-profile-card__body{padding:clamp(16px,2.5vw,24px);}
.orn-profile-note{background:var(--orn-purple-pale);border-radius:10px;padding:11px 15px;font-size:var(--fs-xs);color:var(--orn-purple);margin-bottom:18px;}
.orn-profile-note--accent{
  background:linear-gradient(120deg,var(--orn-purple) 0%,var(--orn-rose,#B76E79) 100%);
  color:#fff;font-weight:500;
}
.orn-profile-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px 22px;}
.orn-profile-grid .orn-field{margin:0;}
.orn-field__label{font-size:var(--fs-sm);font-weight:600;color:var(--orn-ink-strong);margin:4px 0 10px;display:block;}
.orn-field select{
  width:100%;padding:11px 14px;border:1px solid var(--orn-line);border-radius:10px;
  font-family:var(--font);font-size:var(--fs-base);color:var(--orn-ink-strong);background:#fff;
}
.orn-field select:focus,.orn-field input:focus{outline:none;border-color:var(--orn-purple);}
.orn-field input[type="date"]{width:100%;padding:11px 14px;border:1px solid var(--orn-line);border-radius:10px;font-family:var(--font);font-size:var(--fs-base);color:var(--orn-ink-strong);}
.orn-radio-row{display:flex;gap:8px;flex-wrap:wrap;}
.orn-chips{display:flex;flex-wrap:wrap;gap:9px;}
.orn-chip{position:relative;cursor:pointer;margin:0;}
.orn-chip input{position:absolute;opacity:0;inset:0;cursor:pointer;}
.orn-chip span{
  display:inline-flex;align-items:center;justify-content:center;
  padding:11px 18px;border:1px solid var(--orn-purple-soft);border-radius:10px;
  font-size:var(--fs-sm);color:var(--orn-ink-strong);background:#fff;
  transition:background .12s ease,border-color .12s ease,color .12s ease;
}
.orn-chip:hover span{border-color:var(--orn-purple);}
.orn-chip input:checked + span{background:var(--orn-purple-pale);border-color:var(--orn-purple);color:var(--orn-purple);font-weight:600;}
.orn-chip input:focus-visible + span{box-shadow:0 0 0 3px var(--orn-purple-soft);}
.orn-profile-pwd summary{list-style:none;cursor:pointer;}
.orn-profile-pwd summary::-webkit-details-marker{display:none;}
.orn-profile-pwd[open] .orn-profile-card__head{border-bottom:1px solid var(--orn-line);}
.orn-profile-actions{margin-top:4px;}
@media (max-width:560px){ .orn-profile-grid{grid-template-columns:1fr;} }

/* ---- Personal Details (CaratLane two-column grouped layout) ---- */
.orn-pd-banner{
  display:flex;align-items:center;justify-content:space-between;gap:16px;
  background:linear-gradient(110deg,var(--orn-purple-deep) 0%,var(--orn-purple) 60%,var(--orn-purple-mid,#B76E79) 100%);
  border-radius:12px;
  padding:16px 20px;
  margin-bottom:24px;
  color:#fff;
}
.orn-pd-banner__txt{margin:0;font-size:var(--fs-sm);line-height:1.4;color:#fff;}
.orn-pd-banner__txt strong{font-weight:700;}
.orn-pd-banner__coin{flex:0 0 auto;display:flex;}
.orn-pd-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(28px,4vw,56px);}
.orn-pd-col{display:flex;flex-direction:column;gap:22px;}
.orn-pd-group{margin:0;}
.orn-pd-group__title{margin:0 0 4px;font-size:var(--fs-base);font-weight:700;color:var(--orn-ink-strong);}
.orn-pd-group__sub{margin:0 0 12px;font-size:var(--fs-xs);color:var(--orn-ink-soft);}
.orn-pd-group__title + .orn-field,
.orn-pd-group__title + .orn-phone,
.orn-pd-group__title + .orn-radio-row,
.orn-pd-group__title + .orn-datefield,
.orn-pd-group__title + select{margin-top:10px;}
.orn-pd-names{display:grid;grid-template-columns:1fr 1fr;gap:14px;}
.orn-pd-names .orn-field{margin:0;}
.orn-pd-names .orn-field label{font-size:var(--fs-2xs);color:var(--orn-ink-soft);font-weight:500;}
/* pincode field with Locate Me */
.orn-pin-input{display:flex;align-items:center;gap:8px;border:1px solid var(--orn-line);border-radius:10px;padding:0 12px;background:#fff;}
.orn-pin-input:focus-within{border-color:var(--orn-purple);}
.orn-pin-input .orn-uicon{color:var(--orn-grey-500);flex:0 0 auto;}
.orn-pin-input input{flex:1 1 auto;border:none !important;padding:11px 0 !important;background:none;font-size:var(--fs-base);min-width:0;}
.orn-pin-input input:focus{outline:none;}
.orn-pin-locate{flex:0 0 auto;background:none;border:none;color:var(--orn-purple);font-family:var(--font);font-size:var(--fs-sm);font-weight:600;cursor:pointer;white-space:nowrap;}
.orn-pin-locate:hover{text-decoration:underline;}
/* email field with verified tick */
.orn-email-input{position:relative;display:block;}
.orn-email-input input{width:100%;padding:11px 40px 11px 14px;border:1px solid var(--orn-line);border-radius:10px;font-family:var(--font);font-size:var(--fs-base);color:var(--orn-ink-strong);}
.orn-email-input input:focus{outline:none;border-color:var(--orn-purple);}
.orn-email-check{position:absolute;top:50%;right:12px;transform:translateY(-50%);width:20px;height:20px;border-radius:50%;background:var(--orn-green);color:#fff;display:flex;align-items:center;justify-content:center;}
.orn-email-check .orn-uicon{color:#fff;}
/* Save & Earn button */
.orn-pd-group--save{margin-top:auto;}
.orn-pd-save{
  width:100%;border:none;border-radius:10px;
  padding:15px 20px;
  background:var(--orn-cta-gradient);color:#fff;
  font-family:var(--font);font-size:var(--fs-base);font-weight:700;letter-spacing:.03em;
  text-transform:uppercase;cursor:pointer;
}
.orn-pd-save:hover{filter:brightness(1.06);}
@media (max-width:760px){
  .orn-pd-grid{grid-template-columns:1fr;}
  .orn-pd-col{gap:20px;}
}

/* ---- Occasion Details (CaratLane) ---- */
.orn-occ-banner{
  display:flex;align-items:center;justify-content:space-between;gap:16px;
  background:linear-gradient(100deg,#C2185B 0%,#E0588A 42%,#F0A55E 100%);
  border-radius:12px;padding:16px 22px;margin-bottom:26px;color:#fff;overflow:hidden;
}
.orn-occ-banner__txt{display:flex;flex-direction:column;gap:3px;}
.orn-occ-banner__txt strong{font-size:var(--fs-base);font-weight:700;}
.orn-occ-banner__txt span{font-size:var(--fs-sm);opacity:.95;}
.orn-occ-banner__gift{flex:0 0 auto;display:flex;}
.orn-occ-banner__gift .orn-uicon{color:#fff;opacity:.95;}
.orn-occ-group{margin-bottom:26px;}
.orn-occ-group .orn-pd-group__title{font-size:var(--fs-md);}
.orn-occ-group .orn-chips{margin-top:14px;}
.orn-occ-date{max-width:440px;margin-top:12px;}
.orn-occ-save{
  width:100%;border:none;border-radius:10px;margin-top:6px;
  padding:15px 20px;
  background:var(--orn-cta-gradient);color:#fff;
  font-family:var(--font);font-size:var(--fs-base);font-weight:700;letter-spacing:.04em;
  text-transform:uppercase;cursor:pointer;
}
.orn-occ-save:hover{filter:brightness(1.06);}

/* ---- Govt. ID ---- */
.orn-govt{display:flex;flex-direction:column;gap:16px;}
.orn-govt__select{
  width:100%;padding:14px 16px;border:1px solid var(--orn-line);border-radius:10px;
  background:var(--orn-purple-pale);font-family:var(--font);font-size:var(--fs-base);color:var(--orn-ink-strong);cursor:pointer;
}
.orn-govt__select:focus{outline:none;border-color:var(--orn-purple);}
.orn-govt__note{margin:0;font-size:var(--fs-xs);color:var(--orn-purple);}
.orn-govt__row{display:grid;grid-template-columns:1fr 1fr;gap:14px;align-items:stretch;}
.orn-govt__row input[type="text"]{
  width:100%;padding:14px 16px;border:1px solid var(--orn-line);border-radius:10px;
  font-family:var(--font);font-size:var(--fs-base);color:var(--orn-ink-strong);
}
.orn-govt__row input[type="text"]:focus{outline:none;border-color:var(--orn-purple);}
.orn-govt__upload{
  display:flex;align-items:center;justify-content:center;gap:8px;
  padding:14px 16px;border:1px dashed var(--orn-purple);border-radius:10px;
  background:var(--orn-purple-pale);color:var(--orn-purple);
  font-family:var(--font);font-weight:700;font-size:var(--fs-sm);letter-spacing:.04em;text-transform:uppercase;
  cursor:pointer;transition:background .12s ease;
}
.orn-govt__upload:hover{background:#fff;}
.orn-govt__upload .orn-uicon{color:var(--orn-purple);}
.orn-govt__current{margin:0;font-size:var(--fs-sm);color:var(--orn-green);display:flex;align-items:center;gap:6px;}
.orn-govt__current .orn-uicon{color:var(--orn-green);}
.orn-govt__current a{color:var(--orn-purple);font-weight:600;}
@media (max-width:560px){ .orn-govt__row{grid-template-columns:1fr;} }

/* ---- Addresses (clean cards) ---- */
.woocommerce-edit-address .woocommerce-MyAccount-content .woocommerce-Addresses,
.woocommerce-MyAccount-content .u-columns.addresses,
.woocommerce-MyAccount-content .woocommerce-Addresses{
  display:grid !important;grid-template-columns:1fr 1fr;gap:20px;margin:6px 0 0;width:100%;
  align-items:start;grid-auto-flow:row;
}
/* WC injects clearfix ::before/::after on .col2-set/.u-columns - they become anonymous
   grid items and shove the real cards into the wrong cells. Kill them. */
.woocommerce-edit-address .woocommerce-MyAccount-content .woocommerce-Addresses::before,
.woocommerce-edit-address .woocommerce-MyAccount-content .woocommerce-Addresses::after,
.woocommerce-MyAccount-content .u-columns.addresses::before,
.woocommerce-MyAccount-content .u-columns.addresses::after,
.woocommerce-MyAccount-content .woocommerce-Addresses::before,
.woocommerce-MyAccount-content .woocommerce-Addresses::after{display:none !important;}
/* Pin the real cards so layout is deterministic regardless of source order/pseudos. */
.woocommerce-MyAccount-content .woocommerce-Address.col-1{grid-column:1;grid-row:1;}
.woocommerce-MyAccount-content .woocommerce-Address.col-2{grid-column:2;grid-row:1;}
.woocommerce-MyAccount-content .woocommerce-Address{
  width:auto !important;float:none !important;
  background:#fff;border:1px solid var(--orn-line);border-radius:14px;padding:22px;
}
.woocommerce-MyAccount-content .woocommerce-Address-title{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px;}
.woocommerce-MyAccount-content .woocommerce-Address-title h3{font-size:var(--fs-lg);font-weight:700;color:var(--orn-ink-strong);margin:0;}
.woocommerce-MyAccount-content .woocommerce-Address-title .edit{font-size:var(--fs-sm);font-weight:600;color:var(--orn-purple);}
.woocommerce-MyAccount-content address{font-style:normal;line-height:1.7;color:var(--orn-ink-soft);font-size:var(--fs-base);}
.woocommerce-edit-address .woocommerce-MyAccount-content > p{color:var(--orn-ink-soft);margin-bottom:16px;}
@media (max-width:560px){ .woocommerce-MyAccount-content .woocommerce-Addresses{grid-template-columns:1fr !important;} }

/* ---- Sticky footer: the main content area fills at least the viewport
   (minus the announce bar + header), so on short pages the footer's gold
   line is pinned to the bottom of the screen instead of floating mid-page
   with its body running off the bottom edge. --orn-chrome-h is the measured
   announce+header height. ---- */
:root{--orn-chrome-h:180px;}
.orn-main{min-height:calc(100vh - var(--orn-chrome-h));}

/* ---- Edit-address form: reuse the My Profile card UI ---- */
.orn-addr .orn-profile-card{max-width:920px;}
.orn-addr-same{display:flex;align-items:center;gap:10px;margin:0 0 20px;font-size:var(--fs-sm);font-weight:600;color:var(--orn-ink-strong);cursor:pointer;}
.orn-addr-same input{width:18px;height:18px;accent-color:var(--orn-purple);margin:0;}
.orn-addr-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px 20px;}
.orn-addr-grid .form-row{margin:0;display:flex;flex-direction:column;gap:6px;}
.orn-addr-grid .form-row-wide,
.orn-addr-grid p[id*="address_1_field"],
.orn-addr-grid p[id*="address_2_field"],
.orn-addr-grid p[id*="company_field"],
.orn-addr-grid p[id*="city_field"],
.orn-addr-grid p[id*="state_field"],
.orn-addr-grid p[id*="postcode_field"],
.orn-addr-grid p[id*="country_field"],
.orn-addr-grid p[id*="email_field"],
.orn-addr-grid p[id*="phone_field"]{grid-column:1 / -1;}
.orn-addr-grid .form-row-first{grid-column:1;}
.orn-addr-grid .form-row-last{grid-column:2;}
.orn-addr-grid label{font-size:var(--fs-xs);font-weight:600;color:var(--orn-ink-strong);}
.orn-addr-grid label .required{color:var(--orn-rose);border:0;text-decoration:none;}
.orn-addr-grid label .optional{color:var(--orn-ink-soft);font-weight:500;}
.orn-addr-grid .woocommerce-input-wrapper{display:block;width:100%;}
.orn-addr-grid input,
.orn-addr-grid select,
.orn-addr-grid .woocommerce-input-wrapper input{
  width:100% !important;padding:11px 14px !important;
  border:1px solid var(--orn-line) !important;border-radius:10px !important;
  font-family:var(--font);font-size:var(--fs-base);color:var(--orn-ink-strong);background:#fff;
}
.orn-addr-grid input:focus,.orn-addr-grid select:focus{outline:none;border-color:var(--orn-purple) !important;}
/* select2 (country / state) skinned to match the native inputs */
.orn-addr-grid .select2-container{width:100% !important;}
.orn-addr-grid .select2-container .select2-selection--single{
  height:auto;min-height:44px;padding:6px 14px;border:1px solid var(--orn-line);border-radius:10px;background:#fff;
}
.orn-addr-grid .select2-container--default .select2-selection--single .select2-selection__rendered{
  line-height:30px;padding:0;color:var(--orn-ink-strong);
}
.orn-addr-grid .select2-container--default .select2-selection--single .select2-selection__arrow{height:100%;top:0;}
.orn-addr-save{margin-top:22px;}
@media (max-width:600px){
  .orn-addr-grid{grid-template-columns:1fr;}
  .orn-addr-grid .form-row-first,.orn-addr-grid .form-row-last{grid-column:1;}
}

/* ---- Standalone Wishlist page ---- */
.orn-wishlist-page{padding-block:clamp(24px,4vw,52px);}
.orn-wishlist-page__title{font-size:var(--fs-2xl);font-weight:700;color:var(--orn-ink-strong);margin:0 0 22px;letter-spacing:-.01em;}
/* TI prints its own wishlist name ("Default wishlist") - hide it, we have our title */
.orn-wishlist-embed .tinvwl-wishlist-title,
.orn-wishlist-embed .tinv-wishlist > h2,
.orn-wishlist-embed .tinv-header,
.orn-wishlist-embed h2.tinvwl-title,
.orn-wishlist-embed .wishlist_title,
.orn-wishlist-embed .tinvwl-table caption{display:none !important;}
.orn-wishlist-embed .tinv-wishlist{margin:0;}
.orn-wishlist-embed .woocommerce-info,
.orn-wishlist-embed .cart-empty{
  background:var(--orn-purple-pale) !important;border:none !important;border-radius:12px !important;
  padding:18px 22px !important;color:var(--orn-ink-soft);font-size:var(--fs-base);box-shadow:none !important;
}
.orn-wishlist-embed .woocommerce-info::before{display:none !important;}
.orn-wishlist-embed .return-to-shop,
.orn-wishlist-embed .wishlist-continue{margin-top:18px;}
.orn-wishlist-embed .return-to-shop .button,
.orn-wishlist-embed .wc-backward,
.orn-wishlist-embed a.button.wc-backward{
  display:inline-flex;align-items:center;gap:8px;
  background:var(--orn-cta-grad,var(--orn-purple)) !important;color:#fff !important;
  border:none !important;border-radius:999px !important;padding:12px 28px !important;font-weight:600;
}

@media (max-width:900px){
  .woocommerce-account .woocommerce{grid-template-columns:1fr;gap:20px;}
  .orn-acct-nav{position:static;}
}

/* --- 22.2 My Account dashboard card --- */
.orn-account-card{
  background:var(--orn-purple-pale);
  border:1px solid var(--orn-line);
  border-radius:var(--radius-card);
  padding:24px;
  margin-bottom:24px;
}
.orn-account-card__head h2{
  font-size:var(--fs-lg);
  font-weight:600;
  margin:0 0 4px;
}
.orn-account-card__head p{
  font-size:var(--fs-sm);
  color:var(--orn-ink-soft);
  margin:0 0 18px;
}
.orn-account-card__stats{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:12px;
  background:#fff;
  border-radius:var(--radius-card);
  padding:16px;
}
.orn-account-stat{display:flex;flex-direction:column;align-items:center;gap:4px;}
.orn-account-stat__num{
  font-size:var(--fs-lg);
  font-weight:700;
  color:var(--orn-purple);
  line-height:1.2;
}
.orn-account-stat__label{
  font-size:var(--fs-xs);
  font-weight:500;
  color:var(--orn-ink-soft);
  letter-spacing:.03em;
  text-transform:uppercase;
}
.orn-account-card__nudge{
  font-size:var(--fs-sm);
  margin:14px 0 0;
  text-align:center;
}
.orn-account-card__nudge a{
  color:var(--orn-purple);
  font-weight:600;
}
.orn-account-card__nudge a:hover{text-decoration:underline;}

/* Account profile fieldset (DOB + anniversary) */
.orn-account-fields{
  border:none;
  padding:0;
  margin:20px 0;
  display:flex;
  flex-direction:column;
  gap:8px;
}
.orn-account-fields legend{
  font-size:var(--fs-sm);
  font-weight:600;
  color:var(--orn-ink);
  padding:0;
  margin-bottom:10px;
}
.orn-account-fields__hint{
  font-weight:400;
  color:var(--orn-ink-soft);
}
.orn-account-fields .form-row label{
  display:block;
  font-size:var(--fs-sm);
  font-weight:500;
  margin-bottom:4px;
}
.orn-account-fields input[type="date"]{
  width:100%;
  padding:11px 14px;
  border:1px solid var(--orn-line);
  border-radius:8px;
  font-family:var(--font);
  font-size:var(--fs-base);
}

@media (max-width:520px){
  .orn-login-card{padding:24px 20px;}
  .orn-account-card__stats{grid-template-columns:1fr;}
}

/* ==========================================================================
   23. Loyalty (Batch 9) - My Account tab + redeem at checkout
   ========================================================================== */
.orn-loyalty__hero{
  display:grid;
  grid-template-columns:1fr 1.4fr;
  gap:24px;
  background:linear-gradient(135deg,var(--orn-purple-soft) 0%,var(--orn-purple-pale) 100%);
  border:1px solid var(--orn-line);
  border-radius:var(--radius-card);
  padding:28px;
  margin-bottom:24px;
}
.orn-loyalty__balance{
  display:flex;
  flex-direction:column;
  justify-content:center;
  align-items:center;
  text-align:center;
  background:#fff;
  border-radius:var(--radius-card);
  padding:22px 18px;
}
.orn-loyalty__balance-label{
  font-size:var(--fs-xs);
  font-weight:600;
  letter-spacing:.1em;
  color:var(--orn-purple);
  margin-bottom:4px;
}
.orn-loyalty__balance-num{
  font-size:var(--fs-display);
  font-weight:700;
  color:var(--orn-ink-strong);
  line-height:1;
  letter-spacing:-.02em;
}
.orn-loyalty__balance-rs{
  font-size:var(--fs-sm);
  font-weight:600;
  color:var(--orn-purple);
  margin-top:6px;
}
.orn-loyalty__rules h3{
  font-size:var(--fs-base);
  font-weight:600;
  margin:0 0 10px;
  color:var(--orn-ink-strong);
}
.orn-loyalty__rules ul{
  list-style:none;
  padding:0;margin:0;
  display:flex;
  flex-direction:column;
  gap:6px;
}
.orn-loyalty__rules li{
  font-size:var(--fs-sm);
  color:var(--orn-ink);
  line-height:1.45;
  padding-left:18px;
  position:relative;
}
.orn-loyalty__rules li::before{
  content:"✦";
  position:absolute;
  left:0;
  color:var(--orn-purple);
  font-size:var(--fs-xs);
  top:2px;
}

.orn-loyalty__hist-title{
  font-size:var(--fs-sm);
  font-weight:600;
  letter-spacing:.05em;
  text-transform:uppercase;
  color:var(--orn-ink-soft);
  margin:0 0 12px;
}
.orn-loyalty__empty{
  background:#fff;
  border:1px dashed var(--orn-line);
  border-radius:var(--radius-card);
  padding:24px;
  text-align:center;
  color:var(--orn-ink-soft);
  font-size:var(--fs-base);
  margin:0;
}
.orn-loyalty__hist{
  width:100%;
  background:#fff;
  border:1px solid var(--orn-line);
  border-radius:var(--radius-card);
  border-collapse:separate;
  border-spacing:0;
  overflow:hidden;
}
.orn-loyalty__hist th,
.orn-loyalty__hist td{
  padding:11px 14px;
  font-size:var(--fs-sm);
  text-align:left;
  border-bottom:1px solid var(--orn-line);
}
.orn-loyalty__hist th{
  font-weight:600;
  font-size:var(--fs-xs);
  letter-spacing:.05em;
  text-transform:uppercase;
  color:var(--orn-ink-soft);
  background:var(--orn-purple-soft);
}
.orn-loyalty__hist tbody tr:last-child td{border-bottom:none;}
.orn-loyalty__hist .orn-num{text-align:right;font-variant-numeric:tabular-nums;}
.orn-loyalty__hist-delta.is-positive{color:var(--orn-green);font-weight:600;}
.orn-loyalty__hist-delta.is-negative{color:var(--orn-rose);font-weight:600;}

@media (max-width:760px){
  .orn-loyalty__hero{grid-template-columns:1fr;}
}

/* Redeem-at-checkout card */
.orn-redeem,
.orn-redeem-empty{
  margin:14px 0 18px;
  padding:14px 16px;
  border:1px dashed var(--orn-line);
  border-radius:var(--radius-card);
  background:var(--orn-purple-soft);
}
.orn-redeem-empty{
  font-size:var(--fs-sm);
  color:var(--orn-ink-soft);
}
.orn-redeem__head{
  display:flex;
  justify-content:space-between;
  align-items:center;
  margin-bottom:8px;
}
.orn-redeem__title{
  font-size:var(--fs-sm);
  font-weight:600;
  color:var(--orn-ink-strong);
}
.orn-redeem__bal{
  font-size:var(--fs-sm);
  color:var(--orn-purple);
  font-weight:600;
}
.orn-redeem__row{
  display:flex;
  align-items:center;
  gap:10px;
}
.orn-redeem__input{
  width:120px;
  padding:9px 12px;
  border:1px solid var(--orn-line);
  border-radius:8px;
  background:#fff;
  font-family:var(--font);
  font-size:var(--fs-base);
  text-align:right;
}
.orn-redeem__max{
  font-size:var(--fs-sm);
  color:var(--orn-ink-soft);
}
.orn-redeem__hint{
  font-size:var(--fs-xs);
  color:var(--orn-ink-soft);
  margin:6px 0 0;
}

/* ==========================================================================
   24. Wishlist (Batch 10) - TI Wishlist button overrides + cart embed
   ========================================================================== */

/* --- 24.1 Header heart count badge --- */
.orn-header__wish{position:relative;display:inline-flex;align-items:center;}
.orn-wishlist-count{
  position:absolute;
  top:-4px;
  right:-6px;
  min-width:18px;
  height:18px;
  padding:0 5px;
  background:var(--orn-rose);
  color:#fff;
  border-radius:999px;
  font-size:var(--fs-2xs);
  font-weight:700;
  line-height:18px;
  text-align:center;
  letter-spacing:0;
  display:none;
}
.orn-wishlist-count.is-visible{display:inline-flex;align-items:center;justify-content:center;}

/* --- 24.2 PDP wishlist button (under title) --- */
.orn-wishlist-btn--pdp{margin:6px 0 14px;}

/* --- 24.3 Product card wishlist heart (top-right of card image) --- */
.orn-wishlist-btn--card{
  position:absolute;
  top:10px;right:10px;
  z-index:2;
}
.orn-product,
.woocommerce ul.products li.product{position:relative;}

/* --- 24.4 Restyle TI's default button --- */
.tinvwl_add_to_wishlist_button,
.tinvwl_add_to_wishlist-text{
  display:inline-flex !important;
  align-items:center !important;
  gap:6px !important;
  font-family:var(--font) !important;
  font-size:var(--fs-sm) !important;
  font-weight:600 !important;
  color:var(--orn-ink) !important;
  background:transparent !important;
  border:none !important;
  padding:6px 0 !important;
  letter-spacing:.02em;
  text-decoration:none !important;
  cursor:pointer;
  transition:color .12s ease;
}
.tinvwl_add_to_wishlist_button:hover{color:var(--orn-rose) !important;}
.tinvwl_add_to_wishlist_button .tinvwl-icon-heart,
.tinvwl_add_to_wishlist_button .tinvwl-icon-heart-empty,
.tinvwl_add_to_wishlist_button .tinvwl-icon-heart-full,
.tinvwl_add_to_wishlist_button svg{
  width:16px !important;
  height:16px !important;
  color:inherit !important;
  fill:none !important;
  stroke:currentColor !important;
  stroke-width:1.8 !important;
}
.tinvwl_add_to_wishlist_button.tinvwl-product-in-list,
.tinvwl_add_to_wishlist_button.tinvwl_button_view{
  color:var(--orn-rose) !important;
}
.tinvwl_add_to_wishlist_button.tinvwl-product-in-list svg{
  fill:var(--orn-rose) !important;
  stroke:var(--orn-rose) !important;
}

/* --- 24.5 Card variant: round white pill with the heart icon centered --- */
.orn-wishlist-btn--card .tinvwl_add_to_wishlist_button{
  display:inline-flex !important;
  align-items:center !important;
  justify-content:center !important;
  width:36px !important;
  height:36px !important;
  padding:0 !important;
  margin:0 !important;
  background:rgba(255,255,255,.96) !important;
  border-radius:50% !important;
  box-shadow:0 2px 8px -2px rgba(33,36,62,.18) !important;
  position:relative !important;
  line-height:1 !important;
  overflow:hidden !important;
  font-size:0 !important; /* nuke any text node leaking from .tinvwl-txt */
}
/* Hide the text span entirely. Belt-and-suspenders selectors so any of
 * TI's text-output spans render as 0x0 hidden. */
.orn-wishlist-btn--card .tinvwl_add_to_wishlist_button .tinvwl-txt,
.orn-wishlist-btn--card .tinvwl_add_to_wishlist_button > span.tinvwl-txt,
.orn-wishlist-btn--card .tinvwl_add_to_wishlist-text,
.orn-wishlist-btn--card .tinvwl_add_to_wishlist_button > span,
.orn-wishlist-btn--card .tinvwl_add_to_wishlist_button > .tinvwl-text{
  display:none !important;
  width:0 !important;
  height:0 !important;
  margin:0 !important;
  padding:0 !important;
  font-size:0 !important;
  visibility:hidden !important;
  overflow:hidden !important;
}
/* The heart icon is a ::before pseudo on .tinvwl-icon-heart.
 * Zero its margin so it centers perfectly inside the 36px circle. */
.orn-wishlist-btn--card .tinvwl_add_to_wishlist_button::before,
.orn-wishlist-btn--card .tinvwl_add_to_wishlist_button::after{
  margin:0 !important;
  padding:0 !important;
  display:inline-flex !important;
  align-items:center !important;
  justify-content:center !important;
  width:18px !important;
  height:18px !important;
  font-size:var(--fs-md) !important;
  line-height:1 !important;
  position:static !important;
  vertical-align:middle !important;
}

/* --- 24.6 Cart Wishlist tab embed - restyle TI's table --- */
.orn-wishlist-embed{padding:0;}
.orn-wishlist-embed .tinv-wishlist{
  margin:0;padding:0;
}
.orn-wishlist-embed table.tinvwl-table-manage-list{
  width:100%;
  background:#fff;
  border:1px solid var(--orn-line);
  border-radius:var(--radius-card);
  border-collapse:separate;
  border-spacing:0;
  overflow:hidden;
  font-family:var(--font);
}
.orn-wishlist-embed thead{background:var(--orn-purple-soft);}
.orn-wishlist-embed th{
  font-size:var(--fs-xs) !important;
  font-weight:600 !important;
  letter-spacing:.08em;
  text-transform:uppercase;
  color:var(--orn-ink-soft) !important;
  padding:14px !important;
  text-align:left !important;
  border:none !important;
}
.orn-wishlist-embed td{
  padding:14px !important;
  border-top:1px solid var(--orn-line) !important;
  border-left:none !important;
  border-right:none !important;
  font-size:var(--fs-base) !important;
  vertical-align:middle !important;
}
.orn-wishlist-embed .product-thumbnail img{
  width:64px;height:64px;
  border-radius:8px;
  object-fit:cover;
}
.orn-wishlist-embed .product-name a{
  font-weight:600;
  color:var(--orn-ink);
  font-size:var(--fs-base);
}
.orn-wishlist-embed .product-name a:hover{color:var(--orn-purple);}
.orn-wishlist-embed .product-price .amount{
  font-weight:700;
  color:var(--orn-ink-strong);
  font-size:var(--fs-base);
}
.orn-wishlist-embed .product-stock-status{
  font-size:var(--fs-sm);
  color:var(--orn-green);
  font-weight:500;
}
.orn-wishlist-embed .product-action{text-align:right !important;}
.orn-wishlist-embed .product-action .button,
.orn-wishlist-embed .product-action a.button{
  display:inline-flex !important;
  align-items:center !important;
  justify-content:center !important;
  background:var(--orn-cta-gradient) !important;
  color:#fff !important;
  border:none !important;
  padding:10px 16px !important;
  border-radius:var(--radius-pill) !important;
  font-size:var(--fs-sm) !important;
  font-weight:600 !important;
  letter-spacing:.04em;
  text-transform:uppercase;
  text-decoration:none !important;
  cursor:pointer;
}
.orn-wishlist-embed .product-action .button:hover{
  transform:translateY(-1px);
  box-shadow:0 8px 20px -10px rgba(88,50,187,.6);
}
.orn-wishlist-embed .product-remove a.remove{
  color:var(--orn-grey-500) !important;
  background:transparent !important;
  font-weight:300;
  font-size:var(--fs-xl);
}
.orn-wishlist-embed .product-remove a.remove:hover{color:var(--orn-rose) !important;}
.orn-wishlist-embed .tinv-wishlist-empty{
  background:#fff;
  border:1px dashed var(--orn-line);
  border-radius:var(--radius-card);
  padding:48px 24px;
  text-align:center;
  color:var(--orn-ink-soft);
  font-size:var(--fs-base);
}
@media (max-width:760px){
  .orn-wishlist-embed table.tinvwl-table-manage-list,
  .orn-wishlist-embed thead,
  .orn-wishlist-embed tbody,
  .orn-wishlist-embed tr,
  .orn-wishlist-embed td{
    display:block;width:100%;
  }
  .orn-wishlist-embed thead{display:none;}
  .orn-wishlist-embed tr{
    border-top:1px solid var(--orn-line);
    padding:8px 0;
  }
  .orn-wishlist-embed td{
    padding:6px 14px !important;
    border-top:none !important;
  }
}

/* ==========================================================================
   25. Shipping ETA + Order success page (Batch 11)
   ========================================================================== */

/* --- 25.1 Shipping check widget (PDP + Cart) --- */
.orn-shipping-check{
  margin:16px 0;
  padding:14px 16px;
  background:var(--orn-purple-soft);
  border-radius:var(--radius-card);
  border:1px solid var(--orn-line);
}
.orn-shipping-check--cart{margin-bottom:18px;}
.orn-shipping-check__head{
  display:flex;
  align-items:center;
  gap:8px;
  font-size:var(--fs-sm);
  font-weight:600;
  color:var(--orn-ink);
  margin-bottom:10px;
}
.orn-shipping-check__row{
  display:flex;
  gap:8px;
}
.orn-shipping-check__input{
  flex:1;
  padding:10px 12px;
  background:#fff;
  border:1px solid var(--orn-line);
  border-radius:8px;
  font-family:var(--font);
  font-size:var(--fs-base);
  letter-spacing:.05em;
}
.orn-shipping-check__input:focus{
  outline:none;
  border-color:var(--orn-purple);
  box-shadow:0 0 0 3px rgba(79,50,103,.12);
}
.orn-shipping-check__btn{
  background:var(--orn-purple);
  color:#fff;
  border:none;
  border-radius:var(--radius-pill);
  padding:10px 18px;
  font-family:var(--font);
  font-size:var(--fs-sm);
  font-weight:600;
  letter-spacing:.04em;
  text-transform:uppercase;
  cursor:pointer;
  transition:background .12s ease;
}
.orn-shipping-check__btn:hover{background:var(--orn-purple-deep);}
.orn-shipping-check__result{
  display:none;
  margin-top:12px;
  padding-top:12px;
  border-top:1px dashed var(--orn-line);
}
.orn-shipping-check__result.is-shown{display:block;}
.orn-shipping-check__loading,
.orn-shipping-check__err{
  font-size:var(--fs-sm);
  color:var(--orn-ink-soft);
}
.orn-shipping-check__err{color:var(--orn-rose);}
.orn-shipping-check__ok{display:flex;flex-direction:column;gap:4px;}
.orn-shipping-check__date{
  font-size:var(--fs-base);
  color:var(--orn-ink-strong);
}
.orn-shipping-check__loc{
  font-size:var(--fs-sm);
  color:var(--orn-ink-soft);
}
.orn-shipping-check__perks{
  display:flex;
  flex-wrap:wrap;
  gap:14px;
  margin-top:6px;
  font-size:var(--fs-sm);
  color:var(--orn-green);
  font-weight:500;
}

/* --- 25.2 Order success / thankyou page --- */
.orn-thankyou{padding-block:clamp(36px,5vw,72px);}
.orn-thankyou__hero{
  text-align:center;
  margin-bottom:32px;
}
.orn-thankyou__check{
  display:flex;
  justify-content:center;
  margin-bottom:14px;
}
.orn-thankyou__title{
  font-size:clamp(1.6rem,3vw,2.4rem);
  font-weight:600;
  margin:0 0 6px;
  letter-spacing:-.01em;
}
.orn-thankyou__sub{
  font-size:var(--fs-base);
  color:var(--orn-ink-soft);
  max-width:560px;
  margin:0 auto 8px;
}
.orn-thankyou__order-num{
  font-size:var(--fs-sm);
  color:var(--orn-ink);
  margin:0;
}

.orn-thankyou__grid{
  display:grid;
  grid-template-columns:minmax(0,1fr) 300px;
  gap:32px;
  align-items:start;
}
.orn-thankyou__main{display:flex;flex-direction:column;gap:24px;}

.orn-thankyou__eta{
  display:flex;
  align-items:center;
  gap:14px;
  padding:18px 20px;
  background:linear-gradient(135deg,var(--orn-purple-soft) 0%,var(--orn-purple-pale) 100%);
  border:1px solid var(--orn-line);
  border-radius:var(--radius-card);
}
.orn-thankyou__eta-icon{font-size:var(--fs-3xl);}
.orn-thankyou__eta-label{
  font-size:var(--fs-xs);
  font-weight:700;
  letter-spacing:.08em;
  text-transform:uppercase;
  color:var(--orn-purple);
}
.orn-thankyou__eta-date{
  font-size:var(--fs-lg);
  font-weight:700;
  color:var(--orn-ink-strong);
  margin:2px 0;
}
.orn-thankyou__eta-pin{font-weight:500;color:var(--orn-ink-soft);font-size:var(--fs-base);margin-left:4px;}
.orn-thankyou__eta-region{
  font-size:var(--fs-sm);
  color:var(--orn-green);
  font-weight:500;
}

.orn-thankyou__sec-title{
  font-size:var(--fs-sm);
  font-weight:700;
  letter-spacing:.08em;
  text-transform:uppercase;
  color:var(--orn-ink);
  margin:0 0 10px;
}

/* Timeline */
.orn-thankyou__timeline{
  list-style:none;
  margin:0;
  padding:0 0 0 8px;
  display:flex;
  flex-direction:column;
  gap:14px;
  position:relative;
}
.orn-thankyou__timeline::before{
  content:"";
  position:absolute;
  left:4px;
  top:8px;bottom:8px;
  width:2px;
  background:var(--orn-line);
}
.orn-thankyou__timeline li{
  display:flex;
  gap:12px;
  align-items:flex-start;
  position:relative;
}
.orn-thankyou__step-dot{
  width:10px;height:10px;
  background:var(--orn-line);
  border-radius:50%;
  margin-top:5px;
  flex-shrink:0;
  z-index:1;
}
.orn-thankyou__timeline li.is-active .orn-thankyou__step-dot{
  background:var(--orn-purple);
  box-shadow:0 0 0 4px rgba(79,50,103,.15);
}
.orn-thankyou__timeline li strong{
  display:block;
  font-size:var(--fs-base);
  font-weight:600;
  color:var(--orn-ink-strong);
}
.orn-thankyou__timeline li span{
  display:block;
  font-size:var(--fs-sm);
  color:var(--orn-ink-soft);
}

/* Items */
.orn-thankyou__items{
  display:flex;
  flex-direction:column;
  gap:10px;
  background:#fff;
  border:1px solid var(--orn-line);
  border-radius:var(--radius-card);
  padding:14px;
}
.orn-thankyou__item{
  display:grid;
  grid-template-columns:72px minmax(0,1fr) auto;
  gap:14px;
  align-items:center;
}
.orn-thankyou__item-thumb img{
  width:72px;height:72px;
  border-radius:8px;
  object-fit:cover;
}
.orn-thankyou__item-name{font-weight:600;font-size:var(--fs-base);}
.orn-thankyou__item-meta{font-size:var(--fs-sm);color:var(--orn-ink-soft);}
.orn-thankyou__item-price{font-size:var(--fs-base);font-weight:700;}

/* Totals */
.orn-thankyou__totals{
  background:#fff;
  border:1px solid var(--orn-line);
  border-radius:var(--radius-card);
  padding:14px 18px;
}
.orn-thankyou__totals-row{
  display:flex;
  justify-content:space-between;
  padding:6px 0;
  font-size:var(--fs-base);
}
.orn-thankyou__totals-row.is-grand{
  font-size:var(--fs-md);
  font-weight:700;
  border-top:1px solid var(--orn-line);
  margin-top:8px;
  padding-top:10px;
}

/* CTA row */
.orn-thankyou__cta-row{
  display:flex;
  gap:12px;
  margin-top:8px;
}
.orn-thankyou__cta-row .orn-btn{
  flex:1;
  padding:14px 18px;
  border-radius:var(--radius-pill);
  font-size:var(--fs-sm);
  font-weight:700;
  letter-spacing:.05em;
  text-transform:uppercase;
  text-align:center;
  display:inline-flex;
  align-items:center;
  justify-content:center;
}
.orn-btn--primary{
  background:var(--orn-cta-gradient);
  color:#fff;
}
.orn-btn--ghost{
  background:#fff;
  border:1px solid var(--orn-purple);
  color:var(--orn-purple);
}
.orn-btn--ghost:hover{background:var(--orn-purple-soft);color:var(--orn-purple);}
.orn-btn--primary:hover{
  transform:translateY(-1px);
  box-shadow:0 8px 20px -10px rgba(88,50,187,.6);
  color:#fff;
}

/* Side card */
.orn-thankyou__side{
  background:#fff;
  border:1px solid var(--orn-line);
  border-radius:var(--radius-card);
  padding:22px;
  position:sticky;
  top:80px;
}
.orn-thankyou__side h3{
  font-size:var(--fs-xs);
  font-weight:700;
  letter-spacing:.08em;
  text-transform:uppercase;
  color:var(--orn-ink-soft);
  margin:12px 0 6px;
}
.orn-thankyou__side h3:first-child{margin-top:0;}
.orn-thankyou__side address{
  font-style:normal;
  font-size:var(--fs-base);
  line-height:1.5;
}
.orn-thankyou__side p{font-size:var(--fs-base);margin:0 0 6px;line-height:1.5;}
.orn-thankyou__side a{color:var(--orn-purple);}
.orn-thankyou__giftmsg{font-style:italic;color:var(--orn-ink-soft);}

@media (max-width:900px){
  .orn-thankyou__grid{grid-template-columns:1fr;}
  .orn-thankyou__side{position:static;}
}

/* ==========================================================================
   26. Home page (Batch 13) - 7-section CaratLane composition
   ========================================================================== */

/* --- 26.1 Hero --- */
.orn-home-hero{
  position:relative;
  overflow:hidden;
  padding-block:clamp(56px,8vw,108px);
  background:linear-gradient(135deg,var(--orn-purple-soft) 0%,var(--orn-purple-pale) 60%,#fff 100%);
}
.orn-home-hero__bg{
  position:absolute;
  inset:0;
  background:
    radial-gradient(circle at 80% 20%, rgba(199,125,199,.18) 0%, transparent 60%),
    radial-gradient(circle at 20% 80%, rgba(142,99,183,.12) 0%, transparent 60%);
  pointer-events:none;
}
.orn-home-hero__inner{
  position:relative;
  display:grid;
  grid-template-columns:minmax(0,1.2fr) minmax(0,1fr);
  gap:48px;
  align-items:center;
}
.orn-home-hero__copy{display:flex;flex-direction:column;gap:14px;align-items:flex-start;text-align:left;}
.orn-home-hero__eyebrow{margin:0;text-align:left;}
.orn-home-hero__title{
  font-size:clamp(2rem,5vw,3.6rem);
  font-weight:600;
  margin:0;
  line-height:1.08;
  letter-spacing:-.02em;
  color:var(--orn-ink-strong);
}
.orn-home-hero__sub{
  font-size:clamp(1rem,1.5vw,1.15rem);
  color:var(--orn-ink-soft);
  max-width:520px;
  margin:0;
  line-height:1.55;
}
.orn-home-hero__cta{
  display:flex;
  flex-wrap:wrap;
  gap:12px;
  margin-top:8px;
}
.orn-home-hero__cta .orn-btn{padding:14px 28px;}
.orn-home-hero__rate{
  font-size:var(--fs-sm);
  color:var(--orn-ink);
  margin:8px 0 0;
  padding:8px 14px;
  background:var(--orn-cream);
  border-radius:var(--radius-pill);
  display:inline-block;
}
.orn-home-hero__art{
  position:relative;
  width:100%;
  height:clamp(260px,40vw,420px);
}
.orn-home-hero__circle{
  position:absolute;
  border-radius:50%;
  background:linear-gradient(135deg,var(--orn-purple-mid),var(--orn-purple-pale));
  opacity:.45;
}
.orn-home-hero__circle--lg{width:320px;height:320px;right:0;top:20px;}
.orn-home-hero__circle--md{width:180px;height:180px;right:160px;top:160px;background:linear-gradient(135deg,#D9BE7E,var(--orn-purple-pale));opacity:.6;}
.orn-home-hero__circle--sm{width:90px;height:90px;right:260px;top:80px;background:linear-gradient(135deg,#fff,var(--orn-purple-soft));opacity:.95;}

@media (max-width:900px){
  .orn-home-hero__inner{grid-template-columns:1fr;gap:24px;}
  .orn-home-hero__art{display:none;}
}

/* --- 26.2 Category tiles --- */
.orn-home-cats__grid{
  display:grid;
  grid-template-columns:repeat(6,minmax(0,1fr));
  gap:14px;
}
.orn-home-cat{
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  gap:8px;
  padding:24px 14px;
  background:var(--orn-white);
  border:1px solid var(--orn-line);
  border-radius:var(--radius-card);
  text-decoration:none;
  color:var(--orn-ink);
  transition:transform .15s ease,box-shadow .15s ease,border-color .15s ease;
  position:relative;
  text-align:center;
}
.orn-home-cat:hover{
  transform:translateY(-4px);
  box-shadow:var(--shadow-card-hover);
  border-color:var(--orn-purple-mid);
  color:var(--orn-purple);
}
.orn-home-cat__icon{
  font-size:var(--fs-3xl);
  color:var(--orn-purple);
  line-height:1;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  width:48px;height:48px;
  border-radius:50%;
  background:var(--orn-purple-soft);
}
.orn-home-cat--a .orn-home-cat__icon{background:#F5E9E4;}
.orn-home-cat--b .orn-home-cat__icon{background:#E3D5C3;}
.orn-home-cat--c .orn-home-cat__icon{background:#E8F5EE;color:var(--orn-green);}
.orn-home-cat--d .orn-home-cat__icon{background:#FDECEE;color:var(--orn-rose);}
.orn-home-cat--e .orn-home-cat__icon{background:#FBF6EA;}
.orn-home-cat--f .orn-home-cat__icon{background:#F5E9E4;}
.orn-home-cat__label{
  font-size:var(--fs-sm);
  font-weight:600;
  letter-spacing:.02em;
}
.orn-home-cat__arrow{
  font-size:var(--fs-sm);
  color:var(--orn-grey-500);
  transition:transform .15s ease,color .15s ease;
}
.orn-home-cat:hover .orn-home-cat__arrow{
  transform:translateX(4px);
  color:var(--orn-purple);
}
@media (max-width:760px){
  .orn-home-cats__grid{grid-template-columns:repeat(3,1fr);}
}

/* --- 26.3 Trending grid --- */
.orn-home-trending__grid{
  display:grid;
  grid-template-columns:repeat(4,minmax(0,1fr));
  gap:18px;
}
.orn-home-trending__card{
  background:#fff;
  border-radius:var(--radius-card);
  overflow:hidden;
  box-shadow:var(--shadow-card);
  transition:transform .15s ease,box-shadow .15s ease;
  position:relative;
}
.orn-home-trending__card:hover{
  transform:translateY(-3px);
  box-shadow:var(--shadow-card-hover);
}
.orn-home-trending__card .orn-product__media{
  display:block;
  aspect-ratio:1/1;
  background:var(--orn-purple-soft);
}
.orn-home-trending__card .orn-product__media img{
  width:100%;height:100%;
  object-fit:cover;
}
.orn-home-trending__card .orn-product__body{
  padding:14px;
  display:flex;
  flex-direction:column;
  gap:6px;
}
.orn-home-trending__card .orn-product__name{
  font-size:var(--fs-base);
  font-weight:600;
  color:var(--orn-ink-strong);
  text-decoration:none;
  line-height:1.35;
  display:-webkit-box;
  -webkit-line-clamp:2;
  -webkit-box-orient:vertical;
  overflow:hidden;
}
.orn-home-trending__card .orn-product__price{
  font-size:var(--fs-base);
  font-weight:700;
  color:var(--orn-purple);
}
.orn-home-trending__card .orn-product__cta{
  font-size:var(--fs-sm);
  font-weight:600;
  color:var(--orn-purple);
  letter-spacing:.04em;
  text-transform:uppercase;
  margin-top:4px;
  align-self:flex-start;
}
@media (max-width:900px){
  .orn-home-trending__grid{grid-template-columns:repeat(2,1fr);}
}

/* --- 26.4 Three-tier pillars --- */
.orn-home-pillars__grid{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:18px;
}
.orn-home-pillar{
  position:relative;
  display:flex;
  flex-direction:column;
  gap:8px;
  padding:28px 26px;
  background:#fff;
  border:1px solid var(--orn-line);
  border-radius:var(--radius-card);
  text-decoration:none;
  color:var(--orn-ink);
  overflow:hidden;
  transition:transform .15s ease,box-shadow .15s ease,border-color .15s ease;
}
.orn-home-pillar:hover{
  transform:translateY(-3px);
  box-shadow:var(--shadow-card-hover);
  border-color:var(--orn-purple-mid);
}
.orn-home-pillar h3{
  font-size:var(--fs-xl);
  font-weight:600;
  margin:0;
  color:var(--orn-ink-strong);
}
.orn-home-pillar__lead{
  font-size:var(--fs-base);
  color:var(--orn-ink-soft);
  margin:4px 0 0;
  line-height:1.5;
  min-height:64px;
}
.orn-home-pillar__rate{
  font-size:var(--fs-sm);
  font-weight:600;
  color:var(--orn-purple);
  margin:4px 0 0;
}
.orn-home-pillar__more{
  font-size:var(--fs-sm);
  font-weight:600;
  letter-spacing:.02em;
  margin-top:auto;
  color:var(--orn-purple);
}
.orn-home-pillar__dot{
  position:absolute;
  top:18px;right:18px;
  width:14px;height:14px;
  border-radius:50%;
}
.orn-home-pillar--gold .orn-home-pillar__dot{background:linear-gradient(135deg,#D9BE7E,#C9A44C);}
.orn-home-pillar--silver .orn-home-pillar__dot{background:linear-gradient(135deg,#D9D9DC,#9D9FA4);}
.orn-home-pillar--demi .orn-home-pillar__dot{background:linear-gradient(135deg,#EB4F5C,#4E1B26);}
@media (max-width:760px){
  .orn-home-pillars__grid{grid-template-columns:1fr;}
}

/* --- 26.5 Reviews --- */
.orn-home-reviews__grid{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:18px;
}
.orn-home-review{
  background:#fff;
  border:1px solid var(--orn-line);
  border-radius:var(--radius-card);
  padding:22px;
  display:flex;
  flex-direction:column;
  gap:12px;
}
.orn-home-review__head{
  display:flex;
  align-items:center;
  gap:12px;
}
.orn-home-review__avatar{
  width:40px;height:40px;
  border-radius:50%;
  background:var(--orn-purple);
  color:#fff;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  font-weight:700;
  font-size:var(--fs-md);
}
.orn-home-review__meta{
  display:flex;
  flex-direction:column;
  gap:2px;
}
.orn-home-review__name{
  font-size:var(--fs-base);
  font-weight:600;
  color:var(--orn-ink-strong);
}
.orn-home-review__verified{
  margin-left:auto;
  font-size:var(--fs-xs);
  font-weight:600;
  color:var(--orn-green);
  background:#E8F5EE;
  padding:3px 8px;
  border-radius:var(--radius-pill);
}
.orn-home-review__body{
  font-size:var(--fs-base);
  color:var(--orn-ink);
  line-height:1.55;
  margin:0;
}
.orn-home-review__product{
  font-size:var(--fs-sm);
  font-weight:600;
  color:var(--orn-purple);
  text-decoration:none;
}
.orn-stars{display:inline-flex;gap:1px;}
.orn-star{
  color:var(--orn-grey-400);
  font-size:var(--fs-base);
  line-height:1;
}
.orn-star.is-full{color:#D9BE7E;}
@media (max-width:760px){
  .orn-home-reviews__grid{grid-template-columns:1fr;}
}

/* --- 26.6 USP strip --- */
.orn-home-usp{
  background:var(--orn-purple-deep);
  color:#D9C4A9;
  padding-block:36px;
}
.orn-home-usp__grid{
  display:grid;
  grid-template-columns:repeat(4,minmax(0,1fr));
  gap:24px;
}
.orn-home-usp__item{
  display:flex;
  flex-direction:column;
  align-items:center;
  text-align:center;
  gap:4px;
}
.orn-home-usp__icon{
  font-size:var(--fs-2xl);
  margin-bottom:4px;
}
.orn-home-usp__item strong{
  font-size:var(--fs-base);
  font-weight:600;
  color:#fff;
  letter-spacing:.02em;
}
.orn-home-usp__item span{
  font-size:var(--fs-sm);
  color:#B7AFA6;
}
@media (max-width:760px){
  .orn-home-usp__grid{grid-template-columns:repeat(2,1fr);gap:18px;}
}

/* --- 26.7 Newsletter --- */
.orn-home-newsletter{
  background:linear-gradient(135deg,var(--orn-purple-soft),var(--orn-purple-pale));
}
.orn-home-newsletter__inner{
  display:grid;
  grid-template-columns:minmax(0,1fr) minmax(0,1fr);
  gap:32px;
  align-items:center;
}
.orn-home-newsletter__copy h2{margin:6px 0 8px;font-size:clamp(1.5rem,2.2vw,2rem);}
.orn-home-newsletter__copy p{font-size:var(--fs-base);color:var(--orn-ink-soft);margin:0;}
.orn-home-newsletter__form{
  display:grid;
  grid-template-columns:minmax(0,1fr) auto;
  gap:10px;
}
.orn-home-newsletter__input{
  padding:14px 18px;
  background:#fff;
  border:1px solid var(--orn-line);
  border-radius:var(--radius-pill);
  font-family:var(--font);
  font-size:var(--fs-base);
  width:100%;
}
.orn-home-newsletter__input:focus{
  outline:none;
  border-color:var(--orn-purple);
  box-shadow:0 0 0 3px rgba(79,50,103,.12);
}
.orn-home-newsletter__form .orn-btn{padding:14px 32px;}
.orn-home-newsletter__msg{
  grid-column:1 / -1;
  font-size:var(--fs-sm);
  margin:0;
  min-height:1em;
  color:var(--orn-ink-soft);
}
.orn-home-newsletter__msg.is-success{color:var(--orn-green);}
.orn-home-newsletter__msg.is-error{color:var(--orn-rose);}
@media (max-width:760px){
  .orn-home-newsletter__inner{grid-template-columns:1fr;}
  .orn-home-newsletter__form{grid-template-columns:1fr;}
}

/* --- ghost button on dark hero --- */
.orn-btn--ghost-light{
  background:rgba(255,255,255,.85);
  border:1px solid var(--orn-purple);
  color:var(--orn-purple);
}
.orn-btn--ghost-light:hover{
  background:#fff;
  color:var(--orn-purple);
}

/* ==========================================================================
   27. Footer (Batch 14) - full Ornamae footer with brand col + trust badges
   ========================================================================== */
.orn-footer__col--brand{grid-column:span 1;}
.orn-footer__brand{margin-bottom:12px;}
.orn-footer__logo{
  font-family:var(--font);
  font-size:var(--fs-xl);
  font-weight:700;
  letter-spacing:.04em;
  color:#fff;
  text-decoration:none;
}
.orn-footer__lbl{
  display:inline-block;
  min-width:48px;
  font-size:var(--fs-xs);
  letter-spacing:.06em;
  text-transform:uppercase;
  color:#8A8079;
  font-weight:600;
}
.orn-footer__social{display:flex;gap:8px;margin-top:18px;}
.orn-footer__social a{
  width:36px;
  height:36px;
  border-radius:50%;
  border:1px solid rgba(255,255,255,.18);
  background:rgba(255,255,255,.03);
  display:inline-flex;
  align-items:center;
  justify-content:center;
  color:#D9C4A9;
  text-decoration:none;
  transition:background .12s ease,border-color .12s ease,color .12s ease;
}
.orn-footer__social a:hover{
  border-color:#fff;
  background:rgba(255,255,255,.1);
  color:#fff;
}
.orn-footer__badges{
  display:flex;
  flex-wrap:wrap;
  gap:14px;
  justify-content:center;
  padding:22px 0 28px;
  margin-top:10px;
  border-top:1px solid rgba(255,255,255,.08);
}
.orn-footer__badge{
  font-size:var(--fs-sm);
  color:#B7AFA6;
  font-weight:500;
  letter-spacing:.02em;
}
.orn-footer__bar{
  background:rgba(0,0,0,.18);
  padding:14px 0;
  border-top:1px solid rgba(255,255,255,.06);
}
.orn-footer__bar-inner{
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:20px;
  flex-wrap:wrap;
  font-size:var(--fs-sm);
  color:#B7AFA6;
}
.orn-footer__legal a{color:#B7AFA6;}
.orn-footer__legal a:hover{color:#fff;}
.orn-payicons{
  display:flex;
  flex-wrap:wrap;
  gap:6px;
  align-items:center;
}
.orn-payicon{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding:5px 10px;
  background:rgba(255,255,255,.06);
  border:1px solid rgba(255,255,255,.14);
  border-radius:6px;
  font-size:var(--fs-2xs);
  font-weight:700;
  letter-spacing:.04em;
  color:#fff;
}
@media (max-width:760px){
  .orn-footer__badges{gap:10px;font-size:var(--fs-sm);}
  .orn-footer__bar-inner{flex-direction:column;align-items:flex-start;}
}

/* ==========================================================================
   28. Order workflow timeline (Batch 15) - customer view
   ========================================================================== */
.orn-vieworder-timeline{
  background:#fff;
  border:1px solid var(--orn-line);
  border-radius:var(--radius-card);
  padding:22px;
  margin:0 0 22px;
}
.orn-vieworder-timeline__title{
  font-size:var(--fs-sm);
  font-weight:700;
  letter-spacing:.08em;
  text-transform:uppercase;
  color:var(--orn-ink);
  margin:0 0 14px;
}
.orn-vieworder-timeline__steps{
  list-style:none;
  margin:0;padding:0;
  display:grid;
  grid-template-columns:repeat(5,minmax(0,1fr));
  gap:8px;
  position:relative;
}
.orn-vieworder-timeline__steps::before{
  content:"";
  position:absolute;
  left:5%;right:5%;
  top:14px;
  height:2px;
  background:var(--orn-line);
  z-index:0;
}
.orn-vot{
  display:flex;
  flex-direction:column;
  align-items:center;
  gap:6px;
  position:relative;
  z-index:1;
}
.orn-vot__num{
  width:28px;height:28px;
  border-radius:50%;
  background:var(--orn-line);
  color:#fff;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  font-weight:700;
  font-size:var(--fs-sm);
  transition:background .15s ease,transform .15s ease,box-shadow .15s ease;
}
.orn-vot__label{
  font-size:var(--fs-xs);
  text-align:center;
  font-weight:500;
  color:var(--orn-ink-soft);
  line-height:1.3;
}
.orn-vot--done .orn-vot__num{
  background:var(--orn-purple);
}
.orn-vot--done .orn-vot__label{color:var(--orn-purple);}
.orn-vot--active .orn-vot__num{
  background:var(--orn-gold);
  color:var(--orn-ink-strong);
  box-shadow:0 0 0 4px rgba(251,197,11,.25);
  transform:scale(1.05);
}
.orn-vot--active .orn-vot__label{
  color:var(--orn-ink-strong);
  font-weight:700;
}

@media (max-width:560px){
  .orn-vot__label{font-size:var(--fs-2xs);}
  .orn-vot__num{width:24px;height:24px;font-size:var(--fs-sm);}
  .orn-vieworder-timeline__steps::before{top:12px;}
}

/* ==========================================================================
   29. Reviews (Batch 16) - interactive 5-star widget + styled list
   ========================================================================== */

/* 5-star rating input on review form */
.orn-rating-input{
  margin:14px 0;
}
.orn-rating-input > label{
  display:block;
  font-size:var(--fs-sm);
  font-weight:600;
  margin-bottom:8px;
  color:var(--orn-ink);
}
.orn-rating-input__stars{
  display:inline-flex;
  flex-direction:row-reverse;
  gap:4px;
}
.orn-rating-input__stars input[type="radio"]{
  position:absolute;
  opacity:0;
  pointer-events:none;
}
.orn-rating-input__star{
  cursor:pointer;
  font-size:var(--fs-3xl);
  line-height:1;
  color:var(--orn-grey-400);
  transition:color .12s ease,transform .12s ease;
}
.orn-rating-input__star:hover,
.orn-rating-input__star:hover ~ .orn-rating-input__star,
.orn-rating-input__stars input:checked ~ .orn-rating-input__star{
  color:#D9BE7E;
}
.orn-rating-input__star:hover{transform:scale(1.1);}

/* Sort dropdown above review list */
.orn-reviews-sort{
  display:flex;
  align-items:center;
  gap:8px;
  margin:0 0 16px;
  font-size:var(--fs-sm);
  color:var(--orn-ink-soft);
}
.orn-reviews-sort label{font-weight:500;}
.orn-reviews-sort select{
  padding:8px 30px 8px 14px;
  border:1px solid var(--orn-line);
  border-radius:var(--radius-pill);
  background:#fff;
  font-family:var(--font);
  font-size:var(--fs-sm);
  font-weight:500;
  color:var(--orn-ink);
  cursor:pointer;
  appearance:none;
  -webkit-appearance:none;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6' viewBox='0 0 10 6'%3E%3Cpath fill='%234E555E' d='M0 0l5 6 5-6z'/%3E%3C/svg%3E");
  background-repeat:no-repeat;
  background-position:right 14px center;
}

/* Verified-buyer badge inside the review header */
.orn-review-verified{
  display:inline-flex;
  align-items:center;
  font-size:var(--fs-xs);
  font-weight:600;
  color:var(--orn-green);
  background:#E8F5EE;
  padding:3px 9px;
  border-radius:var(--radius-pill);
  margin-left:8px;
  letter-spacing:.02em;
}

/* Woo's own review list - light restyling so it matches our cards */
#reviews .commentlist{
  list-style:none;
  margin:0;padding:0;
  display:flex;
  flex-direction:column;
  gap:14px;
}
#reviews .comment_container{
  display:flex;
  gap:14px;
  background:#fff;
  border:1px solid var(--orn-line);
  border-radius:var(--radius-card);
  padding:18px;
}
#reviews .comment_container .avatar,
#reviews .comment_container img.avatar{
  width:44px !important;
  height:44px !important;
  border-radius:50%;
  object-fit:cover;
  background:var(--orn-purple-soft);
}
#reviews .comment-text{flex:1;}
#reviews .meta{
  font-size:var(--fs-sm);
  color:var(--orn-ink-soft);
  margin:0 0 6px;
}
#reviews .meta strong{
  font-size:var(--fs-base);
  font-weight:600;
  color:var(--orn-ink-strong);
  margin-right:6px;
}
#reviews .star-rating{
  display:inline-block;
  font-size:var(--fs-sm);
  letter-spacing:1px;
  color:#D9BE7E;
  margin-right:8px;
}
#reviews .description{
  font-size:var(--fs-base);
  color:var(--orn-ink);
  line-height:1.55;
  margin:0;
}
#review_form_wrapper{
  margin-top:24px;
  background:#fff;
  border:1px solid var(--orn-line);
  border-radius:var(--radius-card);
  padding:22px;
}
#review_form .comment-form-comment label{
  display:block;font-weight:600;font-size:var(--fs-sm);margin:14px 0 6px;
}
#review_form .comment-form-comment textarea{
  width:100%;
  padding:12px 14px;
  border:1px solid var(--orn-line);
  border-radius:8px;
  font-family:var(--font);
  font-size:var(--fs-base);
}
#review_form .form-submit input{
  background:var(--orn-cta-gradient);
  color:#fff;
  border:none;
  padding:14px 28px;
  border-radius:var(--radius-pill);
  font-weight:700;
  font-size:var(--fs-sm);
  letter-spacing:.05em;
  text-transform:uppercase;
  cursor:pointer;
  min-height:48px;
}

/* --- Photo upload row on review form --- */
.orn-review-photos{margin:14px 0;}
.orn-review-photos label{
  display:block;
  font-weight:600;
  font-size:var(--fs-sm);
  margin-bottom:6px;
  color:var(--orn-ink);
}
.orn-review-photos__hint{
  font-weight:400;
  color:var(--orn-ink-soft);
  font-size:var(--fs-sm);
}
.orn-review-photos input[type="file"]{
  display:block;
  padding:10px 0;
  font-size:var(--fs-sm);
  font-family:var(--font);
  color:var(--orn-ink);
}
.orn-review-photos__preview{
  display:flex;
  flex-wrap:wrap;
  gap:8px;
  margin-top:8px;
}
.orn-review-photos__preview img{
  width:72px;height:72px;
  border-radius:8px;
  object-fit:cover;
  border:1px solid var(--orn-line);
}

/* --- Photo gallery inside a review --- */
.orn-review-gallery{
  display:flex;
  flex-wrap:wrap;
  gap:8px;
  margin:10px 0 4px;
}
.orn-review-photo img{
  width:80px;height:80px;
  border-radius:8px;
  object-fit:cover;
  border:1px solid var(--orn-line);
  transition:transform .15s ease,box-shadow .15s ease;
  display:block;
}
.orn-review-photo:hover img{
  transform:scale(1.03);
  box-shadow:var(--shadow-card-hover);
}

/* --- Helpful-vote row --- */
.orn-review-helpful{
  display:flex;
  align-items:center;
  gap:12px;
  margin-top:10px;
  padding-top:10px;
  border-top:1px solid var(--orn-line);
}
.orn-review-helpful__btn{
  display:inline-flex;
  align-items:center;
  gap:6px;
  padding:7px 16px;
  background:#fff;
  border:1px solid var(--orn-line);
  border-radius:var(--radius-pill);
  color:var(--orn-ink);
  font-family:var(--font);
  font-size:var(--fs-sm);
  font-weight:600;
  letter-spacing:.02em;
  cursor:pointer;
  transition:background .12s ease,border-color .12s ease,color .12s ease;
}
.orn-review-helpful__btn:hover{
  border-color:var(--orn-purple);
  background:var(--orn-purple-soft);
  color:var(--orn-purple);
}
.orn-review-helpful__btn.is-voted{
  background:var(--orn-purple-soft);
  border-color:var(--orn-purple);
  color:var(--orn-purple);
  cursor:default;
}
.orn-review-helpful__count{
  font-size:var(--fs-sm);
  color:var(--orn-ink-soft);
}

/* ==========================================================================
   30. Mobile polish + drawer nav (Batch 18)
   ========================================================================== */

/* --- 30.1 Hamburger button (mobile-only) --- */
.orn-header__hamburger{
  display:none;
  background:transparent;
  border:none;
  padding:0;
  width:44px;
  height:44px;
  cursor:pointer;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  gap:5px;
  margin-right:8px;
}
.orn-header__hamburger span{
  display:block;
  width:22px;
  height:2px;
  background:var(--orn-ink-strong);
  border-radius:2px;
  transition:transform .2s ease,opacity .2s ease;
}

/* --- 30.2 Mobile nav drawer --- */
.orn-mnav{
  position:fixed;
  top:0;left:0;
  width:min(86vw,360px);
  height:100dvh;
  background:#fff;
  z-index:300;
  display:flex;
  flex-direction:column;
  box-shadow:12px 0 32px -8px rgba(33,36,62,.22);
  transform:translateX(-100%);
  transition:transform .25s cubic-bezier(.22,.61,.36,1);
  visibility:hidden;
  padding-top:env(safe-area-inset-top, 0);
}
.orn-mnav.is-open{transform:translateX(0);visibility:visible;}
.orn-mnav-scrim{
  position:fixed;
  inset:0;
  background:rgba(33,36,62,.4);
  z-index:250;
  opacity:0;
  visibility:hidden;
  transition:opacity .2s ease;
}
.orn-mnav-scrim.is-open{opacity:1;visibility:visible;}
body.orn-mnav-open{overflow:hidden;}

.orn-mnav__head{
  display:flex;
  justify-content:space-between;
  align-items:center;
  padding:18px 20px;
  border-bottom:1px solid var(--orn-line);
  flex-shrink:0;
}
.orn-mnav__logo{
  font-size:var(--fs-lg);
  font-weight:700;
  color:var(--orn-purple);
  letter-spacing:.04em;
  text-decoration:none;
}
.orn-mnav__close{
  background:transparent;
  border:none;
  font-size:var(--fs-3xl);
  line-height:1;
  color:var(--orn-ink);
  cursor:pointer;
  width:44px;height:44px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
}
.orn-mnav__body{
  flex:1;
  overflow-y:auto;
  -webkit-overflow-scrolling:touch;
  padding:0 0 env(safe-area-inset-bottom, 16px);
}
.orn-mnav__greet,
.orn-mnav__signin{
  display:block;
  padding:14px 20px;
  font-size:var(--fs-base);
  color:var(--orn-ink-strong);
  background:var(--orn-purple-soft);
  text-decoration:none;
}
.orn-mnav__signin{color:var(--orn-purple);font-weight:600;}

.orn-mnav__list{
  list-style:none;
  margin:0;
  padding:0;
}
.orn-mnav__item{border-bottom:1px solid var(--orn-line);}
.orn-mnav__top{
  display:flex;
  justify-content:space-between;
  align-items:center;
  padding:16px 20px;
  font-size:var(--fs-lg);
  font-weight:600;
  color:var(--orn-ink-strong);
  text-decoration:none;
  cursor:pointer;
  list-style:none;
  min-height:52px;
}
.orn-mnav__top::-webkit-details-marker{display:none;}
.orn-mnav__chev{
  font-size:var(--fs-xl);
  color:var(--orn-grey-500);
  font-weight:300;
  transition:transform .15s ease;
}
.orn-mnav__details[open] > .orn-mnav__top .orn-mnav__chev{transform:rotate(90deg);}

.orn-mnav__sub{
  background:var(--orn-purple-soft);
  padding:6px 0 12px;
}
.orn-mnav__shop-all{
  display:block;
  padding:10px 20px;
  font-size:var(--fs-base);
  font-weight:600;
  color:var(--orn-purple);
  text-decoration:none;
}
.orn-mnav__group{
  border-top:1px solid rgba(255,255,255,.6);
}
.orn-mnav__group summary{
  display:flex;
  justify-content:space-between;
  align-items:center;
  padding:12px 20px;
  font-size:var(--fs-base);
  font-weight:600;
  letter-spacing:.05em;
  text-transform:uppercase;
  color:var(--orn-ink-soft);
  cursor:pointer;
  list-style:none;
  min-height:44px;
}
.orn-mnav__group summary::-webkit-details-marker{display:none;}
.orn-mnav__group[open] summary span{transform:rotate(45deg);}
.orn-mnav__group summary span{
  font-size:var(--fs-lg);
  font-weight:300;
  transition:transform .15s ease;
  color:var(--orn-grey-500);
}
.orn-mnav__group ul,
.orn-mnav__plain{
  list-style:none;
  margin:0;
  padding:0 0 8px;
}
.orn-mnav__group ul li,
.orn-mnav__plain li{margin:0;}
.orn-mnav__group ul a,
.orn-mnav__plain a{
  display:block;
  padding:9px 36px;
  font-size:var(--fs-md);
  color:var(--orn-ink);
  text-decoration:none;
  min-height:36px;
}
.orn-mnav__group ul a:hover,
.orn-mnav__plain a:hover{color:var(--orn-purple);}

.orn-mnav__footer{
  display:flex;
  flex-direction:column;
  padding:18px 20px;
  border-top:1px solid var(--orn-line);
  margin-top:18px;
  gap:14px;
  font-size:var(--fs-base);
}
.orn-mnav__footer a{
  color:var(--orn-ink-soft);
  text-decoration:none;
  padding:6px 0;
}

/* --- 30.3 PDP gallery swipe (horizontal scroll-snap on mobile) --- */
@media (max-width:782px){
  .woocommerce-product-gallery,
  .woocommerce-product-gallery .flex-control-thumbs{
    overflow-x:auto;
    scroll-snap-type:x mandatory;
    -webkit-overflow-scrolling:touch;
  }
  .woocommerce-product-gallery__image{
    scroll-snap-align:center;
    flex-shrink:0;
  }
}

/* --- 30.3b Tablet: swap desktop mega-nav for the hamburger drawer.
   The horizontal nav (11 categories + "More") only fits on one line above
   ~1440px; below that "More" wraps onto a second row and the maroon bar grows
   tall and overlaps the page. So for the whole tablet range (<=1440px) we use
   the hamburger drawer instead. The drawer is not width-gated and works here.
   This matches the 1440px tablet breakpoint used for the PDP gallery/layout. */
@media (max-width:1440px){
  .orn-header__hamburger{display:inline-flex;}
  .orn-nav.orn-nav--mega{display:none !important;}
}

/* --- 30.4 Universal mobile breakpoint sweep --- */
@media (max-width:782px){
  /* Compact header padding */
  .orn-header__top{
    padding-top:10px !important;
    padding-bottom:10px !important;
    gap:6px;
  }
  /* Logo centered, smaller */
  .orn-logo a{font-size:var(--fs-lg);}

  /* Hide search bar on small screens; can re-enable inside drawer later */
  .orn-search{display:none;}

  /* Header action icons - tighten + ensure 44px tap */
  .orn-header__actions{gap:8px;}
  .orn-header__actions > a{
    width:44px;height:44px;
    display:inline-flex;
    align-items:center;
    justify-content:center;
  }
  .orn-header__actions > a span{display:none;}
  .orn-header__actions svg{width:22px;height:22px;}

  /* Section paddings tighter */
  .orn-section{padding-block:clamp(28px,5vw,48px);}
  h1{font-size:clamp(1.6rem,5vw,2rem);}
  h2{font-size:clamp(1.3rem,4vw,1.7rem);}

  /* Body font size at least 16px so iOS doesn't auto-zoom inputs */
  input[type="text"],
  input[type="email"],
  input[type="tel"],
  input[type="number"],
  input[type="date"],
  input[type="password"],
  textarea,
  select{
    font-size:var(--fs-md) !important;
    min-height:44px;
  }

  /* Buttons get tap height */
  .orn-btn,button.button,a.button,.button{
    min-height:44px;
    padding:12px 20px;
  }

  /* Quantity stepper bigger taps */
  .quantity .qty,
  .qty{
    min-width:56px;
    min-height:44px;
    font-size:var(--fs-md) !important;
  }

  /* Cart drawer fills screen on phones */
  .orn-cart-drawer{width:100vw;max-width:100vw;}
  .orn-cart-drawer__close{width:44px;height:44px;}

  /* Forms with two-col layout collapse */
  .orn-checkout-form .col2-set{grid-template-columns:1fr;}
  .orn-checkout-panel{padding:18px;}
  .orn-checkout-step__num{width:24px;height:24px;font-size:var(--fs-xs);}

  /* PDP summary spacing */
  .single-product div.product .summary{padding-top:6px;}

  /* Tabs/text smaller on PDP */
  .orn-pdp-tabs__tab{padding:11px 14px;font-size:var(--fs-sm);}

  /* Detail groups tighter */
  .orn-detail-group{padding:14px;}
  .orn-detail-group__head{font-size:var(--fs-xs);}

  /* Breakup table cells */
  .orn-breakup th,
  .orn-breakup td{padding:8px 4px;font-size:var(--fs-sm);}

  /* Sticky bar - bigger tap, safe-area */
  #orn-pdp-sticky{
    padding:10px 14px env(safe-area-inset-bottom, 10px);
    gap:10px;
  }
  #orn-pdp-sticky .single_add_to_cart_button,
  #orn-pdp-sticky [data-orn-add-to-cart]{
    flex:1;
    min-height:48px;
    font-size:var(--fs-sm);
  }

  /* Home hero tighter */
  .orn-home-hero{padding-block:clamp(36px,8vw,60px);}
  .orn-home-hero__cta{width:100%;}
  .orn-home-hero__cta .orn-btn{flex:1;min-height:48px;}

  /* Footer cols - keep readable */
  .orn-footer{padding-block:36px 0;}
  .orn-footer__cols{grid-template-columns:1fr 1fr;gap:24px;}
  .orn-footer__col--brand{grid-column:1 / -1;}
  .orn-footer__title{font-size:var(--fs-sm);}

  /* Mega menu spillover safety */
  .orn-mega-panel,
  .orn-mega-panel--simple{display:none !important;}

  /* My-account loyalty hero stacks */
  .orn-loyalty__hero{padding:18px;}

  /* Reviews input gets bigger on mobile */
  .orn-rating-input__star{font-size:var(--fs-3xl);}
}

/* --- 30.5 Very narrow phones (≤380px) --- */
@media (max-width:380px){
  .orn-home-cats__grid{grid-template-columns:repeat(2,1fr);}
  .orn-checkout-step__label{display:none;}
  .orn-mini-cart__actions{grid-template-columns:1fr;}
  .orn-cart-drawer__title{font-size:var(--fs-base);}
  .orn-payicons{gap:4px;}
  .orn-payicon{font-size:var(--fs-3xs);padding:4px 7px;}
  .orn-thankyou__cta-row{flex-direction:column;}
  .orn-thankyou__cta-row .orn-btn{width:100%;}
}

/* --- 30.6 Landscape orientation tweak for short heights --- */
@media (max-height:520px) and (orientation:landscape){
  .orn-cart-drawer__body,
  .orn-mnav__body{padding-bottom:env(safe-area-inset-bottom, 8px);}
  .orn-home-hero{padding-block:24px;}
}

/* --- 30.7 Reduce motion respect --- */
@media (prefers-reduced-motion:reduce){
  .orn-cart-drawer,
  .orn-mnav,
  .orn-mnav-scrim,
  .orn-cart-drawer-scrim,
  .orn-mega-panel,
  .orn-checkout-next,
  .orn-product:hover,
  .orn-home-cat:hover{
    transition:none !important;
    transform:none !important;
  }
}

/* ==========================================================================
   31. Cleanup overrides (Batch 19) - kill eyebrows, fix mega menu,
       shrink announce bar, restyle uicon SVGs in context
   ========================================================================== */

/* --- 31.1 Hide every eyebrow label site-wide --- */
.orn-eyebrow{display:none !important;}
.orn-section-head{margin-bottom:clamp(16px,2.5vw,32px);}

/* --- 31.2 Announce bar: smaller on desktop, single line on mobile --- */
.orn-announce{
  font-size:var(--fs-xs);
  font-weight:500;
  padding:6px 16px;
  letter-spacing:.02em;
  line-height:1.4;
  overflow:hidden;
  white-space:nowrap;
  text-overflow:ellipsis;
}
.orn-announce__track{display:inline-block;}
.orn-announce__track--mobile{display:none;}
@media (max-width:640px){
  .orn-announce{
    padding:5px 12px;
    font-size:var(--fs-2xs);
    letter-spacing:0;
  }
  .orn-announce__track--full{display:none;}
  .orn-announce__track--mobile{display:inline-block;}
}

/* --- 31.3 Mega menu fix (clean redesign of dropdown) --- */
/* Make sure the nav container is the positioning context, not the inner-wrap. */
.orn-nav.orn-nav--mega{position:relative;}
.orn-nav--mega .orn-nav__inner{position:static;}

/* Panel: span the FULL nav width (not just the wrap) and sit cleanly below it. */
.orn-mega-panel{
  position:absolute;
  left:0;right:0;
  top:100%;
  width:100%;
  max-width:none;
  background:#fff;
  color:var(--orn-ink);
  box-shadow:0 24px 48px -16px rgba(33,36,62,.22);
  border-top:1px solid var(--orn-line);
  opacity:0;
  visibility:hidden;
  transform:translateY(4px);
  transition:opacity .15s ease,transform .15s ease,visibility .15s ease;
  z-index:90;
  pointer-events:none;
}
.orn-mega-item.has-mega:hover > .orn-mega-panel,
.orn-mega-item.has-mega:focus-within > .orn-mega-panel{
  opacity:1;
  visibility:visible;
  transform:translateY(0);
  pointer-events:auto;
}

/* Reset the inner: wrap-constrained grid, 2 columns: 4-col link panel + promos */
.orn-mega-panel__inner{
  display:grid;
  grid-template-columns:minmax(0,1fr) 260px;
  gap:36px;
  padding:36px clamp(16px,4vw,40px);
  max-width:var(--wrap);
  margin-inline:auto;
  align-items:start;
}

/* Force the 4-column links grid to actually be 4 columns */
.orn-mega-panel__cols{
  display:grid !important;
  grid-template-columns:repeat(4, minmax(0,1fr)) !important;
  gap:28px !important;
}

.orn-mega-col{min-width:0;}
.orn-mega-col__title{
  font-size:var(--fs-base);
  letter-spacing:.1em;
  text-transform:uppercase;
  color:var(--orn-purple);
  font-weight:700;
  margin:0 0 12px;
  padding-bottom:8px;
  border-bottom:1px solid var(--orn-purple-soft);
}
.orn-mega-col__list{list-style:none;margin:0;padding:0;}
.orn-mega-col__list li{margin:0;}
.orn-mega-col__list a{
  display:block;
  padding:6px 0;
  font-size:var(--fs-md);
  color:var(--orn-ink);
  text-decoration:none;
  line-height:1.45;
  transition:color .12s ease, padding-left .12s ease;
}
.orn-mega-col__list a:hover{
  color:var(--orn-purple);
  padding-left:4px;
}

/* Promos: 2 stacked cards on the right */
.orn-mega-panel__promos{
  display:grid;
  grid-template-columns:1fr;
  gap:12px;
}
.orn-mega-promo{
  display:flex;
  flex-direction:column;
  gap:4px;
  padding:18px 20px;
  border-radius:var(--radius-card);
  text-decoration:none;
  color:var(--orn-ink-strong);
  min-height:108px;
  transition:transform .15s ease,box-shadow .15s ease;
}
.orn-mega-promo:hover{
  transform:translateY(-2px);
  box-shadow:var(--shadow-card-hover);
  color:var(--orn-ink-strong);
}
.orn-mega-promo__title{font-size:var(--fs-lg);font-weight:600;line-height:1.25;}
.orn-mega-promo__sub{font-size:var(--fs-base);color:var(--orn-ink-soft);line-height:1.4;margin-top:2px;}
.orn-mega-promo__cta{font-size:var(--fs-base);font-weight:600;color:var(--orn-purple);margin-top:auto;}

/* Recipient pills bar */
.orn-mega-panel__recipients{
  grid-column:1 / -1;
  display:flex;
  flex-wrap:wrap;
  gap:8px;
  padding-top:18px;
  margin-top:4px;
  border-top:1px solid var(--orn-line);
}
.orn-mega-recipient{
  display:inline-flex;align-items:center;
  padding:7px 16px;
  background:var(--orn-purple-soft);color:var(--orn-purple);
  border-radius:var(--radius-pill);
  font-size:var(--fs-base);font-weight:600;
  letter-spacing:.02em;
  text-decoration:none;
}
.orn-mega-recipient:hover{background:var(--orn-purple);color:#fff;}

/* Simple "More" dropdown: tight, right-aligned narrow column */
.orn-mega-panel--simple{
  position:absolute;
  left:auto;right:0;top:100%;
  width:240px;
  border-top:none;
  border-radius:0 0 var(--radius-card) var(--radius-card);
  padding:10px 0;
  box-shadow:0 16px 32px -10px rgba(33,36,62,.18);
  background:#fff;
}
.orn-mega-simple{list-style:none;margin:0;padding:0;}
.orn-mega-simple a{
  display:block;
  padding:9px 22px;
  color:var(--orn-ink);
  font-size:var(--fs-sm);
  text-decoration:none;
}
.orn-mega-simple a:hover{background:var(--orn-purple-soft);color:var(--orn-purple);}

@media (max-width:1100px){
  .orn-mega-panel__inner{
    grid-template-columns:1fr;
    gap:24px;
    padding:24px clamp(16px,4vw,32px);
  }
  .orn-mega-panel__cols{grid-template-columns:repeat(2, minmax(0,1fr)) !important;gap:20px !important;}
  .orn-mega-panel__promos{grid-template-columns:repeat(2,1fr);}
}
@media (max-width:782px){
  .orn-mega-panel,
  .orn-mega-panel--simple{display:none !important;}
}

/* --- 31.4 Uicon SVG behavior --- */
.orn-uicon{display:inline-block;vertical-align:-2px;flex-shrink:0;}
.orn-home-cat__icon .orn-uicon,
.orn-detail-group__icon .orn-uicon,
.orn-home-usp__icon .orn-uicon,
.orn-thankyou__eta-icon .orn-uicon{vertical-align:middle;}
.orn-home-cat__icon{
  display:inline-flex;align-items:center;justify-content:center;
}
.orn-footer__badge .orn-uicon{vertical-align:-3px;margin-right:4px;}
.orn-shipping-check__head .orn-uicon,
.orn-checkout-summary__note .orn-uicon{vertical-align:-3px;margin-right:6px;}
.orn-mega-item__caret .orn-uicon,
.orn-mnav__chev .orn-uicon{vertical-align:middle;}
.orn-detail-group__info .orn-uicon{
  width:13px;height:13px;
  opacity:.5;
}
.orn-review-verified .orn-uicon,
.orn-home-review__verified .orn-uicon{vertical-align:-2px;margin-right:2px;}
.orn-cart-lock__icon .orn-uicon{vertical-align:-2px;}
.orn-trust-row__ico .orn-uicon{color:var(--orn-purple);}
.orn-promise__ico .orn-uicon{color:var(--orn-purple);}
.orn-mini-cart__empty-icon .orn-uicon{color:var(--orn-purple-mid);opacity:.5;}
.orn-cart-empty-state__icon .orn-uicon{color:var(--orn-purple-mid);opacity:.5;}
.orn-ship-icon .orn-uicon{color:var(--orn-purple);vertical-align:-3px;margin-right:6px;}

/* ==========================================================================
   32. Wider wrap + bigger header + cleaner product image placeholder
   ========================================================================== */

/* Match CaratLane: wrap up to 1840px (effectively full viewport on most
 * monitors) with tight 16-32px padding so content spans nearly edge-to-edge. */
.orn-wrap{padding-inline:clamp(16px,1.5vw,32px);}

/* Header actions get bigger taps + spacing */
.orn-header__actions{gap:18px;}
.orn-header__actions svg{width:24px;height:24px;}
.orn-header__actions > a{
  display:inline-flex;
  align-items:center;
  gap:6px;
  font-size:var(--fs-base);
  font-weight:500;
}

/* Cart badge bigger */
.orn-cart-badge{
  min-width:18px;height:18px;
  font-size:var(--fs-xs);
  line-height:18px;
}

/* --- Clean CaratLane-style product grid (4 cols) + compact cards --------- */

/* The grid container: 4 columns on desktop, gap matches CaratLane */
.woocommerce ul.products,
.woocommerce-page ul.products{
  display:grid !important;
  grid-template-columns:repeat(4, minmax(0, 1fr)) !important;
  grid-auto-flow:row !important;
  gap:20px !important;
  margin:0 !important;
  padding:0 !important;
  list-style:none !important;
  width:100% !important;
}
/* Kill WC's clearfix ::before/::after pseudo-elements - they become grid items
 * in a grid container and create an empty leading cell, shifting all products
 * one column to the right. */
.woocommerce ul.products::before,
.woocommerce ul.products::after,
.woocommerce-page ul.products::before,
.woocommerce-page ul.products::after{
  display:none !important;
  content:none !important;
}
/* Kill all default float / inherited width on each card */
.woocommerce ul.products li.product,
.woocommerce-page ul.products li.product{
  width:auto !important;
  margin:0 !important;
  padding:0 !important;
  float:none !important;
  clear:none !important;
  background:#fff !important;
  border:1px solid transparent !important;
  border-radius:14px !important;
  overflow:hidden !important;
  position:relative !important;
  list-style:none !important;
  display:flex !important;
  flex-direction:column !important;
  transition:transform .15s ease, box-shadow .15s ease;
}
.woocommerce ul.products li.product:hover{
  transform:translateY(-2px);
  box-shadow:var(--shadow-card-hover);
}

/* "Sale!" badge top-left */
.woocommerce ul.products li.product .onsale{
  position:absolute !important;
  top:12px !important; left:12px !important;
  right:auto !important; margin:0 !important;
  background:var(--orn-gold) !important;
  color:var(--orn-ink-strong) !important;
  padding:4px 12px !important;
  border-radius:999px !important;
  font-size:var(--fs-xs) !important;
  font-weight:700 !important;
  letter-spacing:.04em;
  line-height:1.4 !important;
  z-index:2 !important;
  min-height:0 !important;
}

/* The main link wraps img + title + price. We DON'T put aspect-ratio on it. */
.woocommerce ul.products li.product a.woocommerce-LoopProduct-link{
  display:block !important;
  text-decoration:none !important;
  color:inherit !important;
  background:transparent !important;
  aspect-ratio:auto !important;
}

/* Image is what gets the 1:1 square + the lavender bg (for placeholders) */
.woocommerce ul.products li.product img,
.woocommerce ul.products li.product .attachment-woocommerce_thumbnail,
.woocommerce ul.products li.product .wp-post-image,
.woocommerce ul.products li.product .orn-product-placeholder{
  display:block !important;
  width:100% !important;
  height:auto !important;
  aspect-ratio:1/1 !important;
  object-fit:cover !important;
  margin:0 !important;
  background:linear-gradient(135deg,#F5E9E4 0%,#FBF6EA 60%,#FFFFFF 100%) !important;
}

/* Title */
.woocommerce ul.products li.product h2.woocommerce-loop-product__title,
.woocommerce ul.products li.product .woocommerce-loop-product__title{
  padding:12px 14px 2px !important;
  font-size:var(--fs-base) !important;
  font-weight:600 !important;
  color:var(--orn-ink-strong) !important;
  line-height:1.35 !important;
  margin:0 !important;
  overflow:hidden;
  display:-webkit-box;
  -webkit-line-clamp:2;
  -webkit-box-orient:vertical;
  min-height:36px;
}

/* Price (regular, sale ins/del) */
.woocommerce ul.products li.product .price{
  display:block !important;
  padding:0 14px 12px !important;
  font-size:var(--fs-base) !important;
  font-weight:700 !important;
  color:var(--orn-purple) !important;
  margin:0 !important;
}
.woocommerce ul.products li.product .price ins{
  background:transparent;
  text-decoration:none;
  font-weight:700;
}
.woocommerce ul.products li.product .price del{
  font-weight:500;
  color:var(--orn-grey-500);
  font-size:var(--fs-sm);
  margin-left:6px;
}

/* Re-ordered card text block: price -> Check Delivery Date -> name (small).
   Mirrors the PDP summary stack. */
.woocommerce ul.products li.product .orn-loop-meta{
  display:flex !important;
  flex-direction:column !important;
  gap:3px !important;
  padding:11px 14px 14px !important;
}
.woocommerce ul.products li.product .orn-loop-meta .orn-loop-price{
  padding:0 !important;
  font-size:var(--fs-md) !important;
  font-weight:700 !important;
  color:var(--orn-ink-strong) !important;
  line-height:1.2 !important;
}
.woocommerce ul.products li.product .orn-loop-delivery{
  font-size:var(--fs-xs) !important;
  font-weight:600 !important;
  color:var(--orn-rose) !important;
  letter-spacing:.01em;
  line-height:1.2;
}
.woocommerce ul.products li.product .orn-loop-meta .orn-loop-title{
  padding:0 !important;
  margin:1px 0 0 !important;
  font-size:var(--fs-sm) !important;
  font-weight:400 !important;
  color:var(--orn-grey-500) !important;
  line-height:1.35 !important;
  min-height:0 !important;
  display:-webkit-box;
  -webkit-line-clamp:2;
  -webkit-box-orient:vertical;
  overflow:hidden;
}

/* Add to cart button: full-width gradient pill at bottom */
.woocommerce ul.products li.product .button,
.woocommerce ul.products li.product a.add_to_cart_button{
  display:block !important;
  margin:auto 14px 14px !important;
  padding:10px 14px !important;
  background:var(--orn-cta-gradient) !important;
  color:#fff !important;
  border:none !important;
  border-radius:999px !important;
  text-align:center !important;
  font-family:var(--font) !important;
  font-weight:600 !important;
  font-size:var(--fs-sm) !important;
  letter-spacing:.05em;
  text-transform:uppercase;
  text-decoration:none !important;
  cursor:pointer;
  min-height:0 !important;
  width:auto !important;
}

/* The wishlist heart that we inject top-right */
.woocommerce ul.products li.product .orn-wishlist-btn--card{
  position:absolute !important;
  top:12px !important;
  right:12px !important;
  z-index:2;
}

/* Responsive grid */
@media (max-width:1100px){
  .woocommerce ul.products,
  .woocommerce-page ul.products{grid-template-columns:repeat(3, minmax(0,1fr)) !important;}
}
@media (max-width:760px){
  .woocommerce ul.products,
  .woocommerce-page ul.products{grid-template-columns:repeat(2, minmax(0,1fr)) !important;gap:14px !important;}
}

/* ===== Card cleanup overrides (Batch 20) ============================== */

/* 1. Kill star ratings on cards (PDP keeps them) */
.woocommerce ul.products li.product .star-rating,
.woocommerce ul.products li.product .woocommerce-product-rating,
.woocommerce ul.products li.product > .star-rating{display:none !important;}

/* 2. Kill any duplicate TI Wishlist UI that isn't our custom-wrapped one */
.woocommerce ul.products li.product .tinv-wraper,
.woocommerce ul.products li.product .tinvwl-loop-button-wrapper,
.woocommerce ul.products li.product > .tinv-wishlist{display:none !important;}
.woocommerce ul.products li.product .orn-wishlist-btn--card .tinv-wraper,
.woocommerce ul.products li.product .orn-wishlist-btn--card .tinvwl-loop-button-wrapper,
.woocommerce ul.products li.product .orn-wishlist-btn--card .tinv-wishlist{display:block !important;}

/* 3. "View Similar" link pinned to bottom-right of image area.
      Uses container queries: image is 100cqw tall (aspect-ratio 1/1), so
      top: calc(100cqw - 44px) puts the pill exactly at the image bottom edge. */
.woocommerce ul.products li.product{
  position:relative !important;
  container-type:inline-size;
}
.orn-card-similar{
  position:absolute;
  top:calc(100cqw - 46px);
  right:12px;
  z-index:3;
  display:inline-flex;
  align-items:center;
  gap:6px;
  padding:7px 12px;
  background:rgba(255,255,255,.94);
  border:1px solid var(--orn-line);
  border-radius:999px;
  color:var(--orn-purple);
  font-size:var(--fs-xs);
  font-weight:600;
  letter-spacing:.02em;
  text-decoration:none;
  box-shadow:0 2px 8px -2px rgba(33,36,62,.15);
  opacity:0;
  transform:translateY(4px);
  transition:opacity .18s ease, transform .18s ease, background .12s ease, color .12s ease;
}
.woocommerce ul.products li.product:hover .orn-card-similar,
.woocommerce ul.products li.product:focus-within .orn-card-similar{
  opacity:1;
  transform:translateY(0);
}
.orn-card-similar:hover{background:#fff;color:var(--orn-purple-deep);}
.orn-card-similar .orn-uicon{color:currentColor;width:14px;height:14px;}

/* 4. "Add to Bag" button: hidden by default, reveal on hover. On touch devices,
      always show. */
.woocommerce ul.products li.product .button,
.woocommerce ul.products li.product a.add_to_cart_button{
  opacity:0;
  transform:translateY(6px);
  transition:opacity .2s ease, transform .2s ease;
  pointer-events:none;
}
.woocommerce ul.products li.product:hover .button,
.woocommerce ul.products li.product:hover a.add_to_cart_button,
.woocommerce ul.products li.product:focus-within .button,
.woocommerce ul.products li.product:focus-within a.add_to_cart_button{
  opacity:1;
  transform:translateY(0);
  pointer-events:auto;
}
@media (hover:none){
  .woocommerce ul.products li.product .button,
  .woocommerce ul.products li.product a.add_to_cart_button{
    opacity:1 !important;
    transform:none !important;
    pointer-events:auto !important;
  }
}

/* ==========================================================================
   33. Header refresh (CaratLane-aligned) - Batch 21
   ========================================================================== */

/* Full row of the top header */
.orn-header__top{
  display:flex;
  align-items:center;
  gap:24px;
  padding-block:18px;
}

/* Logo: bigger, no fading */
.orn-logo a{font-size:var(--fs-3xl);font-weight:700;letter-spacing:.02em;color:var(--orn-purple);}

/* --- Search bar: pill with prominent gradient circular submit button --- */
.orn-search{
  flex:1 1 auto;
  position:relative;
  max-width:680px;
  display:flex;
  align-items:center;
}
.orn-search input[type="search"]{
  width:100%;
  padding:14px 70px 14px 28px;
  background:var(--orn-purple-soft);
  border:1px solid var(--orn-purple-soft);
  border-radius:999px;
  font-family:var(--font);
  font-size:var(--fs-md);
  color:var(--orn-ink);
  transition:background .15s ease, border-color .15s ease;
}
.orn-search input[type="search"]:focus{
  outline:none;
  background:#fff;
  border-color:var(--orn-purple);
  box-shadow:0 0 0 3px rgba(79,50,103,.08);
}
.orn-search input[type="search"]::placeholder{color:var(--orn-grey-500);}
.orn-search .orn-search__submit{
  position:absolute;
  top:50%;
  right:6px;
  transform:translateY(-50%);
  width:44px;
  height:44px;
  border-radius:50%;
  background:var(--orn-cta-gradient);
  color:#fff;
  border:none;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  cursor:pointer;
  box-shadow:0 4px 12px -4px rgba(88,50,187,.5);
  transition:transform .12s ease, box-shadow .12s ease;
}
.orn-search .orn-search__submit:hover{
  transform:translateY(-50%) scale(1.04);
  box-shadow:0 6px 16px -4px rgba(88,50,187,.6);
}
.orn-search .orn-search__submit svg{color:#fff;}

/* --- Mid chips (pincode, gold rate, lang) --- */
.orn-header__chips{
  display:flex;
  align-items:center;
  gap:6px;
  flex-shrink:0;
}
.orn-header-chip{
  display:inline-flex;
  align-items:center;
  gap:8px;
  padding:8px 14px;
  background:#fff;
  border:1px solid var(--orn-line);
  border-radius:999px;
  text-decoration:none;
  color:var(--orn-ink);
  font-size:var(--fs-xs);
  line-height:1.2;
  transition:border-color .12s ease, background .12s ease;
  cursor:pointer;
}
.orn-header-chip:hover{
  border-color:var(--orn-purple);
  background:var(--orn-purple-soft);
  color:var(--orn-ink);
}
.orn-header-chip > span{display:flex;flex-direction:column;line-height:1.15;}
.orn-header-chip small{
  font-size:var(--fs-2xs);
  color:var(--orn-ink-soft);
  font-weight:500;
  letter-spacing:.02em;
}
.orn-header-chip strong{
  font-size:var(--fs-sm);
  font-weight:700;
  color:var(--orn-ink-strong);
  letter-spacing:.01em;
}
.orn-header-chip .orn-uicon{color:var(--orn-purple);}
/* The pin chip is a <button> now (opens a popover); normalise button defaults. */
button.orn-header-chip{font-family:inherit;text-align:left;}

/* ---- Delivery pincode popover (header) ---- */
.orn-pin{position:relative;}
.orn-pin-pop{
  position:absolute;
  top:calc(100% + 8px);
  right:0;
  z-index:1200;
  width:300px;
  max-width:calc(100vw - 32px);
  background:#fff;
  border:1px solid var(--orn-line);
  border-radius:14px;
  box-shadow:0 18px 48px rgba(31,19,48,.18);
  padding:16px;
}
.orn-pin-pop[hidden]{display:none;}
.orn-pin-pop__title{
  font-size:var(--fs-sm);
  font-weight:700;
  color:var(--orn-ink-strong);
  margin-bottom:10px;
}
.orn-pin-pop__row{display:flex;gap:8px;}
.orn-pin-pop__row input{
  flex:1 1 auto;
  min-width:0;
  border:1px solid var(--orn-line);
  border-radius:10px;
  padding:10px 12px;
  font-size:var(--fs-sm);
  font-family:inherit;
  color:var(--orn-ink-strong);
}
.orn-pin-pop__row input:focus{outline:none;border-color:var(--orn-purple);}
.orn-pin-pop__row button{
  flex:0 0 auto;
  border:none;
  border-radius:10px;
  padding:10px 16px;
  background:var(--orn-cta-gradient);
  color:#fff;
  font-family:inherit;
  font-weight:600;
  font-size:var(--fs-sm);
  cursor:pointer;
}
.orn-pin-pop__row button:disabled{opacity:.6;cursor:default;}
.orn-pin-pop__out{display:none;margin-top:10px;}
.orn-pin-pop__out.is-shown{display:block;}
.orn-pin-pop__out strong{
  display:block;
  font-size:var(--fs-sm);
  font-weight:700;
  color:var(--orn-green,#2e7d32);
}
.orn-pin-pop__out span{
  display:block;
  font-size:var(--fs-xs);
  color:var(--orn-ink-soft);
  margin-top:2px;
}
.orn-pin-pop__out.is-error strong{display:none;}
.orn-pin-pop__out.is-error span{color:var(--orn-purple);}

/* ---- Header account dropdown (Sign Up / Log In) ---- */
.orn-acct-menu{position:relative;}
.orn-acct-menu__btn{background:none;border:none;cursor:pointer;font-family:inherit;}
.orn-acct-pop{
  position:absolute;
  top:calc(100% + 10px);
  right:0;
  z-index:1200;
  width:248px;
  background:#fff;
  border:1px solid var(--orn-line);
  border-radius:14px;
  box-shadow:0 18px 48px rgba(31,19,48,.16);
  padding:16px;
  text-align:left;
}
.orn-acct-pop[hidden]{display:none;}
.orn-acct-menu:hover .orn-acct-pop,
.orn-acct-menu:focus-within .orn-acct-pop{display:block;}
.orn-acct-pop__title{display:block;font-size:var(--fs-base);font-weight:700;color:var(--orn-ink-strong);}
.orn-acct-pop__sub{font-size:var(--fs-xs);color:var(--orn-ink-soft);margin:4px 0 12px;line-height:1.45;}
.orn-acct-pop__btns{display:flex;gap:8px;}
.orn-acct-pop__btn{
  flex:1 1 50%;
  display:inline-flex;align-items:center;justify-content:center;
  padding:9px 10px;border-radius:999px;
  font-family:var(--font);font-size:var(--fs-sm);font-weight:600;
  text-decoration:none;
  border:1px solid var(--orn-purple);
  color:var(--orn-purple);background:#fff;
  transition:background .12s ease,color .12s ease;
}
.orn-acct-pop__btn:hover{background:var(--orn-purple-pale);}
.orn-acct-pop__btn--primary{background:var(--orn-cta-gradient);color:#fff;border-color:transparent;}
.orn-acct-pop__btn--primary:hover{filter:brightness(1.06);background:var(--orn-cta-gradient);color:#fff;}

.orn-header-chip__dot{
  width:8px;height:8px;
  border-radius:50%;
  background:var(--orn-gold);
  box-shadow:0 0 0 3px rgba(251,197,11,.18);
  flex-shrink:0;
}
.orn-header-chip--lang{cursor:default;}
.orn-header-chip__flag{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  width:22px;height:16px;
  background:linear-gradient(180deg,#FF9933 33%,#fff 33%,#fff 66%,#138808 66%);
  color:#0a0a0a;
  font-size:var(--fs-3xs);
  font-weight:700;
  border-radius:2px;
  letter-spacing:.5px;
}

/* --- Header action icons (right) --- */
.orn-header__actions{
  display:flex;
  align-items:center;
  gap:6px;
  flex-shrink:0;
  margin-left:auto;
}
.orn-header__action{
  position:relative;
  display:inline-flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  gap:2px;
  min-width:54px;
  padding:6px 10px;
  color:var(--orn-ink);
  text-decoration:none;
  border-radius:10px;
  transition:background .12s ease, color .12s ease;
  font-size:var(--fs-2xs);
  font-weight:500;
  letter-spacing:.01em;
}
.orn-header__action:hover{
  background:var(--orn-purple-soft);
  color:var(--orn-purple);
}
.orn-header__action span:not(.orn-cart-badge):not(.orn-wishlist-count){
  font-size:var(--fs-2xs);
  font-weight:500;
}
.orn-header__action .orn-uicon{
  width:22px;height:22px;
  stroke-width:1.7;
}

/* Make wishlist heart look filled-active when count > 0 */
.orn-header__wish .orn-uicon{color:var(--orn-ink);}
.orn-header__wish.is-active .orn-uicon,
.orn-header__wish:has(.orn-wishlist-count.is-visible) .orn-uicon{
  fill:var(--orn-rose);
  color:var(--orn-rose);
  stroke:var(--orn-rose);
}

/* Wishlist count + cart badge: small numeric pill */
.orn-cart-badge,
.orn-header__wish .orn-wishlist-count{
  position:absolute;
  top:0;
  right:4px;
  min-width:18px;
  height:18px;
  padding:0 5px;
  background:var(--orn-purple);
  color:#fff;
  border-radius:999px;
  font-size:var(--fs-2xs);
  font-weight:700;
  line-height:18px;
  text-align:center;
  display:inline-flex;
  align-items:center;
  justify-content:center;
}
.orn-cart-badge:empty,
.orn-header__wish .orn-wishlist-count:not(.is-visible){display:none;}

/* Show 0 if cart is empty? CaratLane shows badge always. */
.orn-cart-badge{display:inline-flex;}

/* Responsive: progressively hide chips on smaller viewports */
@media (max-width:1280px){
  .orn-header-chip--gold{display:none;}
}
@media (max-width:1100px){
  .orn-header-chip--pin small{display:none;}
  .orn-header-chip--pin strong{font-size:var(--fs-xs);}
  .orn-header-chip--lang{display:none;}
}
@media (max-width:900px){
  .orn-header__chips{display:none;}
  .orn-search{max-width:none;}
}
@media (max-width:782px){
  .orn-header__top{gap:10px;padding-block:12px;}
  .orn-search{display:none;}
  .orn-logo a{font-size:var(--fs-xl);}
  .orn-header__action{min-width:0;padding:6px;}
  .orn-header__action span:not(.orn-cart-badge):not(.orn-wishlist-count){display:none;}
}

/* ============================================================
   BATCH 29 R1: HOME PAGE REBUILD (CaratLane parity)
   Sections covered: Hero carousel, Collections carousel,
   Category photo grid, Trust strip.
   ============================================================ */

/* --- Shared gradient tones used across hero, collections, tiles ----- */
.orn-tone-cream  { background: linear-gradient(135deg, #f7efe2 0%, #fdf8ee 100%); }
.orn-tone-blush  { background: linear-gradient(135deg, #fbe2d4 0%, #fdf0e8 100%); }
.orn-tone-sage   { background: linear-gradient(135deg, #d8e6d4 0%, #f0f6ee 100%); }
.orn-tone-mauve  { background: linear-gradient(135deg, #EAD9DC 0%, #F5E9E4 100%); }
.orn-tone-butter { background: linear-gradient(135deg, #f0d99b 0%, #fbeec2 100%); }
.orn-tone-rose   { background: linear-gradient(135deg, #f3c5cd 0%, #fbe2e6 100%); }
.orn-tone-white  { background: #ffffff; }

/* --- Hero Carousel ------------------------------------------------ */
.orn-hero-carousel{
  position:relative;
  width:100%;
  margin:0 0 48px;
  overflow:hidden;
  isolation:isolate;
}
.orn-hero-carousel__track{
  position:relative;
  width:100%;
  height:clamp(420px, 52vw, 620px);
}
.orn-hero-slide{
  position:absolute;
  inset:0;
  opacity:0;
  visibility:hidden;
  transition:opacity .6s ease, visibility 0s linear .6s;
  background:#f7efe2;
}
.orn-hero-slide.is-active{
  opacity:1;
  visibility:visible;
  transition:opacity .6s ease, visibility 0s linear 0s;
  z-index:2;
}
.orn-hero-slide--cream  { background: linear-gradient(135deg, #f7efe2 0%, #fdf8ee 100%); }
.orn-hero-slide--blush  { background: linear-gradient(135deg, #fbe2d4 0%, #fdf0e8 100%); }
.orn-hero-slide--sage   { background: linear-gradient(135deg, #d8e6d4 0%, #f0f6ee 100%); }
.orn-hero-slide--mauve  { background: linear-gradient(135deg, #EAD9DC 0%, #F5E9E4 100%); }
.orn-hero-slide--butter { background: linear-gradient(135deg, #f0d99b 0%, #fbeec2 100%); }
.orn-hero-slide--rose   { background: linear-gradient(135deg, #f3c5cd 0%, #fbe2e6 100%); }

.orn-hero-slide__inner{
  display:grid;
  grid-template-columns: 1fr 1fr;
  align-items:center;
  height:100%;
  max-width: var(--wrap, 1840px);
  margin: 0 auto;
  padding: 0 clamp(24px, 4vw, 80px);
  gap: clamp(32px, 5vw, 80px);
}
.orn-hero-slide__text{
  display:flex;
  flex-direction:column;
  gap:18px;
  max-width:540px;
}
.orn-hero-slide__eyebrow{
  font-size:var(--fs-sm);
  letter-spacing:2.2px;
  text-transform:uppercase;
  color:#7A2A3A;
  font-weight:600;
}
.orn-hero-slide__headline{
  margin:0;
  display:flex;
  flex-direction:column;
  gap:4px;
  font-family: var(--font-display, 'Cormorant Garamond', Georgia, serif);
  line-height:1.05;
}
.orn-hero-slide__h1{
  font-size: clamp(38px, 5vw, 68px);
  font-weight:500;
  color:#4E1B26;
}
.orn-hero-slide__h2{
  font-size: clamp(38px, 5vw, 68px);
  font-style:italic;
  font-weight:400;
  color:#7A2A3A;
}
.orn-hero-slide__subhead{
  margin:0;
  font-size:var(--fs-lg);
  color:#5A3A42;
  font-weight:500;
  letter-spacing:.5px;
}
.orn-hero-slide__cta{
  align-self:flex-start;
  display:inline-flex;
  align-items:center;
  gap:8px;
  background: var(--orn-cta-gradient);
  color:#fff;
  font-size:var(--fs-md);
  letter-spacing:1.2px;
  text-transform:uppercase;
  font-weight:600;
  padding:14px 32px;
  border-radius:999px;
  text-decoration:none;
  margin-top:8px;
  transition:transform .2s, box-shadow .2s;
  box-shadow:0 4px 14px rgba(122,42,58,.18);
}
.orn-hero-slide__cta:hover{
  transform:translateY(-1px);
  box-shadow:0 8px 22px rgba(122,42,58,.28);
}
.orn-hero-slide__media{
  display:flex;
  align-items:center;
  justify-content:center;
  height:100%;
}
.orn-hero-slide__media img{
  max-width:100%;
  max-height:90%;
  object-fit:contain;
}
.orn-hero-carousel__arrow{
  position:absolute;
  top:50%;
  transform:translateY(-50%);
  z-index:5;
  width:48px;
  height:48px;
  border-radius:50%;
  background:rgba(255,255,255,.92);
  border:1px solid rgba(31,19,48,.08);
  font-size:var(--fs-2xl);
  color:#5A3A42;
  cursor:pointer;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  line-height:1;
  box-shadow:0 2px 8px rgba(0,0,0,.08);
  transition:background .2s, transform .2s;
}
.orn-hero-carousel__arrow:hover{ background:#fff; transform:translateY(-50%) scale(1.04); }
.orn-hero-carousel__arrow--prev{ left:24px; }
.orn-hero-carousel__arrow--next{ right:24px; }
.orn-hero-carousel__dots{
  position:absolute;
  bottom:24px;
  left:50%;
  transform:translateX(-50%);
  display:flex;
  gap:10px;
  z-index:5;
}
.orn-hero-carousel__dot{
  width:9px;
  height:9px;
  border-radius:50%;
  border:0;
  background:rgba(31,19,48,.22);
  cursor:pointer;
  padding:0;
  transition:background .2s, width .2s;
}
.orn-hero-carousel__dot.is-active{
  background:#7A2A3A;
  width:24px;
  border-radius:6px;
}

@media (max-width: 900px){
  .orn-hero-carousel__track{ height: 540px; }
  .orn-hero-slide__inner{
    grid-template-columns: 1fr;
    grid-template-rows: 1fr 1fr;
    text-align:left;
    padding: 24px;
    gap: 16px;
  }
  .orn-hero-slide__media{ display:none; }
  .orn-hero-carousel__arrow{ width:38px; height:38px; font-size:var(--fs-xl); }
  .orn-hero-carousel__arrow--prev{ left:12px; }
  .orn-hero-carousel__arrow--next{ right:12px; }
}

/* --- Collections Carousel ----------------------------------------- */
.orn-collections-carousel{ padding: 56px 0 64px; background:#fff; }
.orn-collections-carousel__heading{
  text-align:center;
  font-family: var(--font-display, 'Cormorant Garamond', Georgia, serif);
  font-size: clamp(28px, 3vw, 42px);
  font-weight:500;
  color:#4E1B26;
  margin:0 0 36px;
}
.orn-collections-carousel__grid{
  display:grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 16px;
  max-width: 1200px;
  margin: 0 auto;
}
.orn-collection-tile{
  position:relative;
  display:block;
  aspect-ratio: 1 / 1;
  border-radius: 14px;
  overflow:hidden;
  text-decoration:none;
  isolation:isolate;
  transition:transform .3s, box-shadow .3s;
}
.orn-collection-tile:hover{
  transform: translateY(-4px);
  box-shadow: 0 18px 40px rgba(0,0,0,.12);
}
.orn-collection-tile--mauve  { background: linear-gradient(160deg, #EAD0D8 0%, #EAD9DC 100%); }
.orn-collection-tile--blush  { background: linear-gradient(160deg, #f3b8a0 0%, #fbe2d4 100%); }
.orn-collection-tile--sage   { background: linear-gradient(160deg, #aac7a4 0%, #d8e6d4 100%); }
.orn-collection-tile--cream  { background: linear-gradient(160deg, #e9d6b3 0%, #f7efe2 100%); }
.orn-collection-tile--butter { background: linear-gradient(160deg, #e3bc6f 0%, #f0d99b 100%); }
.orn-collection-tile--rose   { background: linear-gradient(160deg, #dc8b9a 0%, #f3c5cd 100%); }
.orn-collection-tile__shade{
  position:absolute;
  inset:0;
  background: linear-gradient(180deg, transparent 50%, rgba(0,0,0,.42) 100%);
  z-index:1;
}
.orn-collection-tile__body{
  position:absolute;
  left:0;
  right:0;
  bottom:24px;
  padding: 0 24px;
  text-align:center;
  z-index:2;
  color:#fff;
}
.orn-collection-tile__title{
  margin:0 0 6px;
  font-family: var(--font-display, 'Cormorant Garamond', Georgia, serif);
  font-style: italic;
  font-weight:500;
  font-size: clamp(32px, 2.4vw, 44px);
  text-shadow: 0 2px 12px rgba(0,0,0,.32);
}
.orn-collection-tile__sub{
  margin:0;
  font-size:var(--fs-sm);
  letter-spacing:.6px;
  opacity:.92;
}
.orn-collections-carousel__cta{
  margin-top: 36px;
  text-align:center;
}
.orn-btn--pill{
  display:inline-flex;
  align-items:center;
  background: #7A2A3A;
  color:#fff;
  font-size:var(--fs-sm);
  letter-spacing:1.6px;
  font-weight:600;
  padding: 14px 36px;
  border-radius: 999px;
  text-decoration:none;
  transition: background .2s, transform .2s;
}
.orn-btn--pill:hover{ background:#5a1849; transform: translateY(-1px); }

@media (max-width: 1000px){
  .orn-collections-carousel__grid{ grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 600px){
  .orn-collections-carousel__grid{ grid-template-columns: 1fr; }
}

/* --- Category Photo Grid (6 tiles) -------------------------------- */
.orn-cat-grid-photo{ padding: 48px 0 56px; background:#fff; }
.orn-cat-grid-photo__heading{
  text-align:center;
  font-family: var(--font-display, 'Cormorant Garamond', Georgia, serif);
  font-size: clamp(26px, 2.8vw, 38px);
  font-weight:500;
  margin: 0 0 32px;
  color:#4E1B26;
}
.orn-cat-grid-photo__grid{
  display:grid;
  gap: 18px;
}
.orn-cat-photo-tile{
  text-decoration:none;
  color:#4E1B26;
  display:flex;
  flex-direction:column;
  align-items:center;
  text-align:center;
  transition: transform .25s;
}
.orn-cat-photo-tile:hover{ transform: translateY(-3px); }
.orn-cat-photo-tile__photo{
  width:100%;
  aspect-ratio: 1 / 1;
  border-radius: 50%;
  background-color:#f5eee5;
  margin-bottom: 14px;
  background-size: cover;
  background-position: center;
  transition: box-shadow .3s;
}
.orn-cat-photo-tile:hover .orn-cat-photo-tile__photo{
  box-shadow: 0 14px 32px rgba(0,0,0,.12);
}
.orn-cat-photo-tile__photo--mauve  { background-color:#EAD9DC; }
.orn-cat-photo-tile__photo--blush  { background-color:#fbe2d4; }
.orn-cat-photo-tile__photo--sage   { background-color:#d8e6d4; }
.orn-cat-photo-tile__photo--cream  { background-color:#f7efe2; }
.orn-cat-photo-tile__photo--butter { background-color:#f0d99b; }
.orn-cat-photo-tile__photo--rose   { background-color:#f3c5cd; }
.orn-cat-photo-tile__label{
  font-size: var(--fs-md);
  letter-spacing:.3px;
  font-weight: 500;
  color:#5A3A42;
}

@media (max-width: 1100px){
  .orn-cat-grid-photo__grid{ grid-template-columns: repeat(3, 1fr) !important; }
}
@media (max-width: 640px){
  .orn-cat-grid-photo__grid{ grid-template-columns: repeat(2, 1fr) !important; }
}

/* --- Trust Strip --------------------------------------------------- */
.orn-trust-strip{ padding: 28px 0; border-block: 1px solid rgba(31,19,48,.08); }
.orn-trust-strip--cream { background: #fbf6ec; }
.orn-trust-strip--white { background: #fff; }
.orn-trust-strip--mauve { background: #FCF6F3; }
.orn-trust-strip--sage  { background: #eef5ec; }

.orn-trust-strip__row{
  display:grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 24px;
  align-items: center;
}
.orn-trust-strip__item{
  display:flex;
  gap: 14px;
  align-items: center;
  justify-content: center;
  padding: 8px 12px;
  border-right: 1px solid rgba(31,19,48,.08);
}
.orn-trust-strip__item:last-child{ border-right: 0; }
.orn-trust-strip__icon{
  flex:0 0 auto;
  width: 36px;
  height: 36px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  color:#7A2A3A;
}
.orn-trust-strip__icon svg{ width: 28px; height: 28px; }
.orn-trust-strip__body{ display:flex; flex-direction:column; gap:2px; }
.orn-trust-strip__label{
  font-size: var(--fs-base);
  font-weight: 600;
  color: #4E1B26;
  letter-spacing:.2px;
}
.orn-trust-strip__sub{
  font-size: var(--fs-sm);
  color: #7A6E6A;
}

@media (max-width: 900px){
  .orn-trust-strip__row{ grid-template-columns: repeat(2, 1fr); gap:14px; }
  .orn-trust-strip__item{ border-right:0; }
}
@media (max-width: 480px){
  .orn-trust-strip__row{ grid-template-columns: 1fr; }
}

/* ============================================================
   BATCH 29 R1 OVERRIDE: Font system + eyebrow hide (site-wide).
   - DM Sans is the only sans, used everywhere upright.
   - Cormorant Garamond Italic is the ONLY italic display face.
   - Allura is reserved for script tile titles (collection names).
   - All eyebrow chips are hidden visually but kept in DOM for SEO.
   ============================================================ */

/* Any explicit italic styling on any element gets the editorial italic. */
em,
i,
cite,
[style*="font-style: italic"],
[style*="font-style:italic"],
.is-italic,
.orn-italic,
.orn-hero-slide__h2,
.orn-product__name em,
.orn-collections-carousel__heading em,
.orn-section-head em {
  font-family: var(--font-italic) !important;
  font-style: italic;
  font-weight: 500;
  letter-spacing: 0;
}

/* Hero italic line: slightly heavier so it holds its own next to DM Sans 600. */
.orn-hero-slide__h2 {
  font-family: var(--font-italic) !important;
  font-style: italic;
  font-weight: 500;
  letter-spacing: -.5px;
  /* Cormorant has true italic glyphs; no skew hack needed. */
  transform: none;
}

/* Collection tile titles get the flowing script face. */
.orn-collection-tile__title,
.orn-script {
  font-family: var(--font-script) !important;
  font-style: normal !important;
  font-weight: 400 !important;
  letter-spacing: 0 !important;
  transform: none;
  line-height: 1;
  font-size: clamp(36px, 3vw, 56px) !important;
}

/* DM Sans for upright headlines (no italic, no Cormorant). */
.orn-hero-slide__headline,
.orn-collections-carousel__heading,
.orn-cat-grid-photo__heading,
.orn-hero-slide__h1 {
  font-family: var(--font) !important;
  font-style: normal;
  font-weight: 600;
  letter-spacing: -0.5px;
}

/* Hide ALL eyebrow chips on home/templates while keeping for screen readers.
 * Covers Hero, Loyalty Row, UGC Banner, Sale Row "FLAT" prefix, and any
 * generic .orn-eyebrow tag rendered by other widgets. */
.orn-hero-slide__eyebrow,
.orn-eyebrow,
.orn-section-head .orn-eyebrow,
.orn-home-trending .orn-eyebrow,
.orn-loyalty-card__eyebrow,
.orn-ugc-banner__eyebrow,
.orn-brand-band__eyebrow,
.orn-spr__promo-prefix {
  position: absolute !important;
  width: 1px !important;
  height: 1px !important;
  margin: -1px !important;
  padding: 0 !important;
  overflow: hidden !important;
  clip: rect(0,0,0,0) !important;
  white-space: nowrap !important;
  border: 0 !important;
}

/* Tighten hero stack since eyebrow is gone. */
.orn-hero-slide__text { gap: 14px; }
.orn-hero-slide__headline { gap: 2px; }

/* Force DM Sans everywhere by default (safety net for inherited contexts). */
body,
input,
select,
textarea,
button,
.elementor *:not(em):not(i):not(cite):not(.orn-hero-slide__h2):not(.orn-collection-tile__title):not(.orn-script) {
  font-family: var(--font);
}

/* ============================================================
   BATCH 29 R2: Sale + Product Row, and Lavender-promo Category Grid
   ============================================================ */

/* --- Sale + Product Row ------------------------------------------- */
.orn-sale-product-row{
  padding: 24px 0 56px;
  background: #fff;
}
.orn-spr__grid{
  display:grid;
  grid-template-columns: 1fr 1fr;
  gap: 24px;
  min-height: 460px;
}

/* Left: Promo card */
.orn-spr__promo{
  position:relative;
  display:block;
  border-radius: 16px;
  overflow:hidden;
  color:#fff;
  text-decoration:none;
  padding: 56px 56px 32px;
  isolation: isolate;
  transition: transform .25s;
}
.orn-spr__promo:hover{ transform: translateY(-3px); }
.orn-spr__promo-text{
  position:relative;
  z-index: 2;
  max-width: 56%;
  display:flex;
  flex-direction:column;
  gap: 18px;
}
.orn-spr__promo-prefix{
  display:inline-flex;
  align-items:center;
  gap:10px;
  font-size: var(--fs-base);
  letter-spacing: 3.6px;
  color: rgba(255,255,255,.92);
  font-weight: 500;
  text-transform: uppercase;
}
.orn-spr__promo-rule{
  display:inline-block;
  width: 28px;
  height: 1px;
  background: rgba(255,255,255,.85);
}
.orn-spr__promo-headline{
  margin:0;
  font-family: var(--font);
  font-style: normal;
  font-weight: 700;
  font-size: clamp(56px, 6.5vw, 104px);
  line-height: 0.95;
  letter-spacing: -2.5px;
  color:#fff;
}
.orn-spr__promo-sub-wrap{ display:inline-block; }
.orn-spr__promo-sub{
  display:inline-block;
  background: rgba(255,255,255,.18);
  backdrop-filter: blur(6px);
  padding: 8px 14px;
  border-radius: 6px;
  font-size: var(--fs-sm);
  font-weight: 500;
  letter-spacing: .3px;
}
.orn-spr__promo-photo{
  position:absolute;
  top:0; right:0;
  width: 60%;
  height: 100%;
  background-size: cover;
  background-position: center right;
  z-index: 1;
  opacity: 0.95;
  mask-image: linear-gradient(to right, transparent 0%, #000 18%);
  -webkit-mask-image: linear-gradient(to right, transparent 0%, #000 18%);
}
.orn-spr__promo-brand{
  position:absolute;
  left: 56px;
  bottom: 24px;
  z-index: 2;
}
.orn-spr__promo-brand-name{
  font-family: var(--font);
  font-weight: 600;
  font-size: var(--fs-xl);
  letter-spacing: 6px;
  color:#fff;
}
.orn-spr__promo-brand-sub{
  font-size: var(--fs-xs);
  letter-spacing: 4.2px;
  font-weight: 500;
  color: rgba(255,255,255,.78);
  margin-top: 2px;
}
.orn-spr__promo-disclaimer{
  position:absolute;
  right: 16px;
  bottom: 12px;
  font-size: var(--fs-2xs);
  color: rgba(255,255,255,.78);
  z-index: 2;
  letter-spacing: .3px;
}

/* Right: Panel + product carousel */
.orn-spr__panel{
  border-radius: 16px;
  padding: 32px 24px 24px;
  display:flex;
  flex-direction: column;
  justify-content: space-between;
}
.orn-spr__products-viewport{
  overflow-x: auto;
  overflow-y: hidden;
  scroll-snap-type: x mandatory;
  scrollbar-width: none;
}
.orn-spr__products-viewport::-webkit-scrollbar{ display:none; }
.orn-spr__products-track{
  display: grid;
  grid-auto-flow: column;
  grid-auto-columns: calc(25% - 12px);
  gap: 16px;
  padding-bottom: 8px;
}
.orn-spr__product{
  background:#fff;
  border-radius: 10px;
  padding: 14px;
  display:flex;
  flex-direction: column;
  gap: 8px;
  scroll-snap-align: start;
  transition: box-shadow .25s, transform .25s;
}
.orn-spr__product:hover{
  box-shadow: 0 8px 20px rgba(31,19,48,.12);
  transform: translateY(-2px);
}
.orn-spr__product-media{
  display:block;
  aspect-ratio: 1 / 1;
  border-radius: 6px;
  overflow:hidden;
  background:#fafafa;
}
.orn-spr__product-media img{ width:100%; height:100%; object-fit: cover; display:block; }
.orn-spr__product-price{
  font-size: var(--fs-md);
  font-weight: 600;
  color: #4E1B26;
  margin-top: 4px;
}
.orn-spr__product-price del,
.orn-spr__product-price .woocommerce-Price-amount + .woocommerce-Price-amount{
  font-size: var(--fs-sm);
  font-weight: 400;
  color: #8A8079;
  margin-left: 6px;
  text-decoration: line-through;
}
.orn-spr__product-name{
  font-size: var(--fs-sm);
  color: #4a3a5a;
  text-decoration: none;
  line-height: 1.35;
}
.orn-spr__product-name:hover{ color: var(--orn-purple, #7A2A3A); }

.orn-spr__controls{
  display:flex;
  justify-content: space-between;
  align-items: center;
  margin-top: 20px;
}
.orn-spr__arrows{ display:flex; gap: 10px; }
.orn-spr__arrow{
  width: 38px;
  height: 38px;
  border-radius: 50%;
  background: #fff;
  border: 1px solid rgba(31,19,48,.12);
  font-size: var(--fs-lg);
  line-height: 1;
  color: #5A3A42;
  cursor: pointer;
  display: grid;             /* center the ‹ › chevron precisely */
  place-items: center;
  padding: 0;
  text-align: center;
  transition: transform .2s, filter .2s;
}
.orn-spr__arrow--next{
  background: var(--orn-cta-gradient);
  color: #fff;
  border-color: transparent;
}
/* hover: NO darkening - just lift + brighten slightly */
.orn-spr__arrow:hover{ transform: scale(1.06); filter: brightness(1.05); }
.orn-spr__cta{
  display:inline-flex;
  align-items: center;
  justify-content: center;
  background: var(--orn-cta-gradient);   /* uniform gradient */
  color:#fff;
  text-decoration:none;
  padding: 12px 28px;
  border-radius: 999px;
  font-size: var(--fs-base);
  font-weight: 600;
  letter-spacing: .4px;
  transition: transform .2s, font-weight .15s;
}
/* hover: stay on the gradient, go BOLD + white (no dark fill) */
.orn-spr__cta:hover{ transform: translateY(-1px); font-weight: 800; color:#fff; }

@media (max-width: 1000px){
  .orn-spr__grid{ grid-template-columns: 1fr; }
  .orn-spr__promo{ padding: 40px 32px 28px; min-height: 360px; }
  .orn-spr__promo-text{ max-width: 100%; }
  .orn-spr__promo-photo{ width: 50%; opacity:.7; }
  .orn-spr__promo-brand{ left: 32px; }
  .orn-spr__products-track{ grid-auto-columns: calc(50% - 8px); }
}
@media (max-width: 600px){
  .orn-spr__products-track{ grid-auto-columns: 75%; }
  .orn-spr__promo-headline{ font-size: var(--fs-display); }
}

/* --- Category Grid: Lavender promo variant ----------------------- */
.orn-cat-lp{
  padding: 32px 0 48px;
  background: #fff;
}
.orn-cat-lp__card{
  border-radius: 16px;
  padding: 36px 32px;
  display:grid;
  grid-template-columns: 180px 1fr;
  gap: 32px;
  align-items: center;
}
.orn-cat-lp__promo{
  display:flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 14px;
  text-decoration: none;
  color: #4E1B26;
  text-align: left;
}
.orn-cat-lp__promo-photo{
  width: 96px;
  height: 96px;
  border-radius: 14px;
  background-size: cover;
  background-position: center;
  background-color: #F5E9E4;
  display:flex;
  align-items: center;
  justify-content: center;
}
.orn-cat-lp__promo-photo--placeholder{
  color: var(--orn-purple, #7A2A3A);
}
.orn-cat-lp__promo-label{
  font-family: var(--font);
  font-size: var(--fs-lg);
  font-weight: 600;
  color: #4E1B26;
  line-height: 1.25;
}
.orn-cat-lp__promo-sub{
  font-size: var(--fs-sm);
  color: #7A6E6A;
  font-weight: 500;
  line-height: 1.4;
}
.orn-cat-lp__tiles{
  display:grid;
  grid-template-columns: repeat(6, 1fr);
  gap: 16px;
}
.orn-cat-lp__tile{
  text-decoration: none;
  display:flex;
  flex-direction: column;
  align-items: center;
  gap: 10px;
  text-align: center;
  transition: transform .2s;
}
.orn-cat-lp__tile:hover{ transform: translateY(-3px); }
.orn-cat-lp__tile-photo{
  width: 100%;
  aspect-ratio: 1 / 1;
  border-radius: 12px;
  background-size: cover;
  background-position: center;
  background-color: #fff;
  box-shadow: 0 4px 12px rgba(31,19,48,.06);
}
.orn-cat-lp__tile-label{
  font-size: var(--fs-xs);
  font-weight: 600;
  letter-spacing: 1.2px;
  color: #5A3A42;
  line-height: 1.3;
}

@media (max-width: 1100px){
  .orn-cat-lp__card{ grid-template-columns: 1fr; gap: 24px; }
  .orn-cat-lp__promo{ flex-direction: row; align-items: center; gap: 18px; }
  .orn-cat-lp__tiles{ grid-template-columns: repeat(3, 1fr); }
}
@media (max-width: 600px){
  .orn-cat-lp__tiles{ grid-template-columns: repeat(2, 1fr); }
  .orn-cat-lp__card{ padding: 24px 18px; }
}

/* ============================================================
   BATCH 29 R2.5: Promo Trio (1 tall left + 2 stacked right)
   ============================================================ */
.orn-promo-trio{ padding: 24px 0 48px; background: #fff; }
.orn-promo-trio__grid{
  display:grid;
  grid-template-columns: 1.05fr 1fr;
  gap: 24px;
  min-height: 620px;
}
.orn-promo-trio__col{
  display:grid;
  grid-template-rows: 1fr 1fr;
  gap: 24px;
}
.orn-promo-trio__card{
  position: relative;
  display: flex;
  border-radius: 16px;
  overflow: hidden;
  padding: 40px;
  text-decoration: none;
  isolation: isolate;
  transition: transform .25s, box-shadow .25s;
  min-height: 280px;
}
.orn-promo-trio__card:hover{
  transform: translateY(-3px);
  box-shadow: 0 18px 40px rgba(31,19,48,.12);
}
.orn-promo-trio__card--tall{ min-height: 100%; }
.orn-promo-trio__body{
  position: relative;
  z-index: 2;
  display: flex;
  flex-direction: column;
  gap: 12px;
  max-width: 70%;
  align-self: flex-start;
}
.orn-promo-trio__card--align-center .orn-promo-trio__body{
  align-self: center;
  align-items: center;
  text-align: center;
  max-width: 100%;
}
.orn-promo-trio__card--align-right .orn-promo-trio__body{
  align-self: flex-end;
  align-items: flex-end;
  text-align: right;
}

/* When image is positioned bottom/right, push body to the opposite side */
.orn-promo-trio__card--pos-bottom-center .orn-promo-trio__body{ align-self: flex-start; }
.orn-promo-trio__card--pos-right-center .orn-promo-trio__body{ max-width: 60%; align-self: center; }
.orn-promo-trio__card--pos-right-bottom .orn-promo-trio__body{ max-width: 60%; align-self: flex-start; }

.orn-promo-trio__tag{
  display: inline-flex;
  align-items: center;
  background: rgba(255,255,255,.92);
  color: var(--orn-purple, #7A2A3A);
  font-size: var(--fs-xs);
  font-weight: 600;
  letter-spacing: 1.8px;
  padding: 6px 12px;
  border-radius: 4px;
  text-transform: uppercase;
}
.orn-promo-trio__h1{
  margin: 0;
  font-family: var(--font);
  font-style: normal;
  font-weight: 700;
  font-size: clamp(36px, 4.4vw, 72px);
  line-height: 1;
  letter-spacing: -1.5px;
  color: inherit;
}
.orn-promo-trio__h2{
  margin: 0;
  font-family: var(--font);
  font-weight: 500;
  font-size: clamp(22px, 2.2vw, 32px);
  line-height: 1.2;
  letter-spacing: -.4px;
  color: inherit;
}
.orn-promo-trio__emph{
  font-family: var(--font-italic) !important;
  font-style: italic !important;
  font-weight: 500;
  letter-spacing: 0;
}
.orn-promo-trio__sub-wrap{ display:flex; }
.orn-promo-trio__sub{
  display: inline-block;
  padding: 10px 22px;
  border: 1.5px solid currentColor;
  border-radius: 999px;
  font-size: var(--fs-base);
  font-weight: 500;
  letter-spacing: .3px;
  color: inherit;
  opacity: .95;
}
.orn-promo-trio__cta{
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-size: var(--fs-sm);
  font-weight: 600;
  letter-spacing: 1.6px;
  text-transform: uppercase;
  color: inherit;
  margin-top: 8px;
  border-bottom: 1.5px solid currentColor;
  padding-bottom: 2px;
  align-self: flex-start;
}
.orn-promo-trio__card--align-center .orn-promo-trio__cta{ align-self: center; }
.orn-promo-trio__card--align-right .orn-promo-trio__cta{ align-self: flex-end; }
.orn-promo-trio__cta-arrow{ font-size: var(--fs-3xs); }

@media (max-width: 1000px){
  .orn-promo-trio__grid{ grid-template-columns: 1fr; min-height: auto; }
  .orn-promo-trio__col{ grid-template-rows: auto auto; }
  .orn-promo-trio__card{ min-height: 320px; }
  .orn-promo-trio__body{ max-width: 100%; }
}
@media (max-width: 600px){
  .orn-promo-trio__card{ padding: 28px; min-height: 260px; }
  .orn-promo-trio__h1{ font-size: var(--fs-display); }
}

/* ============================================================
   BATCH 29 R3: Store Finder, Service Cards, Loyalty Row,
                UGC Banner, UGC Grid + Insider, Popular Searches.
   ============================================================ */

/* --- Store Finder ----------------------------------------------- */
.orn-store-finder{ padding: 24px 0 48px; background:#fff; }
.orn-store-finder__grid{
  display:grid;
  grid-template-columns: 1fr 1fr;
  gap: 24px;
  border-radius: 16px;
  overflow: hidden;
  min-height: 380px;
}
.orn-store-finder__image-wrap{ position: relative; overflow:hidden; border-radius: 16px; background: #e9d6c3; }
.orn-store-finder__image{ width:100%; height:100%; object-fit: cover; display:block; }
.orn-store-finder__image-placeholder{ width:100%; height:100%; background: linear-gradient(135deg, #d4baa3 0%, #f0d9c1 100%); }
.orn-store-finder__card{
  display:flex;
  flex-direction: column;
  justify-content: center;
  padding: 56px;
  border-radius: 16px;
}
.orn-store-finder__heading{
  margin: 0 0 28px;
  font-family: var(--font);
  font-weight: 600;
  font-size: clamp(28px, 2.6vw, 36px);
  line-height: 1.25;
  color: #4E1B26;
}
.orn-store-finder__sub{ font-size: var(--fs-base); color: #7A6E6A; margin: 0 0 20px; }
.orn-store-finder__form{
  display:flex;
  background:#fff;
  border-radius: 999px;
  overflow: hidden;
  box-shadow: 0 2px 8px rgba(0,0,0,.06);
}
.orn-store-finder__input{
  flex: 1;
  border: 0;
  outline: 0;
  padding: 16px 24px;
  font-size: var(--fs-base);
  font-family: var(--font);
  background: transparent;
  color: #4E1B26;
}
.orn-store-finder__submit{
  border: 0;
  background: transparent;
  color: #d4691f;
  font-weight: 700;
  letter-spacing: 1.2px;
  padding: 0 24px;
  font-size: var(--fs-sm);
  cursor: pointer;
}
.orn-store-finder__submit:hover{ color: #aa4a10; }
@media (max-width: 1000px){
  .orn-store-finder__grid{ grid-template-columns: 1fr; }
  .orn-store-finder__card{ padding: 36px 28px; }
}

/* --- Service Cards (2-up) --------------------------------------- */
.orn-service-cards{ padding: 24px 0 48px; }
.orn-service-cards__grid{
  display:grid;
  grid-template-columns: 1fr 1fr;
  gap: 24px;
}
.orn-service-card{
  display: block;
  text-decoration: none;
  padding: 56px 48px;
  border-radius: 16px;
  min-height: 340px;
  color: #fff;
  position: relative;
  isolation: isolate;
  transition: transform .25s, box-shadow .25s;
  background-color: #8A8079;
}
.orn-service-card:hover{ transform: translateY(-4px); box-shadow: 0 20px 44px rgba(31,19,48,.18); }
.orn-service-card__body{
  display:flex;
  flex-direction: column;
  justify-content: space-between;
  height: 100%;
  min-height: 240px;
  position: relative;
  z-index: 2;
}
.orn-service-card__heading{
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: 4px;
  font-family: var(--font);
  font-weight: 600;
  font-size: clamp(26px, 2.6vw, 34px);
  line-height: 1.2;
  color: #fff;
  letter-spacing: -0.5px;
}
.orn-service-card__cta{
  display: inline-flex;
  align-items: center;
  background: rgba(0,0,0,.6);
  color: #fff;
  padding: 14px 22px;
  font-size: var(--fs-sm);
  font-weight: 700;
  letter-spacing: 1.4px;
  border-radius: 4px;
  align-self: flex-start;
  margin-top: 24px;
}
@media (max-width: 1000px){
  .orn-service-cards__grid{ grid-template-columns: 1fr; }
  .orn-service-card{ padding: 40px 32px; }
}

/* --- Loyalty Row (3-up) ----------------------------------------- */
.orn-loyalty-row{ padding: 24px 0 48px; background: #fff; }
.orn-loyalty-row__grid{
  display:grid;
  grid-template-columns: 1.5fr 1.5fr 1fr;
  gap: 16px;
}
.orn-loyalty-card{
  position: relative;
  display: block;
  border-radius: 14px;
  overflow: hidden;
  padding: 32px;
  min-height: 180px;
  text-decoration: none;
  isolation: isolate;
  transition: transform .25s;
}
.orn-loyalty-card:hover{ transform: translateY(-3px); }
.orn-loyalty-card__text{ position: relative; z-index: 2; max-width: 60%; display:flex; flex-direction: column; gap: 10px; }
.orn-loyalty-card__eyebrow{
  font-size: var(--fs-2xs);
  font-weight: 700;
  letter-spacing: 2px;
  text-transform: uppercase;
  opacity: 0.85;
}
.orn-loyalty-card__headline{
  margin: 0;
  font-family: var(--font);
  font-weight: 600;
  font-size: clamp(16px, 1.5vw, 20px);
  line-height: 1.3;
  color: inherit;
}
.orn-loyalty-card__cta{
  display: inline-flex;
  align-items: center;
  background: rgba(255,255,255,.92);
  color: #4E1B26;
  padding: 8px 18px;
  font-size: var(--fs-sm);
  font-weight: 600;
  border-radius: 999px;
  align-self: flex-start;
  margin-top: 8px;
}
.orn-loyalty-card__brand{
  position: absolute;
  top: 20px;
  right: 24px;
  font-family: var(--font-italic);
  font-style: italic;
  font-weight: 600;
  font-size: var(--fs-2xl);
  letter-spacing: 2px;
  z-index: 2;
}
.orn-loyalty-card__image{
  position: absolute;
  right: 0;
  bottom: 0;
  width: 45%;
  height: 100%;
  background-size: contain;
  background-position: right center;
  background-repeat: no-repeat;
  z-index: 1;
}
@media (max-width: 1000px){
  .orn-loyalty-row__grid{ grid-template-columns: 1fr; }
}

/* --- UGC Banner ------------------------------------------------- */
.orn-ugc-banner{ padding: 0; margin: 24px 0 48px; }
.orn-ugc-banner__row{
  display:grid;
  grid-template-columns: 1fr 2fr 1fr;
  gap: 12px;
  min-height: 280px;
  align-items: center;
  padding: 32px 24px;
}
/* Text-only mode (no photos uploaded): collapse to a single centered column. */
.orn-ugc-banner--text-only .orn-ugc-banner__row{
  grid-template-columns: 1fr;
  justify-items: center;
  text-align: center;
}
.orn-ugc-banner--text-only .orn-ugc-banner__center{
  max-width: 720px;
  margin: 0 auto;
}
.orn-ugc-banner__strip{ display:grid; gap: 12px; height: 100%; }
.orn-ugc-banner__strip--left  { grid-template-columns: repeat(3, 1fr); }
.orn-ugc-banner__strip--right { grid-template-columns: repeat(3, 1fr); }
.orn-ugc-banner__photo{
  aspect-ratio: 1 / 1;
  background-size: cover;
  background-position: center;
  border-radius: 4px;
  background-color: #2c1f3d;
}
.orn-ugc-banner__photo--placeholder{ background: linear-gradient(135deg, #3a2750 0%, #4E1B26 100%); }
.orn-ugc-banner__center{ text-align: center; color: #fff; padding: 0 24px; }
.orn-ugc-banner__eyebrow{
  font-size: var(--fs-2xl);
  color: #fff;
  margin-bottom: 10px;
}
.orn-ugc-banner__eyebrow em{
  font-family: var(--font-italic);
  font-style: italic;
  font-weight: 500;
}
.orn-ugc-banner__heading{
  margin: 0 0 24px;
  font-family: var(--font);
  font-weight: 500;
  font-size: clamp(22px, 2.4vw, 32px);
  line-height: 1.3;
  color: #fff;
}
.orn-ugc-banner__cta{
  display: inline-flex;
  align-items: center;
  background: var(--orn-cta-gradient);
  color: #fff;
  text-decoration: none;
  padding: 14px 36px;
  border-radius: 999px;
  font-size: var(--fs-sm);
  font-weight: 600;
  letter-spacing: 1.6px;
  text-transform: uppercase;
}
@media (max-width: 1000px){
  .orn-ugc-banner__row{ grid-template-columns: 1fr; }
  .orn-ugc-banner__strip{ grid-template-columns: repeat(6, 1fr) !important; }
}

/* --- UGC Grid + Insider ---------------------------------------- */
.orn-ugc-grid{ padding: 24px 0 48px; background: #fff; }
.orn-ugc-grid__grid{
  display:grid;
  gap: 12px;
  margin-bottom: 24px;
}
.orn-ugc-grid__cell{
  aspect-ratio: 1 / 1;
  background-size: cover;
  background-position: center;
  border-radius: 6px;
  display: block;
  text-decoration: none;
}
.orn-ugc-grid__cell--placeholder{ background: linear-gradient(135deg, #f5e9d9 0%, #f7f3ec 100%); }

.orn-insider-card{
  display:grid;
  grid-template-columns: 1fr 1.4fr;
  gap: 32px;
  align-items: center;
  border-radius: 16px;
  padding: 32px 48px;
  color: #fff;
}
.orn-insider-card__text{ display:flex; flex-direction: column; gap: 8px; }
.orn-insider-card__heading{
  margin: 0;
  font-family: var(--font);
  font-weight: 600;
  font-size: clamp(22px, 2vw, 28px);
  color: #fff;
}
.orn-insider-card__sub{ margin: 0; font-size: var(--fs-sm); color: rgba(255,255,255,.85); }
.orn-insider-card__form{
  display:grid;
  grid-template-columns: 1fr;
  gap: 12px;
}
.orn-insider-card__email{
  border: 0;
  background: #fff;
  border-radius: 999px;
  padding: 14px 24px;
  font-family: var(--font);
  font-size: var(--fs-base);
  color: #4E1B26;
}
.orn-insider-card__submit{
  border: 0;
  background: var(--orn-cta-gradient);
  color: #fff;
  padding: 14px 24px;
  border-radius: 999px;
  font-weight: 600;
  letter-spacing: 1.2px;
  font-size: var(--fs-sm);
  cursor: pointer;
}
.orn-insider-card__radios{
  display:flex;
  gap: 20px;
  font-size: var(--fs-sm);
  color: rgba(255,255,255,.92);
}
.orn-insider-card__radios input{ accent-color: #B76E79; }
@media (max-width: 800px){
  .orn-insider-card{ grid-template-columns: 1fr; padding: 24px; }
}

/* --- Popular Searches ------------------------------------------ */
.orn-popular-searches{ padding: 40px 0 48px; background: #fff; }
.orn-popular-searches__heading{
  text-align: center;
  margin: 0 0 28px;
  font-family: var(--font);
  font-weight: 600;
  font-size: clamp(20px, 1.8vw, 26px);
  color: #4E1B26;
}
.orn-popular-searches__list{
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 18px;
}
.orn-popular-searches__group{
  border-bottom: 1px solid rgba(31,19,48,.08);
  padding-bottom: 18px;
}
.orn-popular-searches__group:last-child{ border-bottom: 0; }
.orn-popular-searches__label{
  font-family: var(--font);
  font-weight: 600;
  font-size: var(--fs-sm);
  color: var(--orn-purple, #7A2A3A);
  margin-bottom: 8px;
  letter-spacing: 0.3px;
}
.orn-popular-searches__links{
  font-size: var(--fs-sm);
  color: #7A6E6A;
  line-height: 1.7;
}
.orn-popular-searches__links a{
  color: #7A6E6A;
  text-decoration: none;
  white-space: nowrap;
}
.orn-popular-searches__links a:hover{ color: var(--orn-purple, #7A2A3A); text-decoration: underline; }

/* Insider signup form feedback states */
.orn-insider-card__feedback{
  grid-column: 1 / -1;
  font-size: var(--fs-sm);
  margin-top: 6px;
  min-height: 18px;
  font-weight: 500;
}
.orn-insider-card__feedback.is-loading  { color: rgba(255,255,255,.78); }
.orn-insider-card__feedback.is-success  { color: #c7f5d2; }
.orn-insider-card__feedback.is-error    { color: #ffc1c8; }

/* =========================================================================
   BATCH 39 - Wishlist page: CaratLane-style product-card grid
   (overrides TI's default data-table via woocommerce/ti-wishlist.php)
   ========================================================================= */
.orn-wishlist{ max-width: var(--wrap); margin-inline: auto; padding: clamp(16px,3vw,32px) clamp(16px,4vw,40px) clamp(40px,6vw,80px); }
.orn-wishlist__head{
  display: flex; align-items: baseline; gap: 12px;
  margin: 0 0 clamp(18px,3vw,32px);
}
.orn-wishlist__title{
  font-family: var(--font);
  font-weight: 600;
  font-size: var(--fs-xl);
  letter-spacing: -0.3px;
  color: var(--orn-ink-strong);
  margin: 0;
}
.orn-wishlist__count{ font-size: var(--fs-sm); color: var(--orn-ink-soft); }

.orn-wishlist-grid{
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: clamp(12px, 1.6vw, 22px);
}
@media (max-width: 1280px){ .orn-wishlist-grid{ grid-template-columns: repeat(4, 1fr); } }
@media (max-width: 1024px){ .orn-wishlist-grid{ grid-template-columns: repeat(3, 1fr); } }
@media (max-width: 700px){  .orn-wishlist-grid{ grid-template-columns: repeat(2, 1fr); gap: 12px; } }

.orn-wishlist-card{
  position: relative;
  display: flex;
  flex-direction: column;
  background: #fff;
  border: 1px solid var(--orn-line);
  border-radius: 14px;
  overflow: hidden;
  transition: box-shadow .2s ease, transform .2s ease;
}
.orn-wishlist-card:hover{
  box-shadow: 0 10px 30px -14px rgba(33,36,62,0.22);
  transform: translateY(-2px);
}
.orn-wishlist-card__remove{
  position: absolute; top: 8px; right: 8px; z-index: 3;
  width: 30px; height: 30px;
  display: grid; place-items: center;
  border: 0; border-radius: 50%;
  background: rgba(255,255,255,0.94);
  box-shadow: 0 1px 4px rgba(31,19,48,0.12);
  color: var(--orn-ink-strong);
  font-size: var(--fs-lg); line-height: 0;
  cursor: pointer;
  transition: background .15s ease, color .15s ease;
}
.orn-wishlist-card__remove:hover{ background: var(--orn-rose); color: #fff; }

.orn-wishlist-card__media{
  display: block;
  aspect-ratio: 1 / 1;
  background: #fafafb;
  overflow: hidden;
}
.orn-wishlist-card__media img{
  width: 100% !important; height: 100% !important;
  object-fit: cover; object-position: center;
  display: block;
  transition: transform .4s ease;
}
.orn-wishlist-card:hover .orn-wishlist-card__media img{ transform: scale(1.04); }

.orn-wishlist-card__body{
  padding: 12px 12px 6px;
  display: flex; flex-direction: column; gap: 3px;
  flex: 1 1 auto;
}
.orn-wishlist-card__price{
  font-family: var(--font);
  font-weight: 700;
  font-size: var(--fs-sm);
  color: var(--orn-ink-strong);
}
.orn-wishlist-card__price del{ color: var(--orn-grey-500); font-weight: 500; margin-left: 4px; font-size: var(--fs-xs); }
.orn-wishlist-card__price ins{ text-decoration: none; }
.orn-wishlist-card__name{
  font-family: var(--font);
  font-size: var(--fs-xs);
  color: var(--orn-ink-soft);
  text-decoration: none;
  line-height: 1.35;
}
.orn-wishlist-card__name:hover{ color: var(--orn-purple); }
.orn-wishlist-card__oos{ font-size: var(--fs-2xs); color: var(--orn-rose); font-weight: 600; }

.orn-wishlist-card__cta{
  margin: 8px 12px 12px;
  padding: 10px 12px;
  text-align: center;
  border: 1px solid var(--orn-purple);
  border-radius: var(--radius-pill);
  background: #fff;
  color: var(--orn-purple) !important;
  font-family: var(--font);
  font-weight: 700;
  font-size: var(--fs-xs);
  letter-spacing: .04em;
  text-transform: uppercase;
  text-decoration: none;
  transition: background .15s ease, color .15s ease;
}
.orn-wishlist-card__cta:hover{ background: var(--orn-purple); color: #fff !important; }

/* Empty-state heading (TI empty template) gets our spacing too. */
.orn-wishlist .tinv-wishlist-empty{ text-align: center; padding: clamp(40px,8vw,100px) 0; }

/* Hide TI's internal "Default wishlist" list-name header - our own
   "Your Wishlist" heading (.orn-wishlist__title) is the page title. Each
   user still has their own separate list; we just don't show the list's
   internal name. */
.orn-wishlist .tinv-header{ display: none !important; }

/* Guest login nudge on the wishlist page (subtle, dismissable-feel banner). */
.orn-wishlist-login{
  display: flex;
  align-items: center;
  gap: 10px;
  margin: 0 0 clamp(16px,2.5vw,28px);
  padding: 12px 16px;
  background: var(--orn-purple-pale);
  border: 1px solid rgba(79,50,103,0.12);
  border-radius: 12px;
  font-size: var(--fs-sm);
  color: var(--orn-ink-soft);
}
.orn-wishlist-login__icon{ flex-shrink: 0; color: var(--orn-purple); display: inline-flex; }
.orn-wishlist-login__text{ flex: 1 1 auto; }
.orn-wishlist-login__cta{
  flex-shrink: 0;
  padding: 7px 16px;
  border-radius: var(--radius-pill);
  background: var(--orn-purple);
  color: #fff !important;
  font-weight: 700;
  font-size: var(--fs-xs);
  letter-spacing: .03em;
  text-transform: uppercase;
  text-decoration: none;
  transition: filter .15s ease;
}
.orn-wishlist-login__cta:hover{ filter: brightness(1.08); }
@media (max-width: 600px){
  .orn-wishlist-login{ flex-wrap: wrap; }
  .orn-wishlist-login__text{ flex: 1 1 100%; }
}

/* =========================================================================
   BATCH 48 - Gold touches (rationed, ~part of the 5%)
     #1 thin gold hairlines (under nav, above footer)
     #3 gold hallmark / certification trust pills
   ========================================================================= */

/* #1 - Quiet gold "frame" hairlines. A 2px gold rule under the nav bar and
   above the footer reads expensive without adding gold mass. */
.orn-nav{
  border-bottom: 2px solid var(--orn-gold);
}
.orn-footer{
  border-top: 2px solid var(--orn-gold);
}

/* #3 - Trust pills become a gold-outlined "hallmark" chip: cream fill, thin
   gold border, gold-brown text, tiny gold check. Signals certified-purity. */
.orn-trust-pill{
  background: #FCF8EF !important;                 /* faint warm gold tint */
  color: #8A6D2A !important;                      /* deep gold-brown text (readable) */
  border: 1px solid var(--orn-gold) !important;   /* antique gold hairline */
}
.orn-trust-pill::before{
  content: '';
  display: inline-block;
  width: 9px; height: 9px;
  margin-right: 1px;
  flex-shrink: 0;
  background: var(--orn-gold);
  -webkit-mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='black' d='M9 16.2 4.8 12l-1.4 1.4L9 19 21 7l-1.4-1.4z'/%3E%3C/svg%3E") center/contain no-repeat;
          mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='black' d='M9 16.2 4.8 12l-1.4 1.4L9 19 21 7l-1.4-1.4z'/%3E%3C/svg%3E") center/contain no-repeat;
}

/* =========================================================================
   BATCH 52 - Homepage: center carousel arrows + bold-on-hover CTAs
   ========================================================================= */
/* Center the ‹ › chevrons in every round carousel arrow */
.orn-hero-carousel__arrow,
.orn-home-cat__arrow,
.orn-collections-carousel__arrow{
  display: grid !important;
  place-items: center !important;
  line-height: 1 !important;
  text-align: center !important;
  padding: 0 !important;
}
/* Primary CTAs: on hover stay on the gradient, go BOLD + white - never darken */
.orn-btn:hover, .button:hover, button.button:hover, a.button:hover,
.single-product.woocommerce div.product .single_add_to_cart_button:hover,
.orn-hero-slide__cta:hover,
.orn-insider-card__submit:hover,
.orn-ugc-banner__cta:hover,
.orn-loyalty-card__cta:hover,
.orn-spr__cta:hover,
.orn-buy-now-btn:hover{
  filter: brightness(1.05) !important;
  font-weight: 800 !important;
  color: #fff !important;
  -webkit-text-fill-color: #fff !important;
}

/* ==========================================================================
   54. Checkout & PLP pagination polish (Batch 54)
   - Compact centered pagination (profile aesthetic)
   - Checkout panels -> profile-card header/body
   - Address form uniform, pincode loading
   - Gifting calendar fit
   - Order review table + payment method cards (professional)
   - Loyalty redeem realtime block
   ========================================================================== */

/* --- 54.1 PLP pagination (shop / category) --- */
.woocommerce-pagination{display:flex;justify-content:center;margin:34px 0 6px;}
.woocommerce-pagination ul.page-numbers{display:inline-flex;align-items:center;flex-wrap:wrap;justify-content:center;gap:6px;list-style:none;margin:0;padding:0;border:0;}
.woocommerce-pagination ul.page-numbers li{margin:0;border:0;display:inline-flex;}
.woocommerce-pagination .page-numbers{
  display:inline-flex;align-items:center;justify-content:center;
  min-width:34px;height:34px;padding:0 11px;
  border:1px solid var(--orn-line);border-radius:9px;
  font-family:var(--font);font-size:var(--fs-sm);font-weight:600;
  color:var(--orn-ink);background:#fff;text-decoration:none;line-height:1;
  transition:border-color .12s ease,color .12s ease,background .12s ease;
}
.woocommerce-pagination a.page-numbers:hover{border-color:var(--orn-purple);color:var(--orn-purple);}
.woocommerce-pagination .page-numbers.current{background:var(--orn-purple);border-color:var(--orn-purple);color:#fff;}
.woocommerce-pagination .page-numbers.dots{border:none;background:none;min-width:auto;padding:0 2px;color:var(--orn-ink-soft);}
.woocommerce-pagination .next.page-numbers,
.woocommerce-pagination .prev.page-numbers{font-size:var(--fs-base);font-weight:500;}

/* --- 54.2 Checkout step nav: smaller, calmer --- */
.orn-checkout-steps{gap:6px;margin:6px 0 26px;}
.orn-checkout-step{padding:6px 8px;gap:8px;font-size:var(--fs-xs);}
.orn-checkout-step__num{width:24px;height:24px;font-size:var(--fs-xs);}
.orn-checkout-step__sep{width:34px;height:2px;}
@media (max-width:520px){
  .orn-checkout-step__label{display:none;}
  .orn-checkout-step__sep{width:22px;}
}

/* --- 54.3 Panels as profile cards --- */
.orn-checkout-panel{padding:0;overflow:visible;}
.orn-checkout-panel__head{
  display:flex;align-items:center;justify-content:space-between;
  padding:15px 20px;border-bottom:1px solid var(--orn-line);
  background:var(--orn-purple-pale);border-radius:14px 14px 0 0;
}
.orn-checkout-panel__head h2{margin:0;font-size:var(--fs-base);font-weight:700;color:var(--orn-ink-strong);}
.orn-checkout-panel__body{padding:clamp(18px,2.5vw,26px);}
.orn-checkout-panel__sub{margin:0 0 20px;}

/* --- 54.4 Address form: grouped, uniform --- */
.orn-checkout-form .form-row label{font-weight:600;color:var(--orn-ink-strong);}
.orn-checkout-form .woocommerce-billing-fields__field-wrapper,
.orn-checkout-form .woocommerce-shipping-fields__field-wrapper{display:grid;grid-template-columns:1fr 1fr;gap:14px 18px;}
.orn-checkout-form .form-row-wide,
.orn-checkout-form #billing_address_1_field,
.orn-checkout-form #billing_address_2_field{grid-column:1 / -1;}
@media (max-width:620px){
  .orn-checkout-form .woocommerce-billing-fields__field-wrapper,
  .orn-checkout-form .woocommerce-shipping-fields__field-wrapper{grid-template-columns:1fr;}
}
.orn-checkout-form h3{font-size:var(--fs-base);font-weight:700;color:var(--orn-ink-strong);margin:4px 0 14px;}
.orn-checkout-form .select2-container--default .select2-selection--single{
  height:auto;border:1px solid var(--orn-line);border-radius:8px;padding:7px 10px;
}
.orn-checkout-form .select2-container--default .select2-selection--single .select2-selection__rendered{line-height:1.6;color:var(--orn-ink-strong);padding:0;}
.orn-checkout-form .select2-container--default .select2-selection--single .select2-selection__arrow{height:100%;}
#billing_postcode.orn-pin-loading{background:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='18' height='18' viewBox='0 0 24 24' fill='none' stroke='%234F3267' stroke-width='2'%3E%3Cpath d='M21 12a9 9 0 1 1-6.219-8.56'/%3E%3C/svg%3E") no-repeat right 12px center / 16px;}

/* --- 54.5 Gifting: calendar fits the row --- */
.orn-checkout-gifting .orn-datefield{max-width:260px;}
.orn-checkout-gifting .orn-datefield__display{
  width:100%;padding:12px 40px 12px 14px;border:1px solid var(--orn-line);border-radius:8px;
  font-family:var(--font);font-size:var(--fs-base);color:var(--orn-ink-strong);cursor:pointer;background:#fff;
}
.orn-checkout-gifting .orn-cal{z-index:30;}

/* --- 54.6 Order review table (payment step) --- */
.orn-checkout-payment table.shop_table{
  width:100%;border-collapse:collapse;border:1px solid var(--orn-line);
  border-radius:12px;overflow:hidden;margin:0 0 20px;
}
.orn-checkout-payment table.shop_table th,
.orn-checkout-payment table.shop_table td{
  padding:12px 16px;text-align:left;font-size:var(--fs-sm);
  border-bottom:1px solid var(--orn-line);color:var(--orn-ink);
}
.orn-checkout-payment table.shop_table thead th{
  background:var(--orn-purple-pale);font-weight:700;color:var(--orn-ink-strong);
  text-transform:uppercase;letter-spacing:.04em;font-size:var(--fs-xs);
}
.orn-checkout-payment table.shop_table td:last-child,
.orn-checkout-payment table.shop_table th:last-child{text-align:right;}
.orn-checkout-payment table.shop_table .product-name{font-weight:600;color:var(--orn-ink-strong);}
.orn-checkout-payment table.shop_table .product-name .orn-price-lock,
.orn-checkout-payment table.shop_table .product-name small{display:block;font-weight:500;color:var(--orn-ink-soft);font-size:var(--fs-xs);margin-top:3px;}
.orn-checkout-payment table.shop_table tfoot th,
.orn-checkout-payment table.shop_table tfoot td{font-weight:600;background:#fff;}
.orn-checkout-payment table.shop_table tfoot tr:last-child th,
.orn-checkout-payment table.shop_table tfoot tr:last-child td{
  font-size:var(--fs-base);font-weight:800;color:var(--orn-ink-strong);border-bottom:none;
}

/* --- 54.7 Payment method cards (professional) --- */
.orn-checkout-payment #payment{background:transparent;border:0;padding:0;}
.orn-checkout-payment .wc_payment_methods{gap:12px;}
.orn-checkout-payment .wc_payment_method{
  display:flex;flex-wrap:wrap;align-items:center;
  padding:16px 18px;border:1.5px solid var(--orn-line);border-radius:12px;
  background:#fff;transition:border-color .15s ease,box-shadow .15s ease,background .15s ease;
}
.orn-checkout-payment .wc_payment_method:hover{border-color:var(--orn-purple-mid);}
.orn-checkout-payment .wc_payment_method:has(input:checked){
  border-color:var(--orn-purple);background:var(--orn-purple-pale);
  box-shadow:0 0 0 3px var(--orn-purple-soft);
}
.orn-checkout-payment .wc_payment_method > input[type="radio"]{
  width:19px;height:19px;flex:0 0 auto;margin:0;accent-color:var(--orn-purple);cursor:pointer;
}
.orn-checkout-payment .wc_payment_method > label{
  flex:1 1 auto;margin:0 0 0 12px;display:flex;align-items:center;gap:10px;
  font-weight:600;font-size:var(--fs-base);color:var(--orn-ink-strong);cursor:pointer;
}
.orn-checkout-payment .wc_payment_method > label img{max-height:26px;width:auto;margin-left:auto;}
.orn-checkout-payment .wc_payment_method .payment_box{
  flex:0 0 100%;margin:12px 0 0;padding:12px 14px;background:#fff;border-radius:8px;
  font-size:var(--fs-sm);color:var(--orn-ink-soft);border:1px solid var(--orn-line);
}
.orn-checkout-payment .wc_payment_method .payment_box::before{display:none;}
.orn-checkout-payment .wc_payment_method .payment_box p{margin:0;}

/* --- 54.8 Loyalty redeem realtime block --- */
.orn-checkout-payment .orn-redeem{
  margin:0 0 18px;padding:16px 18px;border:1px solid var(--orn-line);
  border-radius:12px;background:linear-gradient(180deg,var(--orn-purple-pale),#fff);border-left:3px solid var(--orn-purple);
}
.orn-redeem__head{margin-bottom:12px;}
.orn-redeem__title{font-size:var(--fs-base);font-weight:700;}
.orn-redeem__row{gap:12px;}
.orn-redeem__input{width:110px;text-align:right;padding:11px 12px;border-radius:9px;}
.orn-redeem__input:focus{outline:none;border-color:var(--orn-purple);box-shadow:0 0 0 3px var(--orn-purple-soft);}
.orn-redeem__hint{margin-top:8px;}

/* --- 54.9 Place order button + terms --- */
.orn-checkout-payment .woocommerce-terms-and-conditions-wrapper{margin:16px 0 0;font-size:var(--fs-sm);color:var(--orn-ink-soft);}
.orn-checkout-payment #place_order{margin-top:18px;letter-spacing:.08em;}

/* --- 54.4b Address form: full-width stack + real 2-col grid (override) --- */
.orn-checkout-form #customer_details{display:block;}
.orn-checkout-form #customer_details .col-1,
.orn-checkout-form #customer_details .col-2{width:100%;max-width:none;float:none;margin:0;}
.orn-checkout-form #customer_details .col-2{margin-top:22px;}
.orn-checkout-form .woocommerce-billing-fields,
.orn-checkout-form .woocommerce-shipping-fields,
.orn-checkout-form .woocommerce-additional-fields,
.orn-checkout-form .woocommerce-billing-fields__field-wrapper,
.orn-checkout-form .woocommerce-additional-fields__field-wrapper{width:100%;max-width:none;}
.orn-checkout-form .woocommerce-billing-fields__field-wrapper{
  display:grid;grid-template-columns:1fr 1fr;gap:16px 18px;
}
.orn-checkout-form .woocommerce-billing-fields__field-wrapper > p.form-row{
  width:100% !important;max-width:none !important;justify-self:stretch;margin:0;min-width:0;
}
.orn-checkout-form p.form-row-wide,
.orn-checkout-form #billing_country_field,
.orn-checkout-form #billing_address_1_field,
.orn-checkout-form #billing_address_2_field,
.orn-checkout-form #billing_email_field{grid-column:1 / -1;}
.orn-checkout-form .form-row .input-text,
.orn-checkout-form .form-row input[type="text"],
.orn-checkout-form .form-row input[type="email"],
.orn-checkout-form .form-row input[type="tel"],
.orn-checkout-form .form-row select{width:100% !important;box-sizing:border-box;}
.orn-checkout-form .form-row label{line-height:1.3;}
@media (max-width:620px){
  .orn-checkout-form .woocommerce-billing-fields__field-wrapper{grid-template-columns:1fr;}
}

/* --- 54.7b Payment box: beat WC's #payment id specificity --- */
.orn-checkout-payment #payment div.payment_box,
.orn-checkout-payment .wc_payment_method div.payment_box{
  background:#fff !important;color:var(--orn-ink-soft);
  border:1px solid var(--orn-line);border-radius:8px;margin:12px 0 0;padding:12px 14px;
}
.orn-checkout-payment #payment div.payment_box::before{display:none !important;}

/* ==========================================================================
   55. Thank-you: live tracking card, timeline states, mobile (Batch 55)
   ========================================================================== */

/* Live Shiprocket tracking card */
.orn-thankyou__track{
  border:1px solid var(--orn-line);
  border-left:3px solid var(--orn-purple);
  border-radius:14px;
  padding:16px 18px;
  background:linear-gradient(180deg,var(--orn-purple-pale),#fff);
  display:flex;flex-direction:column;gap:8px;
}
.orn-thankyou__track-head{display:flex;align-items:center;gap:10px;font-weight:700;color:var(--orn-ink-strong);font-size:var(--fs-lg);}
.orn-thankyou__track-head .orn-uicon{color:var(--orn-purple);}
.orn-thankyou__track-status{margin-left:auto;font-style:normal;font-size:var(--fs-sm);font-weight:600;color:var(--orn-purple);background:var(--orn-purple-soft);padding:4px 10px;border-radius:999px;}
.orn-thankyou__track-meta{display:flex;flex-wrap:wrap;gap:6px 18px;font-size:var(--fs-sm);color:var(--orn-ink);}
.orn-thankyou__track-meta strong{color:var(--orn-ink-soft);font-weight:500;}
.orn-thankyou__track-link{align-self:flex-start;font-weight:600;color:var(--orn-purple);font-size:var(--fs-sm);}
.orn-thankyou__track-link:hover{text-decoration:underline;}

/* Timeline: completed steps */
.orn-thankyou__timeline li.is-done .orn-thankyou__step-dot{
  background:var(--orn-purple);border-color:var(--orn-purple);
}
.orn-thankyou__timeline li.is-done .orn-thankyou__step-dot::after{
  content:"";position:absolute;left:50%;top:50%;width:5px;height:9px;
  border:solid #fff;border-width:0 2px 2px 0;transform:translate(-50%,-60%) rotate(45deg);
}
.orn-thankyou__step-dot{position:relative;}
.orn-thankyou__timeline li.is-done strong{color:var(--orn-ink-strong);}
.orn-thankyou__timeline li.is-done span,
.orn-thankyou__timeline li.is-active span{color:var(--orn-ink);}

/* Mobile optimisation */
@media (max-width:600px){
  .orn-thankyou__hero{margin-bottom:6px;}
  .orn-thankyou__title{font-size:clamp(1.4rem,7vw,1.9rem);}
  .orn-thankyou__grid{gap:20px;}
  .orn-thankyou__main{gap:18px;}
  .orn-thankyou__eta{flex-direction:row;align-items:flex-start;gap:12px;padding:14px;}
  .orn-thankyou__cta-row{flex-direction:column;gap:10px;}
  .orn-thankyou__cta-row .orn-btn{width:100%;text-align:center;justify-content:center;}
  .orn-thankyou__track-head{font-size:var(--fs-base);flex-wrap:wrap;}
  .orn-thankyou__track-status{margin-left:0;}
  .orn-thankyou__item-thumb img{width:56px;height:56px;}
  .orn-thankyou__side{margin-top:4px;}
}

/* ==========================================================================
   56. Brand logo image (header) — Batch 56
   ========================================================================== */
.orn-logo__link{display:inline-flex;align-items:center;line-height:0;}
.orn-logo__img{
  display:block;
  height:clamp(38px,4vw,52px);
  width:auto;
  max-width:100%;
}
/* The custom-logo (if set via Customizer) should match */
.orn-logo .custom-logo{height:clamp(38px,4vw,52px);width:auto;display:block;}
@media (max-width:768px){
  .orn-logo__img,.orn-logo .custom-logo{height:34px;}
}
