:root{
  --navy:#0A1628;
  --navy2:#081224;
  --gold:#D4AF37;
  --gold2:#c9a227;
  --sand:#F5F1E8;
  --sand2:#fbf7ef;
  --green:#2D6A4F;
  --radius:18px;
  --max:1160px;
}

*{margin:0;padding:0;box-sizing:border-box}
html,body{height:100%}

body{
  font-family:'Source Sans 3',sans-serif;
  color:var(--navy);
  background:
    radial-gradient(1200px 600px at 10% 0%, rgba(212,175,55,.18), transparent 60%),
    radial-gradient(900px 520px at 90% 10%, rgba(10,22,40,.08), transparent 62%),
    radial-gradient(800px 520px at 70% 95%, rgba(45,106,79,.10), transparent 60%),
    repeating-linear-gradient(45deg, rgba(10,22,40,.02) 0px, rgba(10,22,40,.02) 2px, transparent 2px, transparent 10px),
    linear-gradient(180deg, var(--sand2) 0%, var(--sand) 55%, var(--sand2) 100%);
  line-height:1.55;
  font-size:18px;
}

a{color:inherit;text-decoration:none}
.wrap{max-width:var(--max);margin:0 auto;padding:0 18px}

/* Topbar */
.topbar{
  position:sticky;top:0;z-index:50;
  background:rgba(10,22,40,0.96);
  backdrop-filter:blur(20px);
  border-bottom:1px solid rgba(212,175,55,0.22);
}
.topbar .row{display:flex;align-items:center;justify-content:space-between;gap:14px;padding:14px 0}

.brand{
  display:flex;align-items:center;gap:12px;
  font-weight:900;letter-spacing:.2px;
  color:var(--gold);
}
.brand span:last-child{ /* TripFui text */
  font-size:22px;
  letter-spacing:.4px;
}
.brand .logo{
  width:38px;height:38px;border-radius:14px;
  background:radial-gradient(circle at 30% 30%, #ffe9a6 0%, var(--gold) 45%, var(--gold2) 100%);
  box-shadow:0 12px 30px rgba(212,175,55,0.28);
}

.nav{display:flex;gap:14px;flex-wrap:wrap;font-size:16px}
.nav a{
  padding:9px 12px;border-radius:14px;
  color:rgba(245,241,232,0.90);
}
.nav a:hover{background:rgba(212,175,55,0.12);color:var(--sand)}
.nav a[aria-current="page"]{background:rgba(212,175,55,0.20);color:var(--sand);font-weight:900}

/* Hero */
.hero{padding:46px 0 16px}
.hero h1{
  font-family:'Playfair Display',serif;
  margin:0;
  font-size:58px;
  line-height:1.04;
  letter-spacing:-.7px;
  color:var(--gold);
  text-shadow:0 10px 26px rgba(10,22,40,.18);
}
.hero .sub{
  margin:12px 0 0;
  color:rgba(10,22,40,0.78);
  max-width:84ch;
  font-size:19px
}
.hero .cta{margin-top:18px;display:flex;gap:12px;flex-wrap:wrap}

/* Buttons */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:10px;
  padding:14px 16px;border-radius:16px;font-weight:900;font-size:16px;
  background:linear-gradient(135deg,var(--gold),var(--gold2));
  color:var(--navy);
  border:1px solid rgba(10,22,40,0.12);
  box-shadow:0 14px 26px rgba(10,22,40,0.12);
}
.btn:hover{transform:translateY(-1px);filter:brightness(1.02)}
.btn.ghost{
  background:transparent;color:var(--navy);
  border:1px solid rgba(10,22,40,0.20);
  box-shadow:none;
}
.btn.ghost:hover{background:rgba(10,22,40,0.04)}
.micro{margin:12px 0 0;color:rgba(10,22,40,0.70);font-size:14px}

/* Sections */
.section{padding:18px 0 6px}
.section h2{
  margin:0 0 14px;
  font-size:22px;
  letter-spacing:.2px;
  color:var(--navy);
}
.section h2::after{
  content:"";
  display:block;
  width:64px;height:3px;
  background:linear-gradient(90deg,var(--gold),transparent);
  margin-top:10px;
  border-radius:99px;
}

/* Grid */
.grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
@media(max-width:980px){
  .grid{grid-template-columns:repeat(2,1fr)}
  .hero h1{font-size:48px}
  .brand span:last-child{font-size:20px}
}
@media(max-width:620px){
  .grid{grid-template-columns:1fr}
  .hero h1{font-size:40px}
  .hero .sub{font-size:17px}
  .nav{font-size:15px}
}

/* Cards */
.card{
  background:#fff;
  border:1px solid rgba(10,22,40,0.10);
  border-radius:var(--radius);
  padding:16px;
  box-shadow:0 12px 28px rgba(10,22,40,0.08);
  transition:transform .12s ease, box-shadow .18s ease, border-color .18s ease;
}
.card:hover{
  transform:translateY(-3px);
  box-shadow:0 18px 40px rgba(10,22,40,0.12);
  border-color:rgba(212,175,55,0.42);
}
.badges{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:12px}
.badge{
  font-size:14px;
  color:var(--navy);
  background:rgba(212,175,55,0.14);
  border:1px solid rgba(212,175,55,0.28);
  padding:6px 10px;border-radius:999px
}
.badge.hot{background:rgba(45,106,79,0.14);border-color:rgba(45,106,79,0.35)}
.badge.limited{background:rgba(10,22,40,0.08);border-color:rgba(10,22,40,0.18)}
.card h3{margin:0 0 8px;font-size:20px;line-height:1.25}
.meta{display:flex;gap:10px;flex-wrap:wrap;color:rgba(10,22,40,0.72);font-size:15px;margin:8px 0 12px}
.price{font-weight:900;color:var(--navy)}
.actions{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-top:12px}
.small{font-size:14px;color:rgba(10,22,40,0.65)}

/* Notice */
.notice{
  border:1px solid rgba(212,175,55,0.30);
  background:rgba(212,175,55,0.10);
  border-radius:18px;
  padding:16px;
  color:rgba(10,22,40,0.82);
}
.notice b{color:var(--navy)}
hr{border:none;border-top:1px solid rgba(10,22,40,0.12);margin:20px 0}

/* Footer */
.footer{
  margin-top:38px;
  border-top:1px solid rgba(10,22,40,0.12);
  padding:18px 0 34px;
  background:transparent;
}
.footer .links{display:flex;gap:12px;flex-wrap:wrap;font-size:15px;color:rgba(10,22,40,0.74)}
.footer .links a{padding:7px 10px;border-radius:12px}
.footer .links a:hover{background:rgba(10,22,40,0.05);color:var(--navy)}
.footer small{display:block;color:rgba(10,22,40,0.72);margin-top:10px;font-size:14px}
