:root{
  --bg: #fffafc;
  --surface: rgba(255,255,255,.72);
  --surface-strong: rgba(255,255,255,.88);
  --text: #2a1f22;
  --muted: rgba(42,31,34,.72);
  --muted-2: rgba(42,31,34,.58);

  --pink-50: #fff3f7;
  --pink-100: #fde4ed;
  --pink-200: #f7d0de;
  --cream: #fff4e7;
  --gold: #d6b46a;
  --gold-2: #b8964d;
  --brown: #6b4a3f;

  --radius-lg: 24px;
  --radius-md: 16px;
  --radius-sm: 12px;

  --shadow-sm: 0 10px 24px rgba(40, 20, 30, .08);
  --shadow-md: 0 18px 42px rgba(40, 20, 30, .12);
  --shadow-lg: 0 26px 80px rgba(40, 20, 30, .14);

  --border: rgba(214, 180, 106, .22);
  --ring: rgba(214, 180, 106, .26);

  --font-display: "Playfair Display", ui-serif, Georgia, serif;
  --font-sans: "Poppins", ui-sans-serif, system-ui, -apple-system, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;

  --container: 1120px;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:var(--font-sans);
  color:var(--text);
  background:
    radial-gradient(1200px 520px at 20% -10%, rgba(247, 208, 222, .65), transparent 65%),
    radial-gradient(900px 540px at 90% 20%, rgba(255, 244, 231, .75), transparent 62%),
    linear-gradient(180deg, var(--bg), #fff 42%, #fff 100%);
  overflow-x:hidden;
}

img{max-width:100%; display:block}
a{color:inherit; text-decoration:none}
button{font-family:inherit}

.container{
  width:min(100% - 40px, var(--container));
  margin-inline:auto;
}

.skip-link{
  position:absolute;
  left:-9999px;
  top:12px;
  padding:10px 14px;
  border-radius:999px;
  background:var(--surface-strong);
  border:1px solid var(--border);
  box-shadow:var(--shadow-sm);
  z-index:1000;
}
.skip-link:focus{left:16px}

/* Buttons */
.btn{
  --btn-bg: transparent;
  --btn-fg: var(--text);
  --btn-br: rgba(107, 74, 63, .18);
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:10px;
  padding:12px 16px;
  border-radius:999px;
  border:1px solid var(--btn-br);
  background:var(--btn-bg);
  color:var(--btn-fg);
  box-shadow:0 0 0 rgba(0,0,0,0);
  cursor:pointer;
  transition:transform .18s ease, box-shadow .18s ease, background .18s ease, border-color .18s ease, color .18s ease;
  user-select:none;
  white-space:nowrap;
}
.btn:hover{transform:translateY(-1px); box-shadow:var(--shadow-sm)}
.btn:active{transform:translateY(0px); box-shadow:none}
.btn:focus-visible{outline:0; box-shadow:0 0 0 4px var(--ring), var(--shadow-sm)}

.btn-primary{
  --btn-bg: linear-gradient(135deg, rgba(214,180,106,.95), rgba(184,150,77,.92));
  --btn-fg: #2a1f22;
  --btn-br: rgba(214,180,106,.55);
}
.btn-primary:hover{
  border-color: rgba(214,180,106,.75);
}
.btn-ghost{
  --btn-bg: rgba(255,255,255,.55);
  --btn-fg: var(--text);
  --btn-br: rgba(214,180,106,.28);
  backdrop-filter: blur(10px);
}
.btn-sm{padding:10px 14px; font-size:14px}
.btn-lg{padding:14px 18px}
.btn-ico{
  width:34px; height:34px;
  display:grid; place-items:center;
  border-radius:999px;
  background:rgba(255,255,255,.65);
  border:1px solid rgba(214,180,106,.28);
  font-weight:600;
  letter-spacing:.5px;
}

/* Navbar */
.site-header{position:sticky; top:0; z-index:50}
.navbar{
  position:relative;
  background:rgba(255,250,252,.62);
  backdrop-filter: blur(16px);
  border-bottom:1px solid rgba(214, 180, 106, .18);
}
.navbar.is-scrolled{
  background:rgba(255,255,255,.72);
  box-shadow:0 14px 36px rgba(40, 20, 30, .10);
  border-bottom-color: rgba(214, 180, 106, .24);
}

.nav-inner{
  display:flex;
  align-items:center;
  justify-content:space-between;
  padding:12px 0;
  gap:14px;
}

.brand{
  display:flex;
  align-items:center;
  gap:12px;
  min-width: 180px;
}
.brand-logo{
  width:48px;
  height:48px;
  border-radius:14px;
  background:#fff;
  border:1px solid rgba(214, 180, 106, .22);
  box-shadow: 0 10px 22px rgba(40, 20, 30, .10);
  object-fit:cover;
}
.brand-name{
  font-family:var(--font-display);
  font-weight:700;
  letter-spacing:.2px;
  font-size:20px;
}

.nav-toggle{
  display:none;
  width:44px;
  height:44px;
  border-radius:14px;
  border:1px solid rgba(214, 180, 106, .22);
  background:rgba(255,255,255,.62);
  box-shadow:var(--shadow-sm);
  cursor:pointer;
  transition:transform .18s ease, box-shadow .18s ease;
}
.nav-toggle:hover{transform:translateY(-1px)}
.nav-toggle:focus-visible{outline:0; box-shadow:0 0 0 4px var(--ring), var(--shadow-sm)}
.nav-toggle-line{
  display:block;
  width:18px;
  height:2px;
  background:rgba(42,31,34,.78);
  margin:0 auto;
  border-radius:2px;
}
.nav-toggle-line + .nav-toggle-line{margin-top:5px}

.nav-menu{
  display:flex;
  align-items:center;
  justify-content:flex-end;
  gap:18px;
  flex: 1;
}
.nav-links{
  list-style:none;
  display:flex;
  align-items:center;
  gap:18px;
  padding:0;
  margin:0;
}
.nav-links a{
  font-size:14px;
  color:rgba(42,31,34,.86);
  padding:10px 12px;
  border-radius:999px;
  transition:background .18s ease, color .18s ease, transform .18s ease;
}
.nav-links a:hover{
  background:rgba(247, 208, 222, .30);
  color:rgba(42,31,34,.96);
  transform:translateY(-1px);
}

/* Sections */
.section{
  padding:76px 0;
  position:relative;
}
.section-head{max-width:740px}
.section-head.center{margin:0 auto; text-align:center}
.section-eyebrow{
  display:inline-flex;
  align-items:center;
  gap:10px;
  font-weight:600;
  color:rgba(107, 74, 63, .84);
  letter-spacing:.6px;
  text-transform:uppercase;
  font-size:12px;
  background:rgba(255,255,255,.62);
  border:1px solid rgba(214, 180, 106, .20);
  padding:8px 12px;
  border-radius:999px;
  backdrop-filter: blur(10px);
}
.section-title{
  font-family:var(--font-display);
  font-weight:700;
  font-size:clamp(28px, 4vw, 42px);
  line-height:1.12;
  margin:16px 0 10px;
  letter-spacing:-.2px;
}
.section-desc{
  margin:0;
  color:var(--muted);
  font-size:16px;
  line-height:1.8;
}

/* Hero */
.hero{
  padding:76px 0 30px;
  position:relative;
  z-index:0;
}
.hero-bg{
  position:absolute;
  inset:0;
  pointer-events:none;
  z-index:-1;
}
.hero-bg::before,
.hero-bg::after{
  content:"";
  position:absolute;
  width:780px;
  height:780px;
  border-radius: 48% 52% 47% 53% / 55% 46% 54% 45%;
  filter: blur(1px);
  opacity:.85;
}
.hero-bg::before{
  left:-260px;
  top:-260px;
  background:
    radial-gradient(circle at 30% 30%, rgba(247, 208, 222, .95), transparent 62%),
    radial-gradient(circle at 70% 60%, rgba(255, 244, 231, .78), transparent 62%),
    radial-gradient(circle at 35% 70%, rgba(214, 180, 106, .35), transparent 58%);
}
.hero-bg::after{
  right:-290px;
  top:-210px;
  background:
    radial-gradient(circle at 55% 35%, rgba(255, 244, 231, .88), transparent 62%),
    radial-gradient(circle at 35% 70%, rgba(247, 208, 222, .75), transparent 60%),
    radial-gradient(circle at 65% 60%, rgba(214, 180, 106, .28), transparent 58%);
  transform: rotate(12deg);
}

.hero-inner{
  display:grid;
  grid-template-columns:2fr 3fr;
  gap:32px;
  align-items:center;
}
.hero-content{
  min-width:0;
}
.badge{
  display:inline-flex;
  align-items:center;
  gap:10px;
  background:rgba(255,255,255,.62);
  border:1px solid rgba(214, 180, 106, .20);
  border-radius:999px;
  padding:10px 14px;
  backdrop-filter: blur(10px);
  box-shadow:var(--shadow-sm);
  margin:0 0 14px;
  color:rgba(42,31,34,.82);
  font-weight:500;
}
.badge .dot{
  width:8px; height:8px;
  border-radius:999px;
  background:linear-gradient(135deg, rgba(214,180,106,.95), rgba(184,150,77,.88));
  box-shadow:0 0 0 4px rgba(214, 180, 106, .18);
}
.hero-title{
  font-family:var(--font-display);
  font-weight:700;
  font-size:clamp(34px, 4.4vw, 56px);
  line-height:1.04;
  margin:0 0 14px;
  letter-spacing:-.35px;
}
.hero-subtitle{
  margin:0;
  color:var(--muted);
  font-size:16.5px;
  line-height:1.9;
  max-width:480px;
}
.hero-actions{
  display:flex;
  gap:12px;
  margin-top:22px;
  flex-wrap:wrap;
}
.hero-trust{
  display:flex;
  align-items:center;
  gap:18px;
  margin-top:26px;
  flex-wrap:wrap;
}
.trust-item{
  padding:12px 14px;
  border-radius:16px;
  background:rgba(255,255,255,.52);
  border:1px solid rgba(214, 180, 106, .18);
  backdrop-filter: blur(10px);
}
.trust-kpi{
  display:block;
  font-weight:700;
  letter-spacing:.2px;
  color:rgba(42,31,34,.92);
}
.trust-label{
  display:block;
  font-size:12.5px;
  color:var(--muted-2);
  margin-top:2px;
}

.hero-visual{
  position:relative;
  z-index:1;
  min-height:460px;
}
.hero-card{
  width:100%;
  border-radius: var(--radius-lg);
  background: rgba(255,255,255,.62);
  border:1px solid rgba(214, 180, 106, .22);
  box-shadow: var(--shadow-lg);
  backdrop-filter: blur(18px);
  overflow:hidden;
}

/* Hero banner image framing (dynamic CMS banners) */
.hero-card-inner{
  padding:10px 12px 14px;
  position:relative;
  box-sizing:border-box;
}
.hero-banner-deco{
  position:absolute;
  inset:0;
  z-index:5;
  pointer-events:none;
}
.hero-float-circle{
  position:absolute;
  display:block;
  border-radius:46% 54% 55% 45% / 48% 46% 54% 52%;
  pointer-events:none;
  border:1px solid rgba(214, 180, 106, .16);
  background:
    radial-gradient(circle at 35% 35%, rgba(247, 208, 222, .68), transparent 62%),
    radial-gradient(circle at 70% 60%, rgba(255, 244, 231, .85), transparent 62%),
    radial-gradient(circle at 50% 50%, rgba(214, 180, 106, .24), transparent 70%),
    rgba(255,255,255,.4);
  backdrop-filter:blur(10px);
  opacity:.45;
  filter:blur(3px);
  box-shadow:0 12px 28px rgba(40, 20, 30, .06);
}
.hero-banner-deco .hero-float-circle--tl{
  width:76px;
  height:76px;
  left:10px;
  top:10px;
  opacity:.48;
  animation:floaty 9s ease-in-out infinite;
}
.hero-visual > .hero-float-circle--bl{
  width:132px;
  height:132px;
  left:-22px;
  bottom:12px;
  z-index:6;
  opacity:.46;
}
.hero-visual > .hero-float-circle--tr{
  width:92px;
  height:92px;
  right:-12px;
  top:8px;
  z-index:6;
  opacity:.42;
  animation-duration:10.5s;
}
.hero-card-inner .hero-slide-track,
.hero-card-inner > .hero-slide-visual,
.hero-card-inner > .hero-cake,
.hero-card-inner picture{
  position:relative;
  z-index:1;
}
.hero-card-inner > .hero-cake::before,
.hero-card-inner > .hero-cake::after,
.hero-card-inner .hero-slide-visual.hero-cake::before,
.hero-card-inner .hero-slide-visual.hero-cake::after{
  display:none;
}
.hero-card-inner .hero-slide-visual{
  display:none;
  width:100%;
}
.hero-card-inner .hero-slide-visual.is-active{
  display:block;
}
#beranda[data-hero-slider="1"] .hero-slide-track{
  position:relative;
  width:100%;
  min-height:320px;
}
#beranda[data-hero-slider="1"] .hero-slide-track > .hero-slide-visual{
  display:none;
  position:absolute;
  inset:0;
  width:100%;
  z-index:1;
}
#beranda[data-hero-slider="1"] .hero-slide-track > .hero-slide-visual.is-active{
  display:block;
  z-index:2;
}
.hero-card-inner picture{
  display:flex;
  align-items:center;
  justify-content:center;
  width:100%;
  min-height:320px;
  margin:0;
}
.hero-card-inner img.hero-cake{
  display:block;
  width:100%;
  height:auto;
  max-height:400px;
  min-height:0;
  margin:0;
  padding:4px;
  object-fit:contain;
  object-position:center center;
  border-radius:18px;
  border:1px solid rgba(214, 180, 106, .20);
  box-shadow:0 14px 32px rgba(40, 20, 30, .10);
  background:linear-gradient(180deg, rgba(255, 255, 255, .94), rgba(255, 248, 252, .82));
}
.hero-card-inner > .hero-cake,
.hero-card-inner .hero-slide-visual.hero-cake{
  height:260px;
  width:100%;
  margin:0;
  max-height:none;
  padding:0;
  object-fit:unset;
  border-radius:22px;
}
#beranda[data-hero-slider="1"] .hero-slider-controls{
  display:flex;
  align-items:center;
  gap:10px;
  margin-top:14px;
}
#beranda[data-hero-slider="1"] .hero-slider-btn{
  border:1px solid rgba(214, 180, 106, .55);
  background:#fff;
  color:var(--text, #3b2f2a);
  border-radius:999px;
  width:36px;
  height:36px;
  cursor:pointer;
  font-size:18px;
  line-height:1;
}
#beranda[data-hero-slider="1"] .hero-slider-dots{
  display:flex;
  gap:8px;
  align-items:center;
}
#beranda[data-hero-slider="1"] .hero-slider-dot{
  width:9px;
  height:9px;
  border-radius:50%;
  border:0;
  padding:0;
  background:rgba(214, 180, 106, .45);
  cursor:pointer;
}
#beranda[data-hero-slider="1"] .hero-slider-dot.is-active{
  background:rgba(214, 180, 106, 1);
}
.hero-visual .hero-card{
  position:relative;
  z-index:1;
}

.hero-card-top{
  padding:16px 18px 8px;
  display:flex;
  justify-content:flex-end;
}
.mini-pill{
  font-size:12px;
  color:rgba(42,31,34,.72);
  background:rgba(247, 208, 222, .28);
  border:1px solid rgba(214, 180, 106, .22);
  padding:8px 12px;
  border-radius:999px;
}
.hero-cake{
  height:260px;
  position:relative;
  margin: 8px 18px 12px;
  border-radius: 22px;
  border:1px solid rgba(214, 180, 106, .18);
  background:
    radial-gradient(circle at 20% 30%, rgba(255,255,255,.9), rgba(255,255,255,.35) 55%, transparent 65%),
    radial-gradient(circle at 80% 20%, rgba(247, 208, 222, .62), transparent 60%),
    radial-gradient(circle at 40% 80%, rgba(255, 244, 231, .85), transparent 60%),
    linear-gradient(135deg, rgba(255, 255, 255, .6), rgba(247, 208, 222, .22)),
    repeating-linear-gradient(45deg, rgba(214, 180, 106, .10), rgba(214, 180, 106, .10) 8px, rgba(255, 255, 255, .05) 8px, rgba(255, 255, 255, .05) 16px);
  box-shadow: 0 18px 40px rgba(40, 20, 30, .10);
}
.hero-cake::before,
.hero-cake::after{
  content:"";
  position:absolute;
  inset:auto;
  border-radius:999px;
  opacity:.9;
}
.hero-cake::before{
  width:88px; height:88px;
  left:18px; top:18px;
  background:
    radial-gradient(circle at 30% 30%, rgba(255, 244, 231, .95), rgba(247, 208, 222, .65) 60%, rgba(214, 180, 106, .28) 100%);
  filter: blur(.2px);
}
.hero-cake::after{
  width:120px; height:120px;
  right:16px; bottom:16px;
  background:
    radial-gradient(circle at 30% 30%, rgba(247, 208, 222, .78), transparent 60%),
    radial-gradient(circle at 60% 60%, rgba(214, 180, 106, .32), transparent 62%),
    radial-gradient(circle at 45% 45%, rgba(255, 255, 255, .65), transparent 62%);
}
.hero-card-bottom{
  padding:14px 18px 18px;
  display:grid;
  gap:10px;
}
.mini-row{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:14px;
  padding:12px 14px;
  border-radius:16px;
  background:rgba(255,255,255,.55);
  border:1px solid rgba(214, 180, 106, .16);
}
.mini-label{font-size:12.5px; color:var(--muted-2)}
.mini-value{font-weight:600; color:rgba(42,31,34,.92)}

.floating{
  position:absolute;
  border-radius: 46% 54% 55% 45% / 48% 46% 54% 52%;
  border:1px solid rgba(214, 180, 106, .18);
  box-shadow: var(--shadow-md);
  background:
    radial-gradient(circle at 35% 35%, rgba(247, 208, 222, .62), transparent 62%),
    radial-gradient(circle at 70% 60%, rgba(255, 244, 231, .82), transparent 62%),
    radial-gradient(circle at 50% 50%, rgba(214, 180, 106, .22), transparent 70%),
    rgba(255,255,255,.38);
  backdrop-filter: blur(12px);
  animation: floaty 8.5s ease-in-out infinite;
}
.floating-a{width:140px; height:140px; left:-24px; bottom:20px}
.floating-b{width:110px; height:110px; right:14px; top:28px; animation-duration: 10.5s}
@keyframes floaty{
  0%,100%{transform: translateY(0) rotate(0deg)}
  50%{transform: translateY(-10px) rotate(1.8deg)}
}

/* Layout split */
.split{
  display:grid;
  grid-template-columns: .95fr 1.05fr;
  gap:36px;
  align-items:center;
}
.media-frame{
  position:relative;
  border-radius: var(--radius-lg);
  border:1px solid rgba(214, 180, 106, .22);
  background: rgba(255,255,255,.58);
  box-shadow: var(--shadow-lg);
  backdrop-filter: blur(14px);
  overflow:hidden;
  padding:14px;
}
.media-img{
  height:420px;
  border-radius: 22px;
  border:1px solid rgba(214, 180, 106, .16);
  background:
    radial-gradient(circle at 20% 15%, rgba(247, 208, 222, .75), transparent 55%),
    radial-gradient(circle at 70% 25%, rgba(255, 244, 231, .88), transparent 58%),
    radial-gradient(circle at 35% 75%, rgba(214, 180, 106, .26), transparent 60%),
    linear-gradient(135deg, rgba(255,255,255,.64), rgba(247, 208, 222, .18));
}
.media-stamp{
  position:absolute;
  left:26px;
  bottom:26px;
  padding:14px 16px;
  border-radius: 18px;
  background: rgba(255,255,255,.70);
  border:1px solid rgba(214, 180, 106, .22);
  backdrop-filter: blur(12px);
  box-shadow: var(--shadow-md);
}
.stamp-title{
  display:block;
  font-family: var(--font-display);
  font-weight: 700;
}
.stamp-sub{
  display:block;
  font-size: 12.5px;
  color: var(--muted-2);
  margin-top:3px;
}

.about .section-head .section-title{
  font-size:clamp(30px, 4.3vw, 46px);
}
.about .section-head .section-eyebrow{
  font-size:13px;
  letter-spacing:.85px;
  padding:10px 14px;
}
.about .split{
  gap:40px;
}
.about .media-frame{
  padding:18px 20px 20px;
}
.about .media-frame-inner{
  padding:0;
  box-sizing:border-box;
}
.about .media-img{
  width:100%;
  max-width:none;
  margin:0;
}
.about img.media-img{
  display:block;
  object-fit:cover;
  object-position:center center;
}
.about-points{margin-top:18px; display:grid; gap:14px}
.point{
  display:flex;
  gap:14px;
  align-items:flex-start;
  padding:14px 14px;
  border-radius: 20px;
  background: rgba(255,255,255,.55);
  border:1px solid rgba(214, 180, 106, .16);
  backdrop-filter: blur(10px);
}
.point-ico{
  width:34px; height:34px;
  display:grid; place-items:center;
  border-radius: 14px;
  background: rgba(247, 208, 222, .30);
  border:1px solid rgba(214, 180, 106, .18);
  color: rgba(107, 74, 63, .92);
  flex:none;
}
.point-title{margin:0; font-weight:600}
.point-desc{margin:4px 0 0; color:var(--muted); line-height:1.7; font-size:14.5px}
.about-actions{margin-top:20px; display:flex; gap:12px; flex-wrap:wrap}

/* Cards & grids */
.grid{display:grid; gap:18px}
.products-grid{grid-template-columns: repeat(3, minmax(0, 1fr)); margin-top:28px}
.card{
  border-radius: var(--radius-lg);
  background: rgba(255,255,255,.62);
  border:1px solid rgba(214, 180, 106, .20);
  box-shadow: var(--shadow-md);
  backdrop-filter: blur(14px);
  overflow:hidden;
  transition: transform .18s ease, box-shadow .18s ease, border-color .18s ease;
}
.card:hover{transform: translateY(-2px); box-shadow: var(--shadow-lg); border-color: rgba(214, 180, 106, .34)}
.card-media{
  width:100%;
  aspect-ratio: 1 / 1;
  object-fit: cover;
  object-position: center;
  display:block;
  border-bottom:1px solid rgba(214, 180, 106, .16);
  background:
    radial-gradient(circle at 22% 20%, rgba(255, 244, 231, .92), transparent 58%),
    radial-gradient(circle at 78% 30%, rgba(247, 208, 222, .68), transparent 60%),
    radial-gradient(circle at 40% 85%, rgba(214, 180, 106, .26), transparent 62%),
    linear-gradient(135deg, rgba(255,255,255,.65), rgba(247,208,222,.18));
}
.card-body{padding:16px 16px 18px}
.card-title{
  font-family: var(--font-display);
  margin:0 0 6px;
  font-size:18px;
  letter-spacing:-.15px;
}
.card-text{
  margin:0 0 14px;
  color:var(--muted);
  line-height:1.75;
  font-size:14.5px;
}

.media-birthday{background-image:
  radial-gradient(circle at 25% 25%, rgba(247, 208, 222, .82), transparent 55%),
  radial-gradient(circle at 70% 40%, rgba(255, 244, 231, .92), transparent 58%),
  linear-gradient(135deg, rgba(255,255,255,.68), rgba(214, 180, 106, .16));
}
.media-bento{background-image:
  radial-gradient(circle at 30% 30%, rgba(255, 244, 231, .92), transparent 58%),
  radial-gradient(circle at 70% 30%, rgba(247, 208, 222, .76), transparent 60%),
  linear-gradient(135deg, rgba(255,255,255,.62), rgba(247, 208, 222, .16));
}
.media-dessert{background-image:
  radial-gradient(circle at 30% 40%, rgba(214, 180, 106, .22), transparent 60%),
  radial-gradient(circle at 70% 25%, rgba(255, 244, 231, .92), transparent 60%),
  linear-gradient(135deg, rgba(255,255,255,.64), rgba(247, 208, 222, .18));
}
.media-cupcake{background-image:
  radial-gradient(circle at 35% 30%, rgba(247, 208, 222, .78), transparent 58%),
  radial-gradient(circle at 75% 30%, rgba(214, 180, 106, .18), transparent 62%),
  linear-gradient(135deg, rgba(255,255,255,.66), rgba(255, 244, 231, .22));
}
.media-korean{background-image:
  radial-gradient(circle at 25% 30%, rgba(255, 255, 255, .86), transparent 58%),
  radial-gradient(circle at 70% 35%, rgba(247, 208, 222, .70), transparent 60%),
  linear-gradient(135deg, rgba(255,255,255,.62), rgba(214, 180, 106, .12));
}
.media-cookies{background-image:
  radial-gradient(circle at 25% 35%, rgba(255, 244, 231, .92), transparent 58%),
  radial-gradient(circle at 75% 35%, rgba(214, 180, 106, .24), transparent 62%),
  linear-gradient(135deg, rgba(255,255,255,.62), rgba(247, 208, 222, .14));
}

/* Reasons */
.reasons{
  background:
    radial-gradient(1100px 580px at 30% 10%, rgba(247, 208, 222, .50), transparent 70%),
    radial-gradient(900px 580px at 80% 30%, rgba(255, 244, 231, .72), transparent 70%);
}
.reasons-grid{
  grid-template-columns: repeat(3, minmax(0, 1fr));
  margin-top:28px;
  gap:16px;
}
.reason{
  border-radius: var(--radius-lg);
  background: rgba(255,255,255,.58);
  border:1px solid rgba(214, 180, 106, .18);
  box-shadow: var(--shadow-md);
  backdrop-filter: blur(12px);
  padding:18px 16px;
  transition: transform .18s ease, box-shadow .18s ease, border-color .18s ease;
}
.reason:hover{transform: translateY(-2px); box-shadow: var(--shadow-lg); border-color: rgba(214, 180, 106, .32)}
.reason-ico{
  width:46px; height:46px;
  border-radius: 18px;
  display:grid; place-items:center;
  background: rgba(247, 208, 222, .28);
  border:1px solid rgba(214, 180, 106, .18);
  color: rgba(107, 74, 63, .90);
  margin-bottom:12px;
}
.reason-ico svg{width:24px; height:24px}
.reason-title{margin:0; font-weight:700; letter-spacing:.1px}
.reason-desc{margin:6px 0 0; color:var(--muted); line-height:1.75; font-size:14.5px}

/* Gallery */
.gallery-grid{
  margin-top:28px;
  display:grid;
  grid-template-columns: repeat(12, 1fr);
  gap:14px;
}
.gallery-item{
  min-height: 148px;
  border-radius: 22px;
  border:1px solid rgba(214, 180, 106, .18);
  box-shadow: var(--shadow-md);
  background:
    radial-gradient(circle at 30% 30%, rgba(255, 244, 231, .90), transparent 58%),
    radial-gradient(circle at 70% 35%, rgba(247, 208, 222, .70), transparent 62%),
    radial-gradient(circle at 45% 85%, rgba(214, 180, 106, .22), transparent 62%),
    linear-gradient(135deg, rgba(255,255,255,.62), rgba(247, 208, 222, .18));
  overflow:hidden;
  position:relative;
  transition: transform .18s ease, box-shadow .18s ease, border-color .18s ease;
}
.gallery-item::after{
  content:"";
  position:absolute;
  inset:0;
  background:
    radial-gradient(260px 160px at 20% 15%, rgba(255,255,255,.50), transparent 62%),
    radial-gradient(260px 160px at 80% 85%, rgba(214, 180, 106, .14), transparent 62%);
  opacity:.85;
  pointer-events:none;
}
.gallery-item:hover{transform: translateY(-2px); box-shadow: var(--shadow-lg); border-color: rgba(214, 180, 106, .34)}

.g1{grid-column: span 4; min-height: 220px}
.g2{grid-column: span 3}
.g3{grid-column: span 5; min-height: 220px}
.g4{grid-column: span 3}
.g5{grid-column: span 3; min-height: 220px}
.g6{grid-column: span 6}
.g7{grid-column: span 4}
.g8{grid-column: span 4; min-height: 220px}
.g9{grid-column: span 4}

/* Testimonials */
.testimonials-grid{
  grid-template-columns: repeat(3, minmax(0, 1fr));
  margin-top:28px;
}
.testimonial{padding:18px 16px}
.testimonial-top{
  display:flex;
  align-items:center;
  gap:12px;
}
.avatar{
  width:52px; height:52px;
  border-radius:999px;
  border:1px solid rgba(214, 180, 106, .22);
  box-shadow: 0 10px 18px rgba(40, 20, 30, .10);
  background:
    radial-gradient(circle at 30% 30%, rgba(247, 208, 222, .78), transparent 62%),
    radial-gradient(circle at 70% 60%, rgba(255, 244, 231, .88), transparent 62%),
    rgba(255,255,255,.62);
}
.a2{background:
  radial-gradient(circle at 40% 35%, rgba(255, 244, 231, .90), transparent 62%),
  radial-gradient(circle at 70% 60%, rgba(214, 180, 106, .22), transparent 62%),
  rgba(255,255,255,.62);
}
.a3{background:
  radial-gradient(circle at 30% 35%, rgba(247, 208, 222, .70), transparent 62%),
  radial-gradient(circle at 65% 55%, rgba(214, 180, 106, .24), transparent 62%),
  rgba(255,255,255,.62);
}
.testimonial-name{margin:0; font-weight:700}
.testimonial-meta{margin:2px 0 0; color:var(--muted-2); font-size:12.5px}
.testimonial-text{
  margin:14px 0 0;
  color:var(--muted);
  line-height:1.85;
}

/* Contact */
.contact{padding-bottom:88px}
.contact-card{
  display:grid;
  grid-template-columns: 1.1fr .9fr;
  gap:18px;
  border-radius: 30px;
  padding:18px;
  background:
    radial-gradient(820px 420px at 20% 20%, rgba(247, 208, 222, .45), transparent 65%),
    radial-gradient(760px 420px at 80% 20%, rgba(255, 244, 231, .78), transparent 70%),
    rgba(255,255,255,.62);
  border:1px solid rgba(214, 180, 106, .22);
  box-shadow: var(--shadow-lg);
  backdrop-filter: blur(18px);
  overflow:hidden;
  position:relative;
}
.contact-content{padding:16px 16px}
.contact-actions{margin-top:18px; display:flex; gap:12px; flex-wrap:wrap}
.contact-info{
  margin-top:18px;
  display:grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap:12px;
}
.info-item{
  border-radius: 20px;
  background: rgba(255,255,255,.58);
  border:1px solid rgba(214, 180, 106, .16);
  padding:12px 12px;
  backdrop-filter: blur(10px);
}
.info-label{margin:0; font-size:12px; letter-spacing:.6px; text-transform:uppercase; color:rgba(107, 74, 63, .78); font-weight:600}
.info-value{margin:6px 0 0; color:var(--muted); line-height:1.7; font-size:14px}

.contact-visual{
  position:relative;
  border-radius: 26px;
  border:1px solid rgba(214, 180, 106, .16);
  background: rgba(255,255,255,.46);
  overflow:hidden;
}
.contact-badge{
  position:absolute;
  top:16px; left:16px;
  z-index:2;
  border-radius: 18px;
  background: rgba(255,255,255,.70);
  border:1px solid rgba(214, 180, 106, .22);
  backdrop-filter: blur(12px);
  padding:12px 14px;
  box-shadow: var(--shadow-md);
}
.cb-title{
  display:block;
  font-weight:700;
  font-family: var(--font-display);
}
.cb-sub{display:block; font-size:12.5px; color:var(--muted-2); margin-top:3px}
.contact-blob{
  position:absolute;
  inset:-80px -90px auto auto;
  width:380px; height:380px;
  border-radius: 44% 56% 54% 46% / 52% 48% 52% 48%;
  background:
    radial-gradient(circle at 30% 30%, rgba(247, 208, 222, .70), transparent 62%),
    radial-gradient(circle at 70% 60%, rgba(255, 244, 231, .88), transparent 62%),
    radial-gradient(circle at 45% 55%, rgba(214, 180, 106, .22), transparent 70%);
  filter: blur(.2px);
  opacity:.95;
  transform: rotate(8deg);
}
.contact-cards{
  position:absolute;
  left:16px;
  right:16px;
  bottom:16px;
  display:grid;
  grid-template-columns: 1fr 1fr;
  gap:12px;
  z-index:2;
}
.mini-card{
  border-radius: 20px;
  background: rgba(255,255,255,.70);
  border:1px solid rgba(214, 180, 106, .18);
  padding:12px 12px;
  backdrop-filter: blur(12px);
  box-shadow: var(--shadow-md);
}
.mini-card-title{margin:0; font-weight:700}
.mini-card-desc{margin:6px 0 0; color:var(--muted); font-size:14px; line-height:1.7}

/* Footer */
.footer{
  padding:44px 0 26px;
  border-top:1px solid rgba(214, 180, 106, .18);
  background:
    radial-gradient(1000px 480px at 10% -20%, rgba(247, 208, 222, .40), transparent 70%),
    radial-gradient(900px 500px at 90% 10%, rgba(255, 244, 231, .70), transparent 70%),
    rgba(255,255,255,.50);
  backdrop-filter: blur(16px);
}
.footer-inner{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:24px;
}
.brand-footer .brand-logo{width:44px; height:44px}
.footer-tagline{margin:10px 0 0; color:var(--muted); line-height:1.8; max-width: 420px}
.footer-cols{
  display:grid;
  grid-template-columns: 1fr 1fr;
  gap:22px;
}
.footer-title{margin:0 0 10px; font-weight:700}
.footer-links{list-style:none; padding:0; margin:0; display:grid; gap:8px}
.footer-links a{
  color:rgba(42,31,34,.78);
  padding:8px 10px;
  border-radius: 12px;
  transition: background .18s ease, transform .18s ease, color .18s ease;
}
.footer-links a:hover{
  background: rgba(247, 208, 222, .28);
  color: rgba(42,31,34,.92);
  transform: translateY(-1px);
}
.footer-bottom{
  margin-top:22px;
  padding-top:18px;
  border-top:1px solid rgba(214, 180, 106, .16);
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  color:rgba(42,31,34,.68);
  font-size:14px;
}
.to-top{
  padding:10px 12px;
  border-radius: 999px;
  background: rgba(255,255,255,.52);
  border:1px solid rgba(214, 180, 106, .18);
  transition: transform .18s ease, box-shadow .18s ease, background .18s ease;
}
.to-top:hover{transform: translateY(-1px); box-shadow: var(--shadow-sm)}

/* Modal */
.modal::backdrop{background: rgba(22, 12, 16, .45)}
.modal{
  border:0;
  padding:0;
  background: transparent;
}
.modal-card{
  width:min(520px, calc(100vw - 30px));
  border-radius: 26px;
  background: rgba(255,255,255,.78);
  border:1px solid rgba(214, 180, 106, .22);
  box-shadow: var(--shadow-lg);
  backdrop-filter: blur(18px);
  overflow:hidden;
  position:relative;
}
.modal-close{
  position:absolute;
  top:12px; right:12px;
  width:42px; height:42px;
  border-radius: 16px;
  border:1px solid rgba(214, 180, 106, .20);
  background: rgba(255,255,255,.64);
  cursor:pointer;
  transition: transform .18s ease, box-shadow .18s ease;
}
.modal-close:hover{transform: translateY(-1px); box-shadow: var(--shadow-sm)}
.modal-close:focus-visible{outline:0; box-shadow:0 0 0 4px var(--ring), var(--shadow-sm)}
.modal-body{padding:22px 18px 18px}
.modal-eyebrow{
  margin:0;
  font-size:12px;
  letter-spacing:.6px;
  text-transform:uppercase;
  color:rgba(107, 74, 63, .80);
  font-weight:600;
}
.modal-title{
  margin:10px 0 10px;
  font-family: var(--font-display);
  font-weight:700;
  font-size:26px;
}
.modal-text{margin:0; color:var(--muted); line-height:1.85}
.modal-actions{margin-top:16px; display:flex; gap:10px; flex-wrap:wrap}

/* Reveal animation — visible by default; hidden only once JS marks html.js-ready */
.reveal{
  transition: opacity .55s ease, transform .55s ease;
}
.js-ready .reveal{
  opacity:0;
  transform: translateY(12px);
}
.js-ready .reveal.is-visible{
  opacity:1;
  transform: translateY(0);
}

/* Responsive */
@media (max-width: 1100px){
  .nav-links{gap:10px}
  .nav-links a{padding:10px 9px}
}
@media (max-width: 760px){
  body.nav-menu-open{overflow:hidden}
  .site-header{z-index:100}
  .site-header.is-menu-open::before{
    content:"";
    position:fixed;
    inset:0;
    background:rgba(42, 31, 34, .30);
    z-index:101;
    pointer-events:none;
  }
  .navbar{position:relative; z-index:103}
  .navbar.is-menu-open,
  .navbar.is-scrolled.is-menu-open{
    background:#fff7fa;
    border-bottom-color:rgba(214, 180, 106, .28);
    box-shadow:0 10px 28px rgba(40, 20, 30, .08);
  }
  .nav-inner{
    flex-wrap:nowrap;
    align-items:center;
    padding:10px 0;
    gap:10px 12px;
  }
  .brand{min-width:0; gap:8px; flex:1}
  .brand-logo{width:38px; height:38px; border-radius:12px}
  .brand-name{font-size:17px}
  .nav-toggle{
    display:inline-flex;
    flex-direction:column;
    align-items:center;
    justify-content:center;
    gap:5px;
    width:40px;
    height:40px;
    padding:0;
    border-radius:12px;
    flex-shrink:0;
    position:relative;
    z-index:104;
  }
  .nav-toggle-line{
    width:18px;
    height:2px;
    margin:0;
    transition:transform .22s ease, opacity .22s ease;
  }
  .nav-toggle-line + .nav-toggle-line{margin-top:0}
  .nav-toggle[aria-expanded="true"] .nav-toggle-line:nth-child(1){
    transform:translateY(7px) rotate(45deg);
  }
  .nav-toggle[aria-expanded="true"] .nav-toggle-line:nth-child(2){
    opacity:0;
  }
  .nav-toggle[aria-expanded="true"] .nav-toggle-line:nth-child(3){
    transform:translateY(-7px) rotate(-45deg);
  }
  .nav-menu{
    position:fixed;
    top:88px;
    left:16px;
    right:16px;
    z-index:9999;
    display:none;
    flex:none;
    width:auto;
    margin:0;
    padding:16px 18px 20px;
    flex-direction:column;
    align-items:stretch;
    justify-content:flex-start;
    gap:0;
    background:#fff7fa;
    border:1px solid rgba(214, 180, 106, .24);
    border-radius:20px;
    box-shadow:0 18px 40px rgba(40, 20, 30, .14);
    max-height:calc(100dvh - 104px);
    overflow-y:auto;
    -webkit-overflow-scrolling:touch;
  }
  .nav-menu.is-open{
    display:flex;
  }
  .nav-links{
    flex-direction:column;
    align-items:stretch;
    gap:4px;
    width:100%;
  }
  .nav-links li{width:100%}
  .nav-links a{
    display:flex;
    align-items:center;
    width:100%;
    padding:13px 16px;
    border-radius:14px;
    font-size:15px;
    font-weight:500;
    justify-content:flex-start;
  }
  .nav-links a:hover{
    background:rgba(247, 208, 222, .38);
    transform:none;
  }
  .nav-cta{
    margin:14px 0 0;
    padding-top:14px;
    border-top:1px solid rgba(214, 180, 106, .2);
    width:100%;
  }
  .nav-cta .btn{
    width:100%;
    display:flex;
    justify-content:center;
    text-align:center;
  }
}
@media (max-width: 980px){
  .nav-links{gap:6px}
  .nav-links a{padding:10px 7px}
  .hero{
    padding:48px 0 24px;
  }
  .hero-inner{grid-template-columns: 1fr; gap:20px}
  .hero-content{order:1}
  .hero-visual{order:2; min-height:300px}
  .split{grid-template-columns: 1fr; gap:18px}
  .about .media-frame{padding:14px 16px 16px}
  .about .media-frame-inner{padding:0}
  .products-grid{grid-template-columns: repeat(2, minmax(0, 1fr))}
  .reasons-grid{grid-template-columns: repeat(2, minmax(0, 1fr))}
  .testimonials-grid{grid-template-columns: 1fr}
  .contact-card{grid-template-columns: 1fr}
  .contact-visual{min-height: 280px}
  .contact-info{grid-template-columns: 1fr}
  .footer-inner{flex-direction:column; align-items:flex-start}
}

@media (max-width: 760px){
  .container{width:min(100% - 28px, var(--container))}
  .section{padding:52px 0}
  .section-title{font-size:clamp(24px, 6.5vw, 32px); margin:12px 0 8px}
  .section-desc{font-size:15px; line-height:1.75}
  .badge{margin:0 0 10px; padding:8px 12px}
  .hero-trust{margin-top:18px; gap:10px}
  .trust-item{padding:10px 12px}
  .hero-cake{height:200px; margin:6px 12px 10px}
  .hero-card-top{padding:12px 14px 6px}
  .hero-card-bottom{padding:10px 14px 14px}
  .mini-row{padding:10px 12px}
  .floating-a{width:96px; height:96px; left:-16px; bottom:12px}
  .floating-b{width:78px; height:78px; right:8px; top:18px}
  .trust-item{flex:1}
  .products-grid{grid-template-columns: 1fr}
  .reasons-grid{grid-template-columns: 1fr}
  .gallery-grid{grid-template-columns: 1fr; gap:12px}
  .g1,.g2,.g3,.g4,.g5,.g6,.g7,.g8,.g9{grid-column:auto; min-height: 168px}
  .contact{padding-bottom:64px}
  .footer-cols{grid-template-columns: 1fr}
  .footer-bottom{flex-direction:column; align-items:center}
}

@media (max-width: 768px){
  .hero{
    padding:132px 0 40px;
    margin-bottom:8px;
  }
  .hero-inner{
    grid-template-columns:1fr;
    gap:22px;
  }
  .hero-content{
    order:1;
  }
  .hero-visual{
    order:2;
    min-height:0;
  }
  .hero-title{
    font-size:clamp(28px, 7.5vw, 36px);
    line-height:1.12;
    margin:0 0 12px;
    letter-spacing:-.26px;
  }
  .hero-subtitle{
    font-size:15px;
    line-height:1.75;
    max-width:none;
  }
  .hero-actions{
    margin-top:16px;
    gap:10px;
  }
  .hero-actions .btn{
    flex:1;
  }
  .hero-card-inner{
    padding:6px;
  }
  #beranda[data-hero-slider="1"] .hero-slide-track,
  .hero-card-inner picture{
    display:block;
    width:100%;
    aspect-ratio:5 / 4;
    min-height:320px;
    height:320px;
    max-height:340px;
  }
  .hero-card-inner img.hero-cake{
    display:block;
    width:100%;
    height:100%;
    min-height:320px;
    max-height:340px;
    margin:0;
    padding:0;
    object-fit:cover;
    object-position:center top;
    border-radius:14px;
  }
  .hero-card-inner > .hero-cake,
  .hero-card-inner .hero-slide-visual.hero-cake{
    height:320px;
    min-height:320px;
  }
  #beranda[data-hero-slider="1"] .hero-slide-track > .hero-slide-visual picture{
    min-height:100%;
    height:100%;
  }
  #beranda[data-hero-slider="1"] .hero-slide-track > .hero-slide-visual .hero-cake{
    min-height:320px;
    height:100%;
    max-height:340px;
    object-fit:cover;
    object-position:center top;
  }
  .hero-card-inner .hero-slide-visual.is-active picture,
  .hero-card-inner .hero-slide-visual picture{
    height:100%;
  }
  .hero-banner-deco .hero-float-circle--tl{
    width:56px;
    height:56px;
    left:6px;
    top:6px;
    opacity:.42;
  }
  .hero-visual > .hero-float-circle--bl{
    width:96px;
    height:96px;
    left:-12px;
    bottom:6px;
    opacity:.4;
  }
  .hero-visual > .hero-float-circle--tr{
    width:64px;
    height:64px;
    right:-8px;
    top:2px;
    opacity:.38;
  }
  .about.section,
  section.about#tentang{
    padding-top:60px;
  }
}

@media (prefers-reduced-motion: reduce){
  html{scroll-behavior:auto}
  .btn,.card,.reason,.gallery-item,.nav-links a,.footer-links a,.to-top,.reveal{transition:none}
  .floating{animation:none}
  .nav-menu,.nav-toggle-line{transition:none}
}

/* ----- Multi-page mockup (clickable site) ----- */
.page-main{padding-bottom:48px}
.page-hero{padding-top:18px; padding-bottom:8px}
.page-title{
  font-family:var(--font-display);
  font-size:clamp(2rem, 4vw, 2.75rem);
  letter-spacing:-.02em;
  margin:10px 0 0;
  color:var(--text);
}
.page-list{margin:0; padding-left:1.1rem; color:var(--muted); line-height:1.7}
.page-list li{margin:.45rem 0}
.page-cta{display:flex; flex-wrap:wrap; gap:12px; justify-content:center; margin-top:18px}
.alt-bg{background:linear-gradient(180deg, rgba(255,243,247,.55), rgba(255,255,255,.35))}
.steps-grid{grid-template-columns:repeat(3, minmax(0,1fr)); gap:14px}
.step-card{
  background:var(--surface-strong);
  border:1px solid var(--border);
  border-radius:var(--radius-md);
  padding:16px;
  box-shadow:var(--shadow-sm);
}
.step-num{
  display:inline-flex; width:34px; height:34px; border-radius:999px;
  align-items:center; justify-content:center; font-weight:700;
  background:rgba(214,180,106,.22); color:var(--brown); margin-bottom:8px;
}
.step-title{font-weight:700; margin:0 0 6px}
.step-desc{margin:0; color:var(--muted); font-size:14px; line-height:1.55}
.narrow{max-width:720px; margin-inline:auto}

.card-as-link{
  text-decoration:none;
  color:inherit;
  display:flex;
  flex-direction:column;
  height:100%;
  border-radius:inherit;
}
.card-as-link .card-title{color:inherit}
.card-as-link:hover{transform:translateY(-2px); box-shadow:var(--shadow-md)}
.card-as-link:focus-visible{outline:3px solid var(--ring); outline-offset:2px}

.gallery-as-link{
  display:block;
  text-decoration:none;
  color:inherit;
  border-radius:var(--radius-md);
}
.gallery-as-link:focus-visible{outline:3px solid var(--ring); outline-offset:2px}

.media-frame-link{
  display:block;
  text-decoration:none;
  color:inherit;
  border-radius:var(--radius-lg);
}
.media-frame-inner{position:relative; border-radius:inherit; overflow:hidden}
.media-frame-link:focus-visible .media-frame-inner{outline:3px solid var(--ring); outline-offset:3px}

a.reason-link{
  text-decoration:none;
  color:inherit;
  display:block;
  border-radius:var(--radius-md);
}
a.reason-link:focus-visible{outline:3px solid var(--ring); outline-offset:2px}

.filter-mock{
  display:grid;
  grid-template-columns:repeat(2, minmax(0,1fr));
  gap:12px;
  margin:0 auto 22px;
  max-width:720px;
}
.filter-field{display:flex; flex-direction:column; gap:6px}
.filter-label{font-size:13px; color:var(--muted); font-weight:600}

.detail-visual{border-radius:var(--radius-lg); overflow:hidden}
.detail-img{width:100%; height:auto; display:block; border-radius:var(--radius-lg)}
.detail-img-ph{
  min-height:380px;
  border-radius:var(--radius-lg);
  border:1px solid var(--border);
}
.detail-dl{margin:14px 0 0; display:grid; gap:10px}
.detail-dl div{display:grid; grid-template-columns:160px 1fr; gap:10px; align-items:start}
.detail-dl dt{margin:0; font-size:12px; text-transform:uppercase; letter-spacing:.08em; color:var(--muted); font-weight:700}
.detail-dl dd{margin:0; color:var(--text)}

.gallery-filter-bar{display:flex; flex-wrap:wrap; gap:10px; justify-content:center; margin:0 auto 18px}
.gallery-filter-btn.is-active{
  border-color:rgba(214,180,106,.55);
  background:rgba(255,248,235,.75);
}
.gallery-page-grid .gallery-item{min-height:168px}

.contact-cards-grid{grid-template-columns:repeat(2, minmax(0,1fr)); gap:14px; max-width:900px; margin-inline:auto}
.contact-cta-card{align-items:flex-start}
.contact-form-page{
  background:var(--surface-strong);
  border:1px solid var(--border);
  border-radius:var(--radius-lg);
  padding:18px;
  box-shadow:var(--shadow-sm);
}
.form-mock-note{
  margin:0 0 14px;
  padding:10px 12px;
  border-radius:var(--radius-sm);
  border:1px dashed rgba(214,180,106,.45);
  background:rgba(255,248,235,.65);
  color:var(--brown);
  font-size:14px;
}
.inline-link{color:var(--brown); font-weight:600; text-decoration:underline}
.testimonial-order{margin:6px 0 0; font-size:13px; color:var(--muted)}

@media (max-width: 900px){
  .steps-grid{grid-template-columns:1fr}
  .filter-mock{grid-template-columns:1fr}
  .detail-dl div{grid-template-columns:1fr}
  .contact-cards-grid{grid-template-columns:1fr}
}

/* ---- CMS image alignment classes ----------------------------------------- */
/* Set by TinyMCE image_class_list; rendered in about, pages, landing content. */
.img-center {
  display: block;
  float: none;
  width: auto;
  max-width: 700px;
  height: auto;
  margin: 24px auto;
  border-radius: 12px;
}
.img-full {
  display: block;
  float: none;
  width: 100%;
  max-width: 900px;
  height: auto;
  margin: 24px auto;
  border-radius: 12px;
}
.img-left {
  float: left;
  width: 280px;
  max-width: 40%;
  height: auto;
  margin: 0 24px 16px 0;
  border-radius: 12px;
}
.img-right {
  float: right;
  width: 280px;
  max-width: 40%;
  height: auto;
  margin: 0 0 16px 24px;
  border-radius: 12px;
}
/* Consecutive floated images clear each other so they stack vertically. */
.img-left  ~ .img-left,
.img-left  ~ .img-right,
.img-right ~ .img-left,
.img-right ~ .img-right { clear: both; }

/* Mobile: all alignment classes become full-width block */
@media (max-width: 640px) {
  .img-center,
  .img-full,
  .img-left,
  .img-right {
    float: none;
    display: block;
    width: 100%;
    max-width: 100%;
    margin: 20px 0;
  }
}
