/*
Theme Name: SKIGEMSJEWELINDIA Royal
Theme URI: https://skigemsjewelindia.com
Author: SKIGEMSJEWELINDIA
Description: Cinematic heritage jewellery theme — The House of SKIGEMSJEWELINDIA. Full-screen video hero, jharokha arch collections, editorial grids, scroll choreography. Wine, cream and antique gold. WooCommerce ready.
Version: 2.2.0
Requires at least: 6.0
Requires PHP: 7.4
License: GNU General Public License v2 or later
Text Domain: skigems-royal
*/

/* ============ Tokens ============ */
:root {
  --wine-deep: #2B0A12;
  --wine: #4A0F1C;
  --wine-soft: #6B1A2B;
  --cream: #F8EFDE;
  --champagne: #F1E2C4;
  --gold: #C9A24B;
  --gold-light: #E3C888;
  --gold-pale: #F0DCAE;
  --ink: #3A1220;
  --serif: 'Playfair Display', Georgia, serif;
  --accent-serif: 'Cormorant Garamond', Georgia, serif;
  --sans: 'Poppins', 'Segoe UI', Arial, sans-serif;
}

* { margin: 0; padding: 0; box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  font-family: var(--sans);
  color: var(--ink);
  background: var(--cream);
  line-height: 1.75;
  font-size: 16px;
  overflow-x: hidden;
}
img { max-width: 100%; height: auto; display: block; }
a { color: var(--wine); text-decoration: none; transition: color .3s; }
a:hover { color: var(--gold); }
h1, h2, h3, h4 { font-family: var(--serif); font-weight: 500; line-height: 1.2; }

.skg-container { max-width: 1240px; margin: 0 auto; padding: 0 28px; }

/* ============ Scroll reveal choreography ============ */
.rv { opacity: 0; transform: translateY(36px); transition: opacity 1s cubic-bezier(.16,1,.3,1), transform 1s cubic-bezier(.16,1,.3,1); }
.rv.in { opacity: 1; transform: none; }
.rv-d1 { transition-delay: .12s; }
.rv-d2 { transition-delay: .24s; }
.rv-d3 { transition-delay: .36s; }
.rv-d4 { transition-delay: .48s; }
@media (prefers-reduced-motion: reduce) {
  .rv { opacity: 1; transform: none; transition: none; }
  .skg-hero-media video { display: none; }
}

/* ============ Ornate divider ============ */
.skg-divider {
  display: flex; align-items: center; justify-content: center;
  gap: 18px; margin: 0 auto 26px; color: var(--gold);
}
.skg-divider::before, .skg-divider::after {
  content: ""; height: 1px; width: 90px;
  background: linear-gradient(90deg, transparent, var(--gold));
}
.skg-divider::after { background: linear-gradient(90deg, var(--gold), transparent); }
.skg-divider span { font-size: 15px; letter-spacing: .6em; margin-right: -.6em; }

/* ============ Header (sticky, always solid — never overlaps content) ============ */
.skg-header {
  position: sticky; top: 0; left: 0; right: 0; z-index: 100;
  padding: 18px 0 12px;
  text-align: center;
  background: linear-gradient(180deg, var(--wine) 0%, var(--wine-deep) 100%);
  border-bottom: 1px solid rgba(201,162,75,.35);
  transition: padding .4s, box-shadow .4s;
}
.skg-header.solid {
  padding: 10px 0 8px;
  box-shadow: 0 6px 30px rgba(0,0,0,.35);
}
.skg-house {
  color: var(--gold-light);
  font-size: 10px; letter-spacing: .5em; margin-right: -.5em;
  text-transform: uppercase;
}
.skg-logo a {
  font-family: var(--serif);
  font-size: clamp(20px, 3vw, 30px);
  letter-spacing: .18em;
  color: var(--gold);
}
.skg-logo a:hover { color: var(--gold-pale); }
.skg-nav { margin-top: 8px; }
.skg-nav ul { list-style: none; display: flex; flex-wrap: wrap; justify-content: center; gap: 34px; }
.skg-nav a {
  color: var(--cream); font-size: 11.5px;
  letter-spacing: .22em; text-transform: uppercase;
  padding-bottom: 4px; position: relative;
}
.skg-nav a::after {
  content: ""; position: absolute; left: 50%; right: 50%; bottom: 0;
  height: 1px; background: var(--gold); transition: left .35s, right .35s;
}
.skg-nav a:hover { color: var(--gold-light); }
.skg-nav a:hover::after { left: 0; right: 0; }

/* ============ Hero — clean split: text panel left, framed video right ============ */
.skg-hero {
  position: relative;
  color: var(--cream);
  overflow: hidden;
  background:
    radial-gradient(ellipse at 15% 15%, rgba(150,60,80,.28) 0%, transparent 55%),
    linear-gradient(150deg, #5A1524 0%, #3E0F1B 100%);
  padding: 72px 0;
}
.skg-hero-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 60px;
  align-items: center;
}
.skg-hero-media video, .skg-hero-media img {
  width: 100%; aspect-ratio: 4/3; object-fit: cover; display: block;
}
.skg-hero-inner { position: relative; }
.skg-est {
  font-size: 11px; letter-spacing: .55em; margin-right: -.55em;
  text-transform: uppercase; color: var(--gold-light);
}
.skg-hero h1 {
  font-size: clamp(34px, 4.6vw, 58px);
  margin: 22px 0 10px;
  color: var(--cream);
}
.skg-hero h1 .shimmer {
  display: block;
  font-style: italic;
  font-family: var(--accent-serif);
  background: linear-gradient(100deg, var(--gold) 20%, #F6E7BD 40%, var(--gold) 60%);
  background-size: 200% auto;
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
  animation: skgShimmer 5s linear infinite;
}
@keyframes skgShimmer { to { background-position: 200% center; } }
.skg-hero p {
  color: rgba(248,239,222,.85);
  max-width: 480px; margin: 16px 0 36px;
  font-size: 16.5px; font-weight: 300;
}
.skg-hero .skg-divider { justify-content: flex-start; margin: 0 0 6px; }
.skg-hero .skg-divider::before { display: none; }
.skg-btn {
  display: inline-block; padding: 15px 40px;
  font-size: 11.5px; letter-spacing: .28em; margin-right: -.28em;
  text-transform: uppercase;
  border: 1px solid var(--gold); transition: all .4s;
}
.skg-btn-gold { background: var(--gold); color: var(--wine-deep); }
.skg-btn-gold:hover { background: var(--gold-pale); color: var(--wine-deep); box-shadow: 0 8px 30px rgba(201,162,75,.35); }
.skg-btn-outline { color: var(--gold-light); background: rgba(32,7,14,.25); margin-left: 14px; }
.skg-btn-outline:hover { background: rgba(201,162,75,.15); color: var(--gold-pale); }
.skg-hero-frame {
  border: 1px solid var(--gold);
  padding: 12px;
  position: relative;
  background: rgba(32,7,14,.3);
}
.skg-hero-frame::before {
  content: ""; position: absolute; inset: 5px;
  border: 1px solid rgba(201,162,75,.45); pointer-events: none; z-index: 2;
}

/* ============ Marquee ribbon ============ */
.skg-marquee {
  background: var(--wine-deep);
  border-top: 1px solid rgba(201,162,75,.35);
  border-bottom: 1px solid rgba(201,162,75,.35);
  overflow: hidden; padding: 16px 0; white-space: nowrap;
}
.skg-marquee-track {
  display: inline-block;
  animation: skgMarquee 30s linear infinite;
}
.skg-marquee span {
  font-family: var(--accent-serif);
  font-size: 19px; font-style: italic;
  color: var(--gold-light);
  letter-spacing: .28em;
  padding: 0 34px;
}
.skg-marquee b { color: var(--gold); font-weight: 400; }
@keyframes skgMarquee { to { transform: translateX(-50%); } }

/* ============ Sections ============ */
.skg-section { padding: 110px 0; }
.skg-section-head { text-align: center; margin-bottom: 64px; }
.skg-kicker {
  font-size: 11px; letter-spacing: .5em; margin-right: -.5em;
  text-transform: uppercase; color: var(--gold);
  display: block; margin-bottom: 16px;
}
.skg-section-head h2 { font-size: clamp(30px, 4.2vw, 52px); color: var(--wine); }
.skg-section-head p { color: #7a5a4a; max-width: 600px; margin: 16px auto 0; font-weight: 300; }

/* ============ Collections — jharokha arches ============ */
.skg-cats { background: var(--cream); }
.skg-arch-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 30px; }
.skg-arch { text-align: center; }
.skg-arch-frame {
  position: relative;
  border-radius: 500px 500px 0 0;
  padding: 12px 12px 0;
  border: 1px solid var(--gold);
  border-bottom: none;
  transition: transform .5s cubic-bezier(.16,1,.3,1), box-shadow .5s;
}
.skg-arch:hover .skg-arch-frame { transform: translateY(-8px); box-shadow: 0 24px 60px rgba(43,10,18,.22); }
.skg-arch-frame::before {
  content: "\2756"; position: absolute; top: -13px; left: 50%; transform: translateX(-50%);
  color: var(--gold); font-size: 15px; background: var(--cream); padding: 0 10px; z-index: 3;
}
.skg-arch-img {
  border-radius: 490px 490px 0 0;
  overflow: hidden; position: relative;
}
.skg-arch-img img {
  width: 100%; aspect-ratio: 3/4; object-fit: cover;
  transition: transform .8s cubic-bezier(.16,1,.3,1);
}
.skg-arch:hover .skg-arch-img img { transform: scale(1.07); }
.skg-arch h3 {
  margin-top: 22px; font-size: 20px; color: var(--wine);
}
.skg-arch span {
  display: block; margin-top: 4px;
  font-size: 10.5px; letter-spacing: .3em; margin-right: -.3em;
  text-transform: uppercase; color: var(--gold);
}

/* ============ Editorial signature grid ============ */
.skg-editorial { background: var(--champagne); }
.skg-ed-grid {
  display: grid;
  grid-template-columns: 1.15fr 1fr 1fr;
  grid-template-rows: auto auto;
  gap: 28px;
}
.skg-ed-large { grid-row: 1 / 3; }
.skg-ed-card {
  background: #fff;
  border: 1px solid rgba(201,162,75,.4);
  overflow: hidden; position: relative;
}
.skg-ed-card .imgwrap { overflow: hidden; }
.skg-ed-card img {
  width: 100%; height: 100%; object-fit: cover;
  transition: transform .8s cubic-bezier(.16,1,.3,1);
}
.skg-ed-card:hover img { transform: scale(1.06); }
.skg-ed-large .imgwrap { height: calc(100% - 92px); }
.skg-ed-small .imgwrap { height: 250px; }
.skg-ed-meta { padding: 20px 22px 22px; text-align: center; }
.skg-ed-meta h3 { font-size: 19px; color: var(--wine); }
.skg-ed-meta span {
  font-size: 10.5px; letter-spacing: .26em; margin-right: -.26em;
  text-transform: uppercase; color: var(--gold);
}

/* ============ Heritage — wine, counters ============ */
.skg-heritage {
  background:
    radial-gradient(ellipse at 80% 10%, rgba(107,26,43,.6) 0%, transparent 50%),
    linear-gradient(135deg, var(--wine-deep) 0%, var(--wine) 100%);
  color: var(--cream);
}
.skg-her-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 70px; align-items: center; }
.skg-frame-offset { position: relative; }
.skg-frame-offset img { position: relative; z-index: 2; border: 1px solid rgba(201,162,75,.6); }
.skg-frame-offset::after {
  content: ""; position: absolute; inset: 22px -22px -22px 22px;
  border: 1px solid var(--gold); z-index: 1;
}
.skg-heritage h2 { color: var(--gold-light); font-size: clamp(28px, 3.6vw, 44px); margin-bottom: 20px; }
.skg-heritage p { color: rgba(248,239,222,.82); font-weight: 300; margin-bottom: 16px; }
.skg-pull {
  font-family: var(--accent-serif); font-style: italic;
  font-size: 21px; color: var(--gold-light);
  border-left: 1px solid var(--gold);
  padding-left: 22px; margin: 26px 0;
}
.skg-counters {
  display: grid; grid-template-columns: repeat(3, 1fr);
  gap: 20px; margin-top: 40px; text-align: center;
}
.skg-counter b {
  display: block; font-family: var(--serif); font-weight: 500;
  font-size: clamp(30px, 3.4vw, 44px); color: var(--gold);
}
.skg-counter i {
  font-style: normal; font-size: 10.5px;
  letter-spacing: .28em; margin-right: -.28em;
  text-transform: uppercase; color: rgba(248,239,222,.7);
}

/* ============ Craft strip ============ */
.skg-craft { background: var(--cream); }
.skg-craft-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 70px; align-items: center; }
.skg-craft h2 { color: var(--wine); font-size: clamp(28px, 3.6vw, 44px); margin-bottom: 20px; }
.skg-craft p { color: #6d4c3d; font-weight: 300; margin-bottom: 16px; }
.skg-steps { list-style: none; margin: 26px 0 34px; }
.skg-steps li { padding-left: 30px; position: relative; margin-bottom: 12px; }
.skg-steps li::before { content: "\2756"; position: absolute; left: 0; color: var(--gold); font-size: 13px; }

/* ============ Model quote ============ */
.skg-muse {
  background: var(--champagne);
  position: relative;
}
.skg-muse-grid { display: grid; grid-template-columns: .85fr 1.15fr; gap: 70px; align-items: center; }
.skg-bigquote {
  font-family: var(--accent-serif); font-style: italic;
  font-size: clamp(24px, 3vw, 34px); line-height: 1.55; color: var(--wine);
}
.skg-bigquote::before {
  content: "\201C"; display: block;
  font-size: 110px; line-height: .6; color: var(--gold);
  font-family: var(--serif); margin-bottom: 18px;
}
.skg-quote-by {
  margin-top: 26px; color: var(--gold);
  font-size: 11px; letter-spacing: .35em; margin-right: -.35em; text-transform: uppercase;
}

/* ============ Instagram strip ============ */
.skg-insta { background: var(--cream); text-align: center; }
.skg-ig-grid { display: grid; grid-template-columns: repeat(6, 1fr); gap: 14px; margin: 46px 0; }
.skg-ig-grid a { overflow: hidden; position: relative; display: block; border: 1px solid rgba(201,162,75,.4); }
.skg-ig-grid img { transition: transform .7s, filter .7s; aspect-ratio: 1; object-fit: cover; width: 100%; }
.skg-ig-grid a:hover img { transform: scale(1.1); filter: brightness(.75) sepia(.2); }

/* ============ Appointment / contact ============ */
.skg-appoint {
  background:
    radial-gradient(ellipse at 20% 90%, rgba(107,26,43,.55) 0%, transparent 55%),
    linear-gradient(160deg, var(--wine) 0%, var(--wine-deep) 70%);
  color: var(--cream); text-align: center;
}
.skg-appoint h2 { color: var(--gold-light); font-size: clamp(30px, 4vw, 50px); }
.skg-appoint > .skg-container > p { color: rgba(248,239,222,.8); max-width: 520px; margin: 20px auto 42px; font-weight: 300; }
.skg-appoint-cards {
  display: grid; grid-template-columns: repeat(3, 1fr);
  gap: 24px; margin-top: 54px; text-align: center;
}
.skg-appoint-card {
  border: 1px solid rgba(201,162,75,.35);
  padding: 36px 26px; background: rgba(32,7,14,.35);
  transition: border-color .4s, transform .4s;
}
.skg-appoint-card:hover { border-color: var(--gold); transform: translateY(-4px); }
.skg-appoint-card .glyph { color: var(--gold); font-size: 22px; margin-bottom: 14px; }
.skg-appoint-card h3 { color: var(--gold-light); font-size: 17px; letter-spacing: .08em; margin-bottom: 10px; }
.skg-appoint-card p { color: rgba(248,239,222,.75); font-size: 14px; font-weight: 300; }
.skg-appoint-card a { color: var(--gold-light); }
.skg-appoint-card a:hover { color: var(--gold-pale); }

/* ============ Footer ============ */
.skg-footer {
  background: #20070E;
  color: rgba(248,239,222,.65);
  text-align: center; padding: 70px 0 40px;
  border-top: 1px solid rgba(201,162,75,.3);
}
.skg-footer .skg-house { display: block; margin-bottom: 6px; }
.skg-footer .skg-logo a { font-size: 22px; }
.skg-footer-links { list-style: none; display: flex; justify-content: center; gap: 30px; margin: 26px 0; flex-wrap: wrap; }
.skg-footer-links a { color: var(--cream); font-size: 11px; letter-spacing: .22em; text-transform: uppercase; }
.skg-footer-links a:hover { color: var(--gold); }
.skg-footer small { font-size: 12px; font-weight: 300; }

/* ============ Inner pages ============ */
.skg-page { background: var(--cream); padding: 60px 0 90px; min-height: 60vh; }
.skg-page h1.entry-title, .skg-page h1 { color: var(--wine); margin-bottom: 26px; }
.skg-product-page { padding-top: 48px; }

/* ============ Shop band + category chips ============ */
.skg-shop-band {
  background:
    radial-gradient(ellipse at 80% 0%, rgba(150,60,80,.3) 0%, transparent 55%),
    linear-gradient(150deg, #5A1524 0%, #3E0F1B 100%);
  color: var(--cream);
  text-align: center;
  padding: 58px 0 34px;
}
.skg-shop-band h1 {
  font-family: var(--serif);
  color: var(--cream);
  font-size: clamp(30px, 4vw, 46px);
  margin: 12px 0 6px;
}
.skg-shop-band .skg-divider { margin-bottom: 20px; }
.skg-chips { display: flex; flex-wrap: wrap; justify-content: center; gap: 10px; padding-bottom: 6px; }
.skg-chips a {
  color: var(--gold-light);
  border: 1px solid rgba(201,162,75,.5);
  padding: 8px 20px;
  font-size: 11px; letter-spacing: .18em; text-transform: uppercase;
  border-radius: 30px;
  transition: all .3s;
}
.skg-chips a:hover { background: rgba(201,162,75,.15); color: var(--gold-pale); }
.skg-chips a.on { background: var(--gold); color: var(--wine-deep); border-color: var(--gold); }

/* ============ Shop grid ============ */
.woocommerce .woocommerce-result-count { color: #7a5a4a; font-size: 13px; }
.woocommerce .woocommerce-ordering select {
  border: 1px solid rgba(201,162,75,.6);
  background: #fff; color: var(--ink);
  padding: 9px 14px; font-family: var(--sans); font-size: 13px;
}
.woocommerce ul.products { margin-top: 30px !important; }
.woocommerce ul.products li.product {
  background: #fff;
  border: 1px solid rgba(201,162,75,.45);
  padding: 14px 14px 22px;
  text-align: center;
  transition: box-shadow .45s, transform .45s;
  position: relative;
  margin-bottom: 34px !important;
}
.woocommerce ul.products li.product:hover { box-shadow: 0 20px 50px rgba(43,10,18,.2); transform: translateY(-5px); }
.woocommerce ul.products li.product a img {
  aspect-ratio: 1; object-fit: cover; width: 100%;
  margin-bottom: 14px !important;
  transition: transform .6s;
}
.woocommerce ul.products li.product:hover a img { transform: scale(1.03); }
.woocommerce ul.products li.product .woocommerce-loop-product__title {
  font-family: var(--serif); color: var(--wine); font-size: 18px;
  padding-top: 2px;
}
.woocommerce ul.products li.product .woocommerce-loop-product__title::after {
  content: "\2756"; display: block;
  color: var(--gold); font-size: 9px; margin-top: 8px;
}
.woocommerce ul.products li.product .price,
.woocommerce div.product p.price { color: var(--gold) !important; font-weight: 600; }
.woocommerce ul.products li.product .price { font-size: 15.5px; margin-bottom: 12px; }
.woocommerce ul.products li.product .button {
  margin-top: 4px;
}
.woocommerce nav.woocommerce-pagination ul { border: none; }
.woocommerce nav.woocommerce-pagination ul li { border: none; margin: 0 3px; }
.woocommerce nav.woocommerce-pagination ul li a,
.woocommerce nav.woocommerce-pagination ul li span {
  border: 1px solid rgba(201,