@import url('https://fonts.googleapis.com/css2?family=Cormorant+Garamond:ital,wght@0,300;0,400;0,600;1,300;1,400&family=Great+Vibes&family=Montserrat:wght@300;400;500;600&display=swap');

/* ─── TOKENS ──────────────────────────────────────────────────────────── */
:root {
  --navy:        #1b3556;
  --navy-dark:   #0f1f35;
  --navy-mid:    #243d60;
  --gold:        #c9a96e;
  --gold-light:  #e2c88a;
  --gold-pale:   #f5edd9;
  --cream:       #faf6ef;
  --cream-dark:  #f2ead8;
  --white:       #ffffff;
  --text:        #4a4a4a;
  --text-light:  #7a7a7a;

  --f-script:  'Great Vibes', cursive;
  --f-serif:   'Cormorant Garamond', serif;
  --f-sans:    'Montserrat', sans-serif;

  --transition: 0.35s ease;
  --shadow-sm:  0 4px 16px rgba(0,0,0,.08);
  --shadow-md:  0 10px 32px rgba(0,0,0,.12);
  --shadow-lg:  0 20px 60px rgba(0,0,0,.18);
}

/* ─── RESET ───────────────────────────────────────────────────────────── */
*, *::before, *::after { margin:0; padding:0; box-sizing:border-box; }
html { scroll-behavior:smooth; }
body {
  font-family: var(--f-sans);
  background: var(--cream);
  color: var(--text);
  overflow-x: hidden;
  font-size: 14px;
  -webkit-font-smoothing: antialiased;
}
img { display:block; max-width:100%; }
a { text-decoration:none; }

/* ─── UTILS ───────────────────────────────────────────────────────────── */
.hidden { display:none !important; }
.text-center { text-align:center; }
.container { width:90%; max-width:600px; margin:0 auto; position:relative; z-index:2; }

/* ─── ORNAMENT DIVIDER ────────────────────────────────────────────────── */
.ornament {
  display:flex; align-items:center; justify-content:center;
  gap:12px; margin:0 auto;
  color: var(--gold); font-size:18px; opacity:.7;
}
.ornament::before,
.ornament::after {
  content:''; flex:1; height:1px;
  background: linear-gradient(to right, transparent, var(--gold), transparent);
  max-width:80px;
}

/* ─── COVER ───────────────────────────────────────────────────────────── */
#cover {
  position:fixed; inset:0; z-index:9999;
  background-size:cover; background-position:center;
  display:flex; flex-direction:column; justify-content:flex-end;
  transition: transform 1.1s cubic-bezier(.77,0,.175,1);
}
#cover::before {
  content:'';
  position:absolute; inset:0;
  background: linear-gradient(
    to bottom,
    rgba(11,30,55,.2) 0%,
    rgba(11,30,55,.05) 40%,
    rgba(11,30,55,.6) 70%,
    rgba(11,30,55,.92) 100%
  );
}
.cover-content {
  position:relative; z-index:2;
  text-align:center;
  padding:2rem 1.5rem 3.5rem;
}
.cover-label {
  font-family: var(--f-sans);
  font-size:10px; font-weight:600;
  letter-spacing:4px; text-transform:uppercase;
  color:rgba(255,255,255,.75);
  margin-bottom:12px;
}
.cover-couple {
  font-family: var(--f-script);
  font-size:3.8rem; line-height:1.1;
  color: var(--white);
  text-shadow: 0 2px 20px rgba(0,0,0,.4);
  margin-bottom:6px;
}
.cover-ampersand { color: var(--gold-light); }
.cover-date-line {
  font-family: var(--f-serif);
  font-size:13px; letter-spacing:3px;
  color:rgba(255,255,255,.65);
  margin:10px 0 24px;
}
.cover-guest {
  margin:0 0 28px;
}
.cover-guest-label {
  font-size:11px; color:rgba(255,255,255,.6);
  letter-spacing:1px; margin-bottom:4px;
}
.cover-guest-name {
  font-family: var(--f-serif);
  font-size:1.3rem; font-weight:400; font-style:italic;
  color: var(--white);
}
.btn-open {
  background: var(--gold);
  color: var(--navy-dark);
  border:none; border-radius:50px;
  padding:14px 36px;
  font-family: var(--f-sans);
  font-size:13px; font-weight:600;
  letter-spacing:1.5px; text-transform:uppercase;
  cursor:pointer;
  box-shadow:0 8px 30px rgba(201,169,110,.5);
  transition: var(--transition);
  display:inline-flex; align-items:center; gap:10px;
}
.btn-open:hover { background:var(--gold-light); transform:translateY(-2px); }

/* ─── MUSIC BTN ───────────────────────────────────────────────────────── */
#btn-music {
  position:fixed; bottom:24px; right:24px;
  width:46px; height:46px;
  background: var(--white);
  color: var(--navy);
  border:none; border-radius:50%;
  box-shadow:0 4px 16px rgba(0,0,0,.18);
  font-size:18px; cursor:pointer; z-index:500;
  display:flex; align-items:center; justify-content:center;
  transition: var(--transition);
}
#btn-music:hover { background: var(--gold); color: var(--white); }

/* ─── SECTION BASES ───────────────────────────────────────────────────── */
.s-cream  { background:var(--cream); }
.s-white  { background:var(--white); }
.s-navy   { background:var(--navy-dark); }
.s-gold-pale { background:var(--gold-pale); }

/* ─── 1. HERO ─────────────────────────────────────────────────────────── */
#s-hero {
  padding:60px 0 50px;
  text-align:center;
  background: var(--cream);
  position:relative;
  overflow:hidden;
}
#s-hero::before {
  content:'';
  position:absolute; top:0; left:0; right:0;
  height:3px;
  background:linear-gradient(90deg,transparent,var(--gold),transparent);
}
.hero-eyebrow {
  font-size:9px; letter-spacing:5px;
  text-transform:uppercase; font-weight:600;
  color: var(--gold); margin-bottom:20px;
}
.hero-duo {
  display:flex; justify-content:center; gap:20px;
  margin:20px auto;
}
.arch-frame {
  width:150px; height:220px;
  border-radius:75px 75px 0 0;
  overflow:hidden;
  border:3px solid rgba(201,169,110,.4);
  box-shadow: var(--shadow-md);
  position:relative;
}
.arch-frame img { width:100%; height:100%; object-fit:cover; }
.hero-script {
  font-family: var(--f-script);
  font-size:3.2rem; line-height:1;
  color: var(--navy);
  margin-top:10px;
}
.hero-script span { color: var(--gold); }

/* ─── COUNTDOWN ───────────────────────────────────────────────────────── */
#s-countdown {
  background: var(--navy-dark);
  padding:36px 0;
  text-align:center;
  position:relative;
}
.cd-label {
  font-size:9px; letter-spacing:4px;
  text-transform:uppercase; color: var(--gold);
  margin-bottom:18px;
}
.countdown-row {
  display:flex; justify-content:center; gap:12px;
}
.cd-box {
  background:rgba(255,255,255,.06);
  border:1px solid rgba(201,169,110,.25);
  border-radius:12px;
  width:68px; padding:12px 0;
  color: var(--white);
}
.cd-box .cd-num {
  font-family: var(--f-serif);
  font-size:2rem; font-weight:600;
  line-height:1;
  color: var(--gold-light);
}
.cd-box .cd-unit {
  font-size:9px; letter-spacing:2px;
  text-transform:uppercase;
  color:rgba(255,255,255,.5);
  margin-top:4px;
}
.cd-divider {
  font-family: var(--f-serif);
  font-size:1.5rem; color:rgba(255,255,255,.2);
  align-self:center; margin-bottom:16px;
}
.std-badge {
  display:inline-block;
  font-family: var(--f-serif);
  font-size:13px; letter-spacing:2px;
  color: var(--gold);
  border:1px solid rgba(201,169,110,.3);
  padding:6px 20px; border-radius:50px;
  margin-top:22px;
}

/* ─── 2. SALAM / GREETING ─────────────────────────────────────────────── */
#s-greeting {
  padding:64px 0;
  text-align:center;
  background:var(--cream);
  position:relative;
}
.bismillah-img {
  width:160px; margin:0 auto 28px;
  opacity:.85;
}
.greeting-title {
  font-family: var(--f-script);
  font-size:2.6rem; color: var(--navy);
  margin-bottom:22px;
}
.greeting-body {
  font-family: var(--f-serif);
  font-size:1rem; font-style:italic;
  color: var(--text); line-height:1.9;
  max-width:400px; margin:0 auto 40px;
}
.couple-profiles {
  display:flex; justify-content:center; gap:28px; flex-wrap:wrap;
}
.profile-card { text-align:center; width:150px; }
.profile-arch {
  width:130px; height:180px;
  border-radius:65px 65px 0 0;
  overflow:hidden;
  border:3px solid rgba(201,169,110,.35);
  box-shadow: var(--shadow-sm);
  margin:0 auto 16px;
}
.profile-arch img { width:100%; height:100%; object-fit:cover; }
.profile-name {
  font-family: var(--f-script);
  font-size:1.8rem; color: var(--navy);
  line-height:1;
  margin-bottom:6px;
}
.profile-family {
  font-size:10px; color: var(--text-light);
  line-height:1.6;
}
.profile-family strong { display:block; font-weight:500; }
.couple-connector {
  display:flex; align-items:center; justify-content:center;
  font-family: var(--f-script);
  font-size:2.5rem; color: var(--gold);
  padding-top:60px;
  flex-shrink:0;
}

/* ─── 3. SAVE THE DATE / AYAT ─────────────────────────────────────────── */
#s-savedate {
  background: var(--navy-dark);
  padding:60px 0;
  text-align:center;
  position:relative;
  overflow:hidden;
}
#s-savedate::before {
  content:'';
  position:absolute; inset:0;
  background: radial-gradient(ellipse 80% 60% at 50% 50%, rgba(201,169,110,.08) 0%, transparent 70%);
}
.sd-eyebrow {
  font-size:9px; letter-spacing:5px;
  text-transform:uppercase; font-weight:600;
  color:rgba(255,255,255,.4); margin-bottom:8px;
}
.sd-title {
  font-family: var(--f-script);
  font-size:3.5rem; color: var(--white);
  margin-bottom:28px;
}
.sd-ayat {
  font-family: var(--f-serif);
  font-size:1rem; font-style:italic;
  color:rgba(255,255,255,.75);
  line-height:1.9; max-width:380px; margin:0 auto 10px;
}
.sd-ayat-ref {
  font-size:11px; color: var(--gold);
  letter-spacing:1px;
}

/* ─── 4. AKAD & RESEPSI ───────────────────────────────────────────────── */
#s-events {
  background:var(--cream);
  padding:60px 0;
}
.events-title {
  font-family: var(--f-script);
  font-size:2.8rem; color: var(--navy);
  text-align:center; margin-bottom:36px;
}
.event-card {
  background: var(--white);
  border-radius:20px;
  padding:36px 28px;
  box-shadow: var(--shadow-sm);
  text-align:center;
  position:relative;
  overflow:hidden;
  margin-bottom:20px;
}
.event-card::before {
  content:'';
  position:absolute; top:0; left:0; right:0;
  height:3px;
  background:linear-gradient(90deg, var(--gold), var(--gold-light), var(--gold));
}
.event-icon {
  width:44px; height:44px;
  background: var(--gold-pale);
  border-radius:50%;
  display:flex; align-items:center; justify-content:center;
  font-size:18px; margin:0 auto 16px;
}
.event-type {
  font-family: var(--f-script);
  font-size:2rem; color: var(--navy);
  margin-bottom:16px;
}
.event-date-text {
  font-family: var(--f-serif);
  font-size:1.1rem; font-weight:600;
  color: var(--navy); margin-bottom:4px;
}
.event-time-text {
  font-size:12px; color: var(--gold);
  letter-spacing:2px; font-weight:600;
  text-transform:uppercase; margin-bottom:12px;
}
.event-separator { width:32px; height:1px; background:var(--gold); margin:14px auto; opacity:.4; }
.event-addr {
  font-size:13px; color: var(--text-light);
  line-height:1.7;
}
.btn-map {
  display:inline-flex; align-items:center; gap:8px;
  margin-top:18px;
  background:transparent;
  border:1.5px solid var(--gold);
  color: var(--gold);
  border-radius:50px;
  padding:10px 24px;
  font-family: var(--f-sans);
  font-size:12px; font-weight:600;
  letter-spacing:1px; text-transform:uppercase;
  cursor:pointer; transition: var(--transition);
}
.btn-map:hover { background: var(--gold); color: var(--white); }

/* ─── 5. LIVE STREAMING ───────────────────────────────────────────────── */
#s-stream {
  background: var(--navy-dark);
  padding:60px 0; text-align:center;
}
.stream-title {
  font-family: var(--f-script);
  font-size:2.8rem; color: var(--white);
  margin-bottom:16px;
}
.stream-body {
  font-size:13px; color:rgba(255,255,255,.65);
  line-height:1.8; max-width:340px;
  margin:0 auto 24px;
}
.stream-info {
  font-family: var(--f-serif);
  font-size:1rem; font-style:italic;
  color: var(--gold-light); margin-bottom:24px;
}
.btn-ig {
  display:inline-flex; align-items:center; gap:10px;
  background:linear-gradient(135deg,#f09433,#e6683c,#dc2743,#cc2366,#bc1888);
  color: var(--white);
  border:none; border-radius:50px;
  padding:14px 32px;
  font-family: var(--f-sans);
  font-size:13px; font-weight:600;
  cursor:pointer; transition: var(--transition);
  box-shadow:0 8px 24px rgba(220,39,67,.4);
}
.btn-ig:hover { transform:translateY(-2px); box-shadow:0 12px 30px rgba(220,39,67,.5); }

/* ─── 6. AMPLOP DIGITAL ───────────────────────────────────────────────── */
#s-amplop {
  background: var(--cream);
  padding:60px 0; text-align:center;
}
.amplop-title {
  font-family: var(--f-script);
  font-size:2.8rem; color: var(--navy);
  margin-bottom:10px;
}
.amplop-subtitle {
  font-size:12px; color: var(--text-light);
  margin-bottom:32px;
}
.atm-cards-wrap {
  display:flex; flex-direction:column;
  align-items:center; gap:24px;
}
.atm-card {
  width:100%; max-width:340px;
}
.atm-inner {
  background:linear-gradient(135deg, #1a3a6c 0%, #0d1f3c 100%);
  border:1px solid rgba(255,255,255,.08);
  border-radius:18px;
  padding:24px;
  box-shadow:0 16px 40px rgba(0,0,0,.3);
  text-align:left; position:relative; overflow:hidden;
}
.atm-inner::after {
  content:'';
  position:absolute; top:-40%; right:-20%;
  width:250px; height:250px;
  background:radial-gradient(circle,rgba(201,169,110,.12) 0%,transparent 70%);
  pointer-events:none;
}
.atm-top {
  display:flex; justify-content:space-between;
  align-items:flex-start; margin-bottom:24px;
}
.atm-bank-name {
  font-family: var(--f-serif);
  font-size:18px; font-weight:600;
  color: var(--white); letter-spacing:.5px;
}
.atm-chip-wrap { display:flex; align-items:center; gap:10px; margin-bottom:18px; }
.atm-chip {
  width:36px; height:26px;
  background:linear-gradient(135deg,#e5c07b,#d4a373);
  border-radius:5px; position:relative;
}
.atm-chip::after {
  content:''; position:absolute; inset:4px;
  border:1px solid rgba(0,0,0,.15); border-radius:3px;
}
.atm-nfc { color:rgba(255,255,255,.35); font-size:15px; transform:rotate(90deg); }
.atm-number {
  font-family:'Courier New', monospace;
  font-size:20px; font-weight:700;
  color: var(--white); letter-spacing:4px;
  margin-bottom:18px;
  text-shadow:1px 2px 4px rgba(0,0,0,.5);
}
.atm-footer {
  display:flex; justify-content:space-between; align-items:flex-end;
}
.atm-holder .atm-label {
  font-size:8px; color:rgba(255,255,255,.4);
  letter-spacing:1.5px; text-transform:uppercase; margin-bottom:2px;
}
.atm-holder .atm-name {
  font-size:13px; font-weight:500; color: var(--white); letter-spacing:.5px;
}
.atm-logo {
  display:flex; position:relative; width:48px; height:28px;
}
.atm-logo .circle {
  width:28px; height:28px; border-radius:50%;
  position:absolute; opacity:.85;
}
.atm-logo .circle-1 { background:#eb001b; left:0; }
.atm-logo .circle-2 { background:#f79e1b; right:0; }
.btn-copy {
  width:100%; margin-top:10px;
  background:rgba(255,255,255,.07);
  border:1px solid rgba(255,255,255,.15);
  color:rgba(255,255,255,.8);
  padding:11px; border-radius:10px;
  font-family: var(--f-sans);
  font-size:12px; font-weight:500;
  cursor:pointer; transition: var(--transition);
  display:flex; align-items:center; justify-content:center; gap:8px;
}
.btn-copy:hover { background: var(--gold); color: var(--navy-dark); border-color: var(--gold); }

/* ─── 7. GALLERY ──────────────────────────────────────────────────────── */
#s-gallery {
  background: var(--white);
  padding:60px 0; text-align:center;
}
.gallery-title {
  font-family: var(--f-script);
  font-size:2.8rem; color: var(--navy);
  margin-bottom:32px;
}
.gallery-grid {
  display:grid;
  grid-template-columns:1fr 1fr;
  grid-template-rows:auto auto;
  gap:10px;
}
.gallery-grid img {
  width:100%; height:160px;
  object-fit:cover; border-radius:12px;
  box-shadow: var(--shadow-sm);
  transition: var(--transition);
}
.gallery-grid img:hover { transform:scale(1.02); box-shadow: var(--shadow-md); }
.gallery-grid img:first-child {
  grid-column:1 / 3;
  height:220px;
}

/* ─── 8. LOVE STORY ───────────────────────────────────────────────────── */
#s-story {
  background: var(--cream);
  padding:60px 0;
}
.story-title {
  font-family: var(--f-script);
  font-size:2.8rem; color: var(--navy);
  text-align:center; margin-bottom:36px;
}
.timeline {
  position:relative; padding-left:20px;
}
.timeline::before {
  content:'';
  position:absolute; left:20px; top:8px; bottom:8px;
  width:1px;
  background:linear-gradient(to bottom, transparent, var(--gold) 10%, var(--gold) 90%, transparent);
  opacity:.3;
}
.tl-item {
  display:flex; gap:20px;
  margin-bottom:36px; position:relative;
}
.tl-item:last-child { margin-bottom:0; }
.tl-dot {
  flex-shrink:0;
  width:40px; height:40px;
  background: var(--white);
  border:2px solid rgba(201,169,110,.4);
  border-radius:50%;
  display:flex; align-items:center; justify-content:center;
  font-size:18px;
  position:relative; z-index:1;
  box-shadow: var(--shadow-sm);
}
.tl-content {
  background: var(--white);
  border-radius:16px;
  padding:20px 24px;
  box-shadow: var(--shadow-sm);
  flex:1;
}
.tl-title {
  font-family: var(--f-serif);
  font-size:1.1rem; font-weight:600;
  color: var(--navy); margin-bottom:8px;
}
.tl-text {
  font-size:13px; color: var(--text-light);
  line-height:1.8;
}

/* ─── 9. RSVP / UCAPAN ────────────────────────────────────────────────── */
#s-rsvp {
  background: var(--navy-dark);
  padding:60px 0; text-align:center;
}
.rsvp-title {
  font-family: var(--f-script);
  font-size:2.8rem; color: var(--white);
  margin-bottom:6px;
}
.rsvp-sub {
  font-size:12px; color:rgba(255,255,255,.5);
  letter-spacing:2px; text-transform:uppercase;
  margin-bottom:32px;
}
.rsvp-form {
  text-align:left; max-width:420px; margin:0 auto;
}
.rsvp-form input,
.rsvp-form textarea {
  width:100%; padding:14px 18px;
  background:rgba(255,255,255,.06);
  border:1px solid rgba(255,255,255,.12);
  border-radius:12px;
  font-family: var(--f-sans);
  font-size:13px; color: var(--white);
  margin-bottom:12px;
  transition: var(--transition);
}
.rsvp-form input::placeholder,
.rsvp-form textarea::placeholder { color:rgba(255,255,255,.3); }
.rsvp-form input:focus,
.rsvp-form textarea:focus {
  outline:none;
  border-color:rgba(201,169,110,.5);
  background:rgba(255,255,255,.09);
}
.rsvp-form textarea { resize:vertical; min-height:110px; }
.btn-send {
  width:100%; padding:15px;
  background: var(--gold);
  color: var(--navy-dark);
  border:none; border-radius:12px;
  font-family: var(--f-sans);
  font-size:13px; font-weight:700;
  letter-spacing:1.5px; text-transform:uppercase;
  cursor:pointer; transition: var(--transition);
  box-shadow:0 8px 24px rgba(201,169,110,.35);
}
.btn-send:hover { background: var(--gold-light); transform:translateY(-1px); }

.ucapan-list {
  margin-top:32px; text-align:left; max-width:420px; margin-left:auto; margin-right:auto;
}
.ucapan-item {
  background:rgba(255,255,255,.05);
  border:1px solid rgba(255,255,255,.08);
  border-radius:12px; padding:16px 18px;
  margin-bottom:12px;
}
.ucapan-name {
  font-weight:600; font-size:13px; color: var(--white);
  margin-bottom:4px;
}
.ucapan-text {
  font-size:12px; color:rgba(255,255,255,.65);
  line-height:1.7; margin-bottom:6px;
}
.ucapan-time { font-size:10px; color:rgba(255,255,255,.3); }

/* ─── 10. CLOSING ─────────────────────────────────────────────────────── */
#s-closing {
  background: var(--cream);
  padding:60px 0; text-align:center;
}
.closing-arch {
  width:180px; height:260px;
  border-radius:90px 90px 0 0;
  overflow:hidden;
  border:4px solid rgba(201,169,110,.3);
  box-shadow: var(--shadow-md);
  margin:0 auto 32px;
}
.closing-arch img { width:100%; height:100%; object-fit:cover; }
.closing-salam {
  font-family: var(--f-script);
  font-size:2.2rem; color: var(--navy);
  margin-bottom:20px;
}
.closing-message {
  font-family: var(--f-serif);
  font-size:.95rem; font-style:italic;
  color: var(--text); line-height:1.9;
  max-width:360px; margin:0 auto 24px;
}
.closing-names {
  font-family: var(--f-script);
  font-size:2.5rem; color: var(--navy);
}
.closing-footer {
  margin-top:36px; padding:20px;
  background: var(--navy-dark);
  color:rgba(255,255,255,.4);
  font-size:10px; letter-spacing:2px;
  text-transform:uppercase;
}

/* ─── REVEAL ANIMATION ────────────────────────────────────────────────── */
.reveal {
  opacity:0; transform:translateY(30px);
  transition: opacity .7s ease, transform .7s ease;
}
.reveal.visible {
  opacity:1; transform:translateY(0);
}

/* ─── RESPONSIVE ──────────────────────────────────────────────────────── */
@media(max-width:400px) {
  .cover-couple { font-size:3rem; }
  .hero-duo { gap:12px; }
  .arch-frame { width:130px; height:195px; }
  .couple-profiles { gap:16px; }
  .atm-number { font-size:16px; letter-spacing:2px; }
}

/* ─── GEAR MENU ───────────────────────── */
.gear-container {
  position: fixed;
  top: 18px;
  left: 18px;
  z-index: 99999;
}

#gear-btn {
  width: 42px;
  height: 42px;
  border-radius: 50%;
  border: none;
  background: var(--white);
  color: var(--navy);
  box-shadow: var(--shadow-sm);
  cursor: pointer;
  font-size: 16px;
  transition: 0.3s;
}

#gear-btn:hover {
  background: var(--gold);
  color: white;
}

.gear-panel {
  position: absolute;
  top: 50px;
  left: 0;
  width: 220px;
  background: white;
  border-radius: 12px;
  padding: 12px;
  box-shadow: var(--shadow-md);
}

.gear-panel h3 {
  font-size: 12px;
  margin-bottom: 8px;
  color: var(--navy);
}

.gear-panel input,
.gear-panel textarea {
  width: 100%;
  margin-bottom: 8px;
  padding: 8px;
  font-size: 12px;
  border: 1px solid #ddd;
  border-radius: 6px;
}

.gear-panel button {
  width: 100%;
  padding: 8px;
  font-size: 12px;
  border: none;
  border-radius: 6px;
  cursor: pointer;
  margin-bottom: 6px;
  background: var(--navy);
  color: white;
}

.gear-panel button:hover {
  background: var(--gold);
}

/* ─── PASSWORD MODAL ───────────────── */
.gear-modal {
  position: fixed;
  inset: 0;
  background: rgba(0,0,0,.5);
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 999999;
}

.gear-box {
  background: white;
  padding: 18px;
  border-radius: 12px;
  width: 260px;
  text-align: center;
  box-shadow: var(--shadow-md);
}

.gear-box h3 {
  font-size: 14px;
  margin-bottom: 10px;
  color: var(--navy);
}

.gear-box input {
  width: 100%;
  padding: 10px;
  margin-bottom: 10px;
  border: 1px solid #ddd;
  border-radius: 8px;
}

.gear-box button {
  width: 100%;
  padding: 10px;
  border: none;
  background: var(--navy);
  color: white;
  border-radius: 8px;
  cursor: pointer;
}

.gear-box button:hover {
  background: var(--gold);
}