/*
Theme Name: Mellow Magnets
Theme URI: https://mellowmagnets.com
Author: Mellow Magnets
Author URI: https://mellowmagnets.com
Description: A refined, elegant WordPress theme for Mellow Magnets — premium custom photo magnets for every occasion.
Version: 1.0.0
Requires at least: 6.0
Tested up to: 6.5
Requires PHP: 8.0
License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Text Domain: mellow-magnets
Tags: custom-colors, custom-logo, full-width-template, e-commerce, elegance
*/

/* === TOKENS === */
:root {
  --white:  #FFFFFF;
  --ink:    #07020D;
  --gold:   #F9DC77;
  --rose:   #EC9192;
  --sage:   #558654;
  --i4:  rgba(7,2,13,.04);
  --i8:  rgba(7,2,13,.08);
  --i15: rgba(7,2,13,.15);
  --i35: rgba(7,2,13,.35);
  --i55: rgba(7,2,13,.55);
  --g15: rgba(249,220,119,.15);
  --g30: rgba(249,220,119,.30);
  --r15: rgba(236,145,146,.15);
  --r30: rgba(236,145,146,.30);
  --s12: rgba(85,134,84,.12);
  --ease: cubic-bezier(.25,.8,.25,1);
  --t: .38s;
}

/* === RESET & BASE === */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; }
body {
  font-family: 'DM Sans', sans-serif;
  font-weight: 300;
  color: var(--ink);
  background: var(--white);
  overflow-x: hidden;
}
a { text-decoration: none; color: inherit; }
img { display: block; max-width: 100%; height: auto; }
h1, h2, h3, h4, h5, h6 {
  font-family: 'Cormorant Garamond', serif;
  font-weight: 300;
  line-height: 1.1;
}
p { line-height: 1.8; }
ul { list-style: none; }

/* === LAYOUT === */
.wrap { max-width: 1220px; margin: 0 auto; padding: 0 2rem; }
.sec  { padding: 8rem 0; }

/* === EYEBROW / LABELS === */
.eyebrow {
  font-family: 'DM Sans', sans-serif;
  font-weight: 400;
  font-size: .68rem;
  letter-spacing: .26em;
  text-transform: uppercase;
  color: var(--rose);
}
.divider {
  width: 44px; height: 1px;
  background: linear-gradient(90deg, var(--gold), transparent);
  margin: 1.4rem 0;
}
.divider.c { margin: 1.4rem auto; }

/* === BUTTONS === */
.btn {
  display: inline-flex;
  align-items: center;
  gap: .55rem;
  padding: .85rem 2.2rem;
  font-family: 'DM Sans', sans-serif;
  font-weight: 400;
  font-size: .78rem;
  letter-spacing: .13em;
  text-transform: uppercase;
  border: none;
  border-radius: 2px;
  cursor: pointer;
  transition: all var(--t) var(--ease);
}
.btn-rose   { background: var(--rose);  color: var(--white); box-shadow: 0 4px 20px var(--r30); }
.btn-rose:hover   { background: #e07e7f; transform: translateY(-2px); box-shadow: 0 8px 30px var(--r30); }
.btn-ghost  { background: transparent; color: var(--white); border: 1px solid rgba(255,255,255,.4); }
.btn-ghost:hover  { background: var(--white); color: var(--ink); transform: translateY(-2px); }
.btn-outline { background: transparent; color: var(--ink); border: 1px solid var(--i15); }
.btn-outline:hover { background: var(--ink); color: var(--white); border-color: var(--ink); transform: translateY(-2px); }

/* === NAV === */
#site-nav {
  position: fixed;
  inset: 0 0 auto;
  z-index: 900;
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 1.6rem 3rem;
  transition: all var(--t) var(--ease);
}
#site-nav.solid {
  background: rgba(255,255,255,.97);
  backdrop-filter: blur(14px);
  padding: 1rem 3rem;
  box-shadow: 0 1px 0 var(--i8);
}
.nav-logo {
  font-family: 'Cormorant Garamond', serif;
  font-weight: 300;
  font-size: 1.6rem;
  color: var(--white);
  letter-spacing: .03em;
  transition: color var(--t);
}
.nav-logo em   { font-style: italic; color: var(--gold); }
#site-nav.solid .nav-logo    { color: var(--ink); }
#site-nav.solid .nav-logo em { color: var(--rose); }

.nav-links {
  display: flex;
  align-items: center;
  gap: 2.2rem;
  list-style: none;
}
.nav-links a {
  font-size: .76rem;
  letter-spacing: .13em;
  text-transform: uppercase;
  color: rgba(255,255,255,.7);
  position: relative;
  transition: color var(--t);
}
.nav-links a::after {
  content: '';
  position: absolute;
  bottom: -4px; left: 0; right: 0;
  height: 1px;
  background: var(--gold);
  transform: scaleX(0);
  transform-origin: left;
  transition: transform var(--t) var(--ease);
}
.nav-links a:hover              { color: var(--white); }
.nav-links a:hover::after       { transform: scaleX(1); }
#site-nav.solid .nav-links a        { color: var(--i55); }
#site-nav.solid .nav-links a:hover  { color: var(--ink); }

.nav-actions { display: flex; align-items: center; gap: 1.2rem; }
.nav-signin {
  font-size: .74rem;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: rgba(255,255,255,.6);
  background: none;
  border: none;
  cursor: pointer;
  transition: color var(--t);
}
.nav-signin:hover           { color: var(--rose) !important; }
#site-nav.solid .nav-signin { color: var(--i35); }

.nav-hamburger {
  display: none;
  flex-direction: column;
  gap: 5px;
  background: none;
  border: none;
  cursor: pointer;
  padding: .4rem;
}
.nav-hamburger span {
  width: 24px; height: 1px;
  background: var(--white);
  transition: all var(--t);
}
#site-nav.solid .nav-hamburger span { background: var(--ink); }

/* Mobile nav */
.mobile-nav {
  display: none;
  position: fixed;
  inset: 0;
  z-index: 800;
  background: var(--ink);
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 2rem;
}
.mobile-nav.open { display: flex; }
.mobile-nav a {
  font-family: 'Cormorant Garamond', serif;
  font-size: 2rem;
  color: var(--white);
  letter-spacing: .04em;
}
.mobile-nav a:hover { color: var(--gold); }

/* === HERO === */
#hero {
  min-height: 100vh;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  text-align: center;
  position: relative;
  overflow: hidden;
  background: var(--ink);
}
.hero-mesh {
  position: absolute; inset: 0; pointer-events: none;
  background:
    radial-gradient(ellipse 90% 70% at 50% -10%, rgba(249,220,119,.10) 0%, transparent 65%),
    radial-gradient(ellipse 50% 60% at 10% 85%,  rgba(85,134,84,.09)   0%, transparent 55%),
    radial-gradient(ellipse 55% 50% at 90% 80%,  rgba(236,145,146,.10) 0%, transparent 55%);
}
.hero-noise {
  position: absolute; inset: 0; opacity: .032;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='300' height='300'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.85' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
  background-size: 220px;
}
.hero-body { position: relative; z-index: 2; max-width: 860px; padding: 0 2rem; }
.hero-tag {
  font-family: 'Great Vibes', cursive;
  font-size: 1.55rem;
  color: var(--gold);
  margin-bottom: .2rem;
  opacity: 0;
  animation: rise .9s .15s forwards;
}
.hero-h1 {
  font-family: 'Cormorant Garamond', serif;
  font-weight: 300;
  font-size: clamp(3.4rem, 9vw, 7rem);
  color: var(--white);
  letter-spacing: -.01em;
  line-height: 1.04;
  opacity: 0;
  animation: rise 1s .35s forwards;
}
.hero-h1 em { font-style: italic; color: var(--gold); }
.hero-sub {
  margin-top: 1.5rem;
  font-size: 1rem;
  font-weight: 200;
  letter-spacing: .07em;
  color: rgba(255,255,255,.5);
  opacity: 0;
  animation: rise .9s .55s forwards;
}
.hero-btns {
  margin-top: 3rem;
  display: flex;
  gap: 1.2rem;
  align-items: center;
  justify-content: center;
  flex-wrap: wrap;
  opacity: 0;
  animation: rise .9s .75s forwards;
}
.hero-scroll {
  position: absolute;
  bottom: 2.8rem; left: 50%;
  transform: translateX(-50%);
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: .5rem;
  color: rgba(255,255,255,.28);
  font-size: .62rem;
  letter-spacing: .22em;
  text-transform: uppercase;
  z-index: 2;
  animation: bob 2.8s ease-in-out infinite;
}
.hero-scroll::after {
  content: '';
  width: 1px; height: 44px;
  background: linear-gradient(to bottom, rgba(255,255,255,.2), transparent);
}
@keyframes rise { from { opacity:0; transform:translateY(20px); } to { opacity:1; transform:none; } }
@keyframes bob  { 0%,100%{transform:translateX(-50%) translateY(0);} 50%{transform:translateX(-50%) translateY(7px);} }

/* === TICKER === */
.ticker { overflow: hidden; background: var(--gold); padding: 1.1rem 0; }
.ticker-track {
  display: flex; gap: 3.5rem;
  animation: tick 30s linear infinite;
  white-space: nowrap;
}
.ticker-item {
  display: flex; align-items: center; gap: .65rem; flex-shrink: 0;
  font-family: 'DM Sans', sans-serif;
  font-weight: 400; font-size: .72rem;
  letter-spacing: .16em; text-transform: uppercase;
  color: var(--ink);
}
.t-dot { width:5px; height:5px; border-radius:50%; background:var(--ink); opacity:.3; flex-shrink:0; }
@keyframes tick { 0%{transform:translateX(0);} 100%{transform:translateX(-50%);} }

/* === HOW IT WORKS === */
#how { background: var(--white); }
.how-head { text-align: center; margin-bottom: 5rem; }
.how-head h2 { font-size: clamp(2.2rem,4vw,3.4rem); margin-top: .6rem; }
.how-steps {
  display: grid;
  grid-template-columns: 1fr 60px 1fr 60px 1fr;
  align-items: start;
}
.how-step { text-align: center; padding: 2.8rem 1.8rem; }
.how-num {
  font-family: 'Cormorant Garamond', serif;
  font-weight: 300; font-size: 5rem; line-height: 1;
  color: var(--gold); opacity: .45;
}
.how-icon  { font-size: 2.2rem; margin: 1rem 0 1.2rem; }
.how-step h3 { font-size: 1.5rem; margin-bottom: .7rem; }
.how-step p  { font-size: .88rem; color: var(--i55); }
.how-arr {
  align-self: center; padding-top: 2.5rem;
  font-size: 1.4rem; color: var(--rose); opacity: .55; text-align: center;
}

/* === GALLERY === */
#gallery { background: #f9f8f5; }
.gallery-head { text-align: center; margin-bottom: 4rem; }
.gallery-head h2 { font-size: clamp(2rem,3.8vw,3.2rem); margin-top: .6rem; }
.gallery-head p  { color: var(--i55); font-size: .9rem; max-width: 520px; margin: .8rem auto 0; }
.gg {
  display: grid;
  grid-template-columns: repeat(12,1fr);
  grid-template-rows: 260px 220px;
  gap: 1rem;
}
.gi { border-radius: 5px; overflow: hidden; position: relative; cursor: pointer; background: var(--i8); }
.gi:nth-child(1) { grid-column:1/6;  grid-row:1/2; }
.gi:nth-child(2) { grid-column:6/9;  grid-row:1/2; }
.gi:nth-child(3) { grid-column:9/13; grid-row:1/2; }
.gi:nth-child(4) { grid-column:1/4;  grid-row:2/3; }
.gi:nth-child(5) { grid-column:4/8;  grid-row:2/3; }
.gi:nth-child(6) { grid-column:8/13; grid-row:2/3; }
.gi img { width:100%; height:100%; object-fit:cover; transition:transform var(--t) var(--ease); }
.gf {
  width:100%; height:100%; min-height:180px;
  display:flex; flex-direction:column; align-items:center; justify-content:center; gap:.5rem;
  transition:transform var(--t) var(--ease);
}
.gi:nth-child(1) .gf { background:linear-gradient(135deg,#e8e0d4,#d4c9b8); }
.gi:nth-child(2) .gf { background:linear-gradient(135deg,var(--g15),#f0ece4); }
.gi:nth-child(3) .gf { background:linear-gradient(135deg,var(--r15),#f4eeed); }
.gi:nth-child(4) .gf { background:linear-gradient(135deg,var(--s12),#edf0ec); }
.gi:nth-child(5) .gf { background:linear-gradient(135deg,#e4e8f0,var(--g15)); }
.gi:nth-child(6) .gf { background:linear-gradient(135deg,var(--r15),var(--s12)); }
.gf-icon { font-size:2.2rem; }
.gf-lbl  { font-family:'Cormorant Garamond',serif; font-size:.95rem; color:var(--i35); letter-spacing:.06em; }
.go {
  position:absolute; inset:0;
  background:rgba(7,2,13,.68);
  display:flex; flex-direction:column; align-items:center; justify-content:center;
  opacity:0; transition:opacity var(--t) var(--ease); padding:1.5rem;
}
.go h4   { font-family:'Cormorant Garamond',serif; font-size:1.5rem; color:var(--white); margin-bottom:.3rem; }
.go span { font-size:.72rem; letter-spacing:.15em; text-transform:uppercase; color:var(--gold); }
.gi:hover .gf { transform:scale(1.05); }
.gi:hover img  { transform:scale(1.05); }
.gi:hover .go  { opacity:1; }

/* === OCCASIONS === */
#occasions { background:var(--ink); position:relative; overflow:hidden; }
.occ-glow  { position:absolute; border-radius:50%; filter:blur(90px); opacity:.12; pointer-events:none; }
.og1 { width:500px; height:500px; background:var(--gold); top:-120px; right:-80px; }
.og2 { width:400px; height:400px; background:var(--rose); bottom:-80px; left:-60px; }
.occ-head  { text-align:center; margin-bottom:5rem; position:relative; z-index:1; }
.occ-head .eyebrow { color:var(--gold); }
.occ-head h2 { font-size:clamp(2.2rem,4vw,3.4rem); color:var(--white); margin-top:.6rem; }
.occ-head p  { color:rgba(255,255,255,.45); margin-top:.8rem; font-size:.92rem; }
.occ-grid { display:grid; grid-template-columns:repeat(5,1fr); gap:1.2rem; position:relative; z-index:1; }
.oc {
  border:1px solid rgba(255,255,255,.1);
  border-radius:5px; padding:2.6rem 1.4rem 2.2rem;
  text-align:center; transition:all var(--t) var(--ease);
  position:relative; overflow:hidden; cursor:default;
}
.oc:hover { border-color:rgba(255,255,255,.25); transform:translateY(-6px); background:rgba(255,255,255,.04); }
.oc-bar {
  position:absolute; bottom:0; left:0; right:0; height:3px;
  transform:scaleX(0); transform-origin:left;
  transition:transform .45s var(--ease);
}
.oc:nth-child(1) .oc-bar { background:var(--rose); }
.oc:nth-child(2) .oc-bar { background:var(--gold); }
.oc:nth-child(3) .oc-bar { background:var(--sage); }
.oc:nth-child(4) .oc-bar { background:var(--rose); }
.oc:nth-child(5) .oc-bar { background:var(--gold); }
.oc:hover .oc-bar { transform:scaleX(1); }
.oc-icon { font-size:2.4rem; margin-bottom:1.3rem; }
.oc h3   { font-size:1.25rem; color:var(--white); margin-bottom:.6rem; }
.oc p    { font-size:.82rem; color:rgba(255,255,255,.42); line-height:1.7; }
.oc-tag  {
  display:inline-block; margin-top:1.1rem;
  font-size:.64rem; letter-spacing:.16em; text-transform:uppercase;
  color:var(--rose); border:1px solid rgba(236,145,146,.35);
  border-radius:20px; padding:.28rem .75rem;
}
.oc:nth-child(2) .oc-tag, .oc:nth-child(5) .oc-tag { color:var(--gold); border-color:rgba(249,220,119,.35); }
.oc:nth-child(3) .oc-tag { color:#7bb87a; border-color:rgba(85,134,84,.35); }

/* === PRICING === */
#pricing { background:#f9f8f5; }
.pricing-head { text-align:center; margin-bottom:4.5rem; }
.pricing-head h2 { font-size:clamp(2.2rem,4vw,3.4rem); margin-top:.6rem; }
.pricing-head p  { color:var(--i55); font-size:.92rem; max-width:480px; margin:.8rem auto 0; }
.pg { display:grid; grid-template-columns:1fr 1fr 1fr; gap:1.5rem; }
.pc {
  border:1px solid var(--i8); border-radius:6px; padding:3rem 2.4rem;
  position:relative; overflow:hidden;
  transition:all var(--t) var(--ease);
  background:var(--white);
}
.pc:not(.pf):hover { transform:translateY(-5px); box-shadow:0 16px 44px var(--i8); }
.pf { background:var(--ink); border-color:var(--ink); box-shadow:0 24px 64px rgba(7,2,13,.20); transform:translateY(-8px); }
.p-badge {
  position:absolute; top:1.4rem; right:1.4rem;
  background:var(--rose); color:var(--white);
  font-size:.62rem; letter-spacing:.15em; text-transform:uppercase;
  padding:.3rem .7rem; border-radius:2px;
}
.p-tier  { font-family:'DM Sans',sans-serif; font-weight:400; font-size:.68rem; letter-spacing:.22em; text-transform:uppercase; color:var(--rose); margin-bottom:1.2rem; }
.pf .p-tier  { color:var(--gold); }
.p-price { font-family:'Cormorant Garamond',serif; font-weight:300; font-size:3.2rem; color:var(--ink); line-height:1; }
.pf .p-price { color:var(--white); }
.p-price sup { font-size:1.2rem; vertical-align:.45em; }
.p-per  { font-family:'DM Sans',sans-serif; font-size:.76rem; font-weight:300; color:var(--i55); }
.pf .p-per  { color:rgba(255,255,255,.4); }
.p-min  { font-size:.78rem; color:var(--i35); margin-top:.3rem; }
.pf .p-min  { color:rgba(255,255,255,.3); }
.p-rule { height:1px; background:var(--i8); margin:1.8rem 0; }
.pf .p-rule { background:rgba(255,255,255,.1); }
.p-list { list-style:none; display:flex; flex-direction:column; gap:.9rem; margin-bottom:2.4rem; }
.p-list li { display:flex; align-items:flex-start; gap:.75rem; font-size:.86rem; color:var(--i55); line-height:1.6; }
.pf .p-list li { color:rgba(255,255,255,.6); }
.p-list li::before { content:'✦'; color:var(--gold); font-size:.58rem; margin-top:.28rem; flex-shrink:0; }

/* === TESTIMONIALS === */
#testimonials { background:var(--white); }
.test-head { text-align:center; margin-bottom:4.5rem; }
.test-head h2 { font-size:clamp(2.2rem,4vw,3.4rem); margin-top:.6rem; }
.tg { display:grid; grid-template-columns:repeat(3,1fr); gap:2rem; }
.tc { padding:2.6rem; border:1px solid var(--i8); border-radius:5px; transition:all var(--t) var(--ease); }
.tc:hover { box-shadow:0 12px 36px var(--i8); transform:translateY(-4px); }
.tq  { font-family:'Cormorant Garamond',serif; font-size:5.5rem; line-height:.8; color:var(--gold); opacity:.4; margin-bottom:.6rem; }
.tt  { font-family:'Cormorant Garamond',serif; font-style:italic; font-size:1.1rem; line-height:1.7; color:var(--ink); margin-bottom:1.8rem; }
.ta  { display:flex; align-items:center; gap:.9rem; }
.av  { width:42px; height:42px; border-radius:50%; flex-shrink:0; display:flex; align-items:center; justify-content:center; font-family:'Cormorant Garamond',serif; font-style:italic; font-size:1.1rem; color:var(--white); }
.av1 { background:linear-gradient(135deg,var(--rose),#c46464); }
.av2 { background:linear-gradient(135deg,var(--gold),#c9a830); }
.av3 { background:linear-gradient(135deg,var(--sage),#3d6b3c); }
.t-name  { font-family:'DM Sans',sans-serif; font-weight:400; font-size:.88rem; }
.t-occ   { font-size:.76rem; color:var(--i55); }
.t-stars { color:var(--gold); font-size:.68rem; margin-bottom:.4rem; }

/* === CONTACT === */
#contact { background:#f9f8f5; }
.cg { display:grid; grid-template-columns:1fr 1.5fr; gap:6rem; align-items:start; }
.cl h2   { font-size:clamp(2rem,3.5vw,3rem); margin-top:.6rem; line-height:1.15; }
.cl > p  { color:var(--i55); font-size:.9rem; margin-top:1rem; margin-bottom:2.5rem; line-height:1.8; }
.cdl     { display:flex; flex-direction:column; gap:1.4rem; }
.cd      { display:flex; gap:1rem; align-items:flex-start; }
.cd-icon { width:38px; height:38px; border-radius:50%; flex-shrink:0; display:flex; align-items:center; justify-content:center; font-size:.95rem; background:var(--r15); }
.cd-body h5 { font-family:'DM Sans',sans-serif; font-weight:500; font-size:.78rem; letter-spacing:.12em; text-transform:uppercase; margin-bottom:.2rem; }
.cd-body p  { font-size:.86rem; color:var(--i55); line-height:1.65; }

/* Contact form */
.cf  { display:flex; flex-direction:column; gap:1.1rem; }
.fr  { display:grid; grid-template-columns:1fr 1fr; gap:1.1rem; }
.fg  { display:flex; flex-direction:column; gap:.42rem; }
.fg label { font-size:.68rem; letter-spacing:.18em; text-transform:uppercase; color:var(--i55); }
.fg input, .fg select, .fg textarea {
  padding:.88rem 1rem;
  border:1px solid var(--i8); border-radius:3px;
  font-family:'DM Sans',sans-serif; font-weight:300;
  font-size:.9rem; color:var(--ink); background:var(--white);
  outline:none; appearance:none;
  transition:border-color var(--t) var(--ease);
  width:100%;
}
.fg input:focus, .fg select:focus, .fg textarea:focus { border-color:var(--rose); }
.fg textarea { resize:vertical; min-height:120px; }
.f-ok { display:none; padding:1.3rem; border-radius:4px; background:rgba(85,134,84,.1); border:1px solid rgba(85,134,84,.25); text-align:center; }
.f-ok.show { display:block; }
.f-ok p { color:var(--sage); font-size:.88rem; }

/* === FOOTER === */
.site-footer { background:var(--ink); padding:5.5rem 0 2.5rem; }
.fg2 { display:grid; grid-template-columns:2fr 1fr 1fr 1fr; gap:4rem; margin-bottom:4.5rem; }
.fb-logo { font-family:'Cormorant Garamond',serif; font-weight:300; font-size:1.7rem; color:var(--white); margin-bottom:1rem; display:block; }
.fb-logo em { font-style:italic; color:var(--gold); }
.fb p   { font-size:.84rem; color:rgba(255,255,255,.35); line-height:1.8; }
.fsoc   { display:flex; gap:.7rem; margin-top:1.5rem; }
.fsoc a {
  width:34px; height:34px; border-radius:50%;
  border:1px solid rgba(255,255,255,.12);
  display:flex; align-items:center; justify-content:center;
  color:rgba(255,255,255,.4); font-size:.8rem; font-style:italic;
  transition:all var(--t) var(--ease);
}
.fsoc a:hover { border-color:var(--rose); color:var(--rose); transform:translateY(-2px); }
.fcol h5 { font-family:'DM Sans',sans-serif; font-weight:400; font-size:.66rem; letter-spacing:.22em; text-transform:uppercase; color:rgba(255,255,255,.35); margin-bottom:1.3rem; }
.fcol ul { list-style:none; display:flex; flex-direction:column; gap:.7rem; }
.fcol ul a { font-size:.84rem; color:rgba(255,255,255,.35); transition:color var(--t) var(--ease); }
.fcol ul a:hover { color:var(--white); }
.fbot { border-top:1px solid rgba(255,255,255,.07); padding-top:2rem; display:flex; justify-content:space-between; align-items:center; flex-wrap:wrap; gap:.8rem; }
.fbot p { font-size:.76rem; color:rgba(255,255,255,.22); }
.fbl  { display:flex; gap:1.4rem; }
.fbl a { font-size:.76rem; color:rgba(255,255,255,.28); transition:color var(--t); }
.fbl a:hover { color:var(--white); }

/* === ACCOUNT MODAL === */
#mover {
  position:fixed; inset:0; z-index:1000;
  background:rgba(7,2,13,.65); backdrop-filter:blur(8px);
  display:flex; align-items:center; justify-content:center;
  opacity:0; pointer-events:none;
  transition:opacity var(--t) var(--ease);
}
#mover.open { opacity:1; pointer-events:all; }
.modal {
  background:var(--white); border-radius:7px; padding:3rem;
  width:100%; max-width:430px; position:relative;
  transform:translateY(18px);
  transition:transform var(--t) var(--ease);
}
#mover.open .modal { transform:none; }
.mx { position:absolute; top:1.2rem; right:1.4rem; background:none; border:none; cursor:pointer; font-size:1.6rem; color:var(--i35); line-height:1; transition:color var(--t); }
.mx:hover { color:var(--ink); }
.mtabs { display:flex; border-bottom:1px solid var(--i8); margin-bottom:2rem; }
.mtab { flex:1; padding:.85rem; background:none; border:none; cursor:pointer; font-family:'DM Sans',sans-serif; font-weight:400; font-size:.74rem; letter-spacing:.14em; text-transform:uppercase; color:var(--i55); border-bottom:2px solid transparent; margin-bottom:-1px; transition:all var(--t); }
.mtab.on { color:var(--rose); border-bottom-color:var(--rose); }
.mpanel { display:none; }
.mpanel.on { display:block; }
.mpanel h3 { font-family:'Cormorant Garamond',serif; font-weight:300; font-size:1.9rem; margin-bottom:.4rem; }
.mpanel > p { font-size:.86rem; color:var(--i55); margin-bottom:1.8rem; }
.mform { display:flex; flex-direction:column; gap:.95rem; }
.mi { padding:.88rem 1rem; border:1px solid var(--i8); border-radius:3px; font-family:'DM Sans',sans-serif; font-weight:300; font-size:.9rem; color:var(--ink); outline:none; width:100%; transition:border-color var(--t); }
.mi:focus { border-color:var(--rose); }
.mgrid { display:grid; grid-template-columns:1fr 1fr; gap:.9rem; }
.mfoot { text-align:center; margin-top:1rem; font-size:.8rem; color:var(--i55); }
.mfoot a { color:var(--rose); }

/* === SCROLL REVEAL === */
.r { opacity:0; transform:translateY(22px); transition:opacity .65s ease, transform .65s ease; }
.r.in { opacity:1; transform:none; }
.r.d1{transition-delay:.1s;} .r.d2{transition-delay:.2s;} .r.d3{transition-delay:.3s;} .r.d4{transition-delay:.4s;} .r.d5{transition-delay:.5s;}

/* === INNER PAGES === */
.page-hero {
  padding: 12rem 0 6rem;
  background: var(--ink);
  text-align: center;
  position: relative;
  overflow: hidden;
}
.page-hero h1 { font-size: clamp(2.5rem,5vw,4rem); color: var(--white); }
.page-hero p  { color: rgba(255,255,255,.5); margin-top: 1rem; }
.page-content { padding: 6rem 0; }
.page-content .wrap { max-width: 800px; }

/* === WP DEFAULTS === */
.wp-block-image img { border-radius: 4px; }
.aligncenter { text-align: center; margin: 0 auto; }
.screen-reader-text { position: absolute; left: -9999px; }

/* === WOOCOMMERCE BASICS === */
.woocommerce ul.products { display: grid; grid-template-columns: repeat(3,1fr); gap: 2rem; }
.woocommerce ul.products li.product a img { border-radius: 4px; transition: transform var(--t) var(--ease); }
.woocommerce ul.products li.product:hover a img { transform: scale(1.03); }
.woocommerce a.button, .woocommerce button.button { background: var(--rose) !important; color: var(--white) !important; border-radius: 2px !important; font-family: 'DM Sans', sans-serif !important; letter-spacing: .1em !important; text-transform: uppercase !important; font-size: .78rem !important; }
.woocommerce a.button:hover, .woocommerce button.button:hover { background: #e07e7f !important; }

/* === RESPONSIVE === */
@media(max-width:1024px) {
  .how-steps { grid-template-columns:1fr; }
  .how-arr   { display:none; }
  .occ-grid  { grid-template-columns:repeat(3,1fr); }
  .gg        { grid-template-rows:220px 180px; }
  .pg        { grid-template-columns:1fr 1fr; }
  .pf        { transform:none; }
  .cg        { grid-template-columns:1fr; gap:3rem; }
  .fg2       { grid-template-columns:1fr 1fr; gap:2.5rem; }
}
@media(max-width:720px) {
  #site-nav  { padding:1.2rem 1.4rem; }
  #site-nav.solid { padding:.9rem 1.4rem; }
  .nav-links, .nav-signin { display:none; }
  .nav-hamburger { display:flex; }
  .occ-grid  { grid-template-columns:1fr 1fr; }
  .gg        { grid-template-columns:1fr 1fr; grid-template-rows:auto; }
  .gi:nth-child(1) { grid-column:1/3; aspect-ratio:16/7; }
  .gi        { grid-column:auto; grid-row:auto; aspect-ratio:1; }
  .tg        { grid-template-columns:1fr; }
  .pg        { grid-template-columns:1fr; }
  .fr        { grid-template-columns:1fr; }
  .fg2       { grid-template-columns:1fr; gap:2rem; }
}
