/* dnbestup-clone — Components (cards, badges, forms) */

/* === Header === */
.site-header{
  position:sticky;top:0;z-index:50;
  background:rgba(255,249,238,.78);
  backdrop-filter:saturate(140%) blur(14px);
  -webkit-backdrop-filter:saturate(140%) blur(14px);
  border-bottom:1px solid var(--line-soft);
}
.nav-row{
  display:flex;align-items:center;justify-content:space-between;gap:24px;
  height:var(--header-h);
}
.brand{display:flex;align-items:center;gap:10px;font-weight:800;letter-spacing:-.02em;color:var(--deep-ocean-2);font-size:18px}
.brand-mark{
  width:34px;height:34px;border-radius:10px;
  background:linear-gradient(135deg,var(--warm-gold),var(--coral));
  display:grid;place-items:center;color:#fff;font-weight:900;
  box-shadow:var(--sh-warm);
}
.brand-mark svg{width:18px;height:18px}
.nav-list{display:none;gap:6px;align-items:center}
.nav-list a{
  padding:8px 14px;border-radius:var(--r-pill);
  font-size:14.5px;font-weight:500;color:var(--ink);
  transition:background .2s,color .2s;
}
.nav-list a:hover{background:var(--surface-warm);color:var(--deep-ocean)}
.nav-actions{display:flex;align-items:center;gap:10px}
.lang-pill{
  display:inline-flex;align-items:center;gap:6px;
  padding:6px 12px;border:1px solid var(--line);border-radius:var(--r-pill);
  font-family:var(--f-mono);font-size:11.5px;letter-spacing:.1em;color:var(--ink-2);
}
.kakao-btn{
  display:inline-flex;align-items:center;gap:8px;
  padding:11px 18px;border-radius:var(--r-pill);
  background:#FEE500;color:#181600;font-weight:700;font-size:14px;
  transition:transform .2s var(--ease-out);
}
.kakao-btn:hover{transform:translateY(-1px)}
.menu-toggle{
  display:inline-flex;flex-direction:column;gap:4px;
  width:42px;height:42px;border:1px solid var(--line);
  border-radius:12px;align-items:center;justify-content:center;
  background:var(--cream);
}
.menu-toggle span{display:block;width:18px;height:1.5px;background:var(--ink)}

@media(min-width:980px){
  .nav-list{display:flex}
  .menu-toggle{display:none}
}

/* === Hero === */
.hero{
  position:relative;
  padding:clamp(48px,8vw,96px) 0 clamp(64px,9vw,120px);
  overflow:hidden;
}
.hero-grid{
  display:grid;
  grid-template-columns:1fr;
  gap:48px;
  align-items:end;
}
@media(min-width:1024px){
  .hero-grid{grid-template-columns:1.05fr .95fr;gap:64px;align-items:center}
}
.hero-tag{
  display:inline-flex;align-items:center;gap:10px;
  padding:8px 14px 8px 8px;border-radius:var(--r-pill);
  background:var(--surface-warm);color:var(--deep-ocean);
  font-size:13px;font-weight:600;letter-spacing:-.005em;margin-bottom:24px;
  border:1px solid var(--line-soft);
}
.hero-tag .dot{width:6px;height:6px;border-radius:50%;background:var(--coral);box-shadow:0 0 0 4px rgba(255,107,91,.18)}
.hero-headline{
  font-size:var(--t-h1);font-weight:800;line-height:1;letter-spacing:-.03em;
  color:var(--ink);
}
.hero-headline em{
  font-family:var(--f-italic);font-style:italic;font-weight:400;
  color:var(--warm-gold-deep);
  display:block;margin-top:.05em;
}
.hero-headline .x{font-family:var(--f-italic);font-style:italic;font-weight:400;color:var(--coral)}
.hero-sub{
  margin-top:24px;font-size:clamp(16px,1.25vw,19px);line-height:1.6;color:var(--ink-2);max-width:520px;
}
.hero-actions{display:flex;flex-wrap:wrap;gap:12px;margin-top:32px}
.hero-stats{
  margin-top:48px;display:grid;grid-template-columns:repeat(3,minmax(0,1fr));
  border-top:1px solid var(--line-soft);padding-top:24px;gap:16px;
}
.hero-stat .v{font-size:clamp(24px,2.4vw,36px);font-weight:800;letter-spacing:-.02em;color:var(--deep-ocean)}
.hero-stat .v sup{font-size:.55em;color:var(--coral);margin-left:2px}
.hero-stat .l{font-size:12.5px;color:var(--ink-2);margin-top:4px;font-family:var(--f-mono);letter-spacing:.1em;text-transform:uppercase}

.hero-visual{
  position:relative;aspect-ratio:4/5;
  border-radius:var(--r-xl);
  overflow:hidden;
  box-shadow:var(--sh-3);
}
.hero-visual img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.hero-visual::after{
  content:"";position:absolute;inset:auto 0 0 0;height:50%;
  background:linear-gradient(180deg,transparent,rgba(15,37,56,.55));
}
.hero-float{
  position:absolute;left:24px;right:24px;bottom:24px;z-index:2;
  display:flex;justify-content:space-between;align-items:flex-end;gap:14px;color:#fff;
}
.hero-float-l{font-family:var(--f-italic);font-style:italic;font-size:18px;line-height:1.3;max-width:62%}
.hero-float-r{
  display:inline-flex;align-items:center;gap:8px;
  padding:10px 14px;border-radius:var(--r-pill);
  background:rgba(255,255,255,.92);color:var(--deep-ocean-2);font-weight:700;font-size:13px;
}
.hero-float-r .ar{font-family:var(--f-mono);transition:transform .3s var(--ease-out)}
.hero-float-r:hover .ar{transform:translateX(4px)}

.hero-deco-num{
  position:absolute;font-family:var(--f-serif);font-style:italic;
  font-size:clamp(72px,16vw,200px);font-weight:300;color:var(--warm-gold);opacity:.2;
  top:-30px;right:-10px;line-height:.8;pointer-events:none;
}

/* === Ticker === */
.ticker-strip{
  background:var(--deep-ocean);color:var(--cream);
  padding:18px 0;overflow:hidden;
  border-top:1px solid rgba(232,181,96,.2);
  border-bottom:1px solid rgba(232,181,96,.2);
}
.ticker-strip .ticker span{
  display:inline-flex;align-items:center;gap:14px;
  font-family:var(--f-italic);font-style:italic;font-size:clamp(20px,2.4vw,32px);
  font-weight:400;letter-spacing:-.005em;
  color:var(--warm-gold);
}
.ticker-strip .ticker span::after{
  content:"✦";color:var(--coral);font-size:.7em;margin-left:14px;
}

/* === Category big grid === */
.cat-grid{
  display:grid;
  grid-template-columns:1fr;
  gap:18px;
}
@media(min-width:760px){
  .cat-grid{
    grid-template-columns:repeat(6,1fr);
    grid-auto-rows:minmax(180px,auto);
    gap:18px;
  }
  .cat-card.x-large{grid-column:span 4;grid-row:span 2}
  .cat-card.medium{grid-column:span 2;grid-row:span 1}
  .cat-card.wide{grid-column:span 3;grid-row:span 1}
}
.cat-card{
  position:relative;overflow:hidden;border-radius:var(--r-lg);
  background:var(--surface);box-shadow:var(--sh-1);
  isolation:isolate;
  transition:transform .35s var(--ease-out),box-shadow .35s var(--ease-out);
  min-height:200px;
  display:flex;flex-direction:column;justify-content:flex-end;
  padding:22px;color:#fff;
}
.cat-card:hover{transform:translateY(-4px);box-shadow:var(--sh-3)}
.cat-card .bg{position:absolute;inset:0;z-index:-2;background-color:var(--deep-ocean);background-size:cover;background-position:center;transition:transform .8s var(--ease-out)}
.cat-card .bg::after{content:"";position:absolute;inset:0;background:linear-gradient(135deg,var(--deep-ocean),var(--jungle));mix-blend-mode:multiply;opacity:.45}
.cat-card:hover .bg{transform:scale(1.06)}
.cat-card::before{
  content:"";position:absolute;inset:0;z-index:-1;
  background:linear-gradient(180deg,rgba(15,37,56,.05) 30%,rgba(15,37,56,.85));
}
.cat-card .num{
  font-family:var(--f-serif);font-style:italic;font-weight:300;
  font-size:clamp(28px,3vw,44px);color:var(--warm-gold);line-height:1;
  position:absolute;top:18px;left:22px;
}
.cat-card .pin{
  position:absolute;top:18px;right:18px;
  font-family:var(--f-mono);font-size:11px;letter-spacing:.12em;text-transform:uppercase;
  background:rgba(255,255,255,.16);backdrop-filter:blur(8px);
  -webkit-backdrop-filter:blur(8px);
  padding:4px 10px;border-radius:var(--r-pill);color:#fff;
}
.cat-card h3{
  font-size:clamp(22px,2.2vw,32px);font-weight:800;letter-spacing:-.02em;line-height:1.05;
}
.cat-card .tags{display:flex;gap:6px;flex-wrap:wrap;margin-top:10px}
.cat-card .tags li{
  font-size:12px;padding:3px 9px;border-radius:var(--r-pill);
  background:rgba(255,255,255,.16);backdrop-filter:blur(6px);
  -webkit-backdrop-filter:blur(6px);
}
.cat-card .arrow{
  position:absolute;bottom:22px;right:22px;
  width:42px;height:42px;border-radius:50%;
  background:var(--warm-gold);color:var(--deep-ocean-2);
  display:grid;place-items:center;font-size:18px;
  transition:transform .3s var(--ease-out);
}
.cat-card:hover .arrow{transform:translate(4px,-4px)}

/* === Curated product cards === */
.curated-row{
  display:grid;gap:20px;
  grid-template-columns:1fr;
}
@media(min-width:680px){.curated-row{grid-template-columns:repeat(2,1fr)}}
@media(min-width:1024px){.curated-row{grid-template-columns:repeat(4,1fr)}}
@media(min-width:1280px){.curated-row{grid-template-columns:1.4fr 1fr 1fr 1fr}}
.product-card{
  background:var(--surface);border-radius:var(--r-lg);overflow:hidden;
  border:1px solid var(--line-soft);
  transition:transform .3s var(--ease-out),box-shadow .3s var(--ease-out);
  display:flex;flex-direction:column;
}
.product-card:hover{transform:translateY(-3px);box-shadow:var(--sh-2);border-color:var(--warm-gold)}
.product-card .thumb{aspect-ratio:4/3;position:relative;overflow:hidden}
.product-card .thumb img{width:100%;height:100%;object-fit:cover;transition:transform .6s var(--ease-out)}
.product-card:hover .thumb img{transform:scale(1.04)}
.product-card .badge{
  position:absolute;top:12px;left:12px;
  background:var(--coral);color:#fff;
  font-size:11.5px;font-weight:700;padding:5px 10px;border-radius:var(--r-pill);
}
.product-card .body{padding:18px 20px 20px;display:flex;flex-direction:column;gap:8px;flex:1}
.product-card .cat{font-family:var(--f-mono);font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--warm-gold-deep)}
.product-card h4{font-size:18px;font-weight:700;letter-spacing:-.01em;line-height:1.25}
.product-card .meta{display:flex;align-items:center;gap:10px;color:var(--ink-2);font-size:13px;margin-top:auto}
.product-card .meta .star{color:var(--warm-gold-deep);font-weight:700}
.product-card .price{display:flex;align-items:baseline;gap:6px;font-size:18px;font-weight:800;color:var(--deep-ocean);margin-top:8px}
.product-card .price small{font-size:12px;font-weight:500;color:var(--ink-2)}
.product-card .price del{font-size:13px;font-weight:500;color:var(--ink-2);opacity:.6}

/* === Tip magazine === */
.tip-grid{
  display:grid;gap:24px;grid-template-columns:1fr;
}
@media(min-width:900px){.tip-grid{grid-template-columns:1.3fr 1fr 1fr;align-items:start}}
.tip-card{
  background:var(--surface);border-radius:var(--r-lg);overflow:hidden;
  border:1px solid var(--line-soft);
  display:flex;flex-direction:column;
  transition:transform .3s var(--ease-out),box-shadow .3s var(--ease-out);
}
.tip-card:hover{transform:translateY(-3px);box-shadow:var(--sh-2)}
.tip-card .thumb{aspect-ratio:16/10;background-color:var(--surface-warm);background-size:cover;background-position:center}
.tip-card.featured .thumb{aspect-ratio:4/5}
.tip-card .body{padding:24px 26px 28px;display:flex;flex-direction:column;gap:12px;flex:1}
.tip-card .cat{font-family:var(--f-mono);font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--coral)}
.tip-card h4{font-size:clamp(18px,1.6vw,22px);font-weight:700;line-height:1.3;letter-spacing:-.01em}
.tip-card.featured h4{font-size:clamp(24px,2.2vw,32px);line-height:1.15}
.tip-card p{color:var(--ink-2);font-size:14.5px;line-height:1.6}
.tip-card .by{display:flex;align-items:center;gap:10px;margin-top:auto;font-size:13px;color:var(--ink-2)}
.tip-card .av{width:30px;height:30px;border-radius:50%;background:var(--warm-gold);display:grid;place-items:center;color:#fff;font-weight:700;font-size:12px}

/* === Reviews / community === */
.reviews-grid{
  columns:1 280px;column-gap:18px;
}
@media(min-width:600px){.reviews-grid{columns:2 280px}}
@media(min-width:1024px){.reviews-grid{columns:3 280px}}
.review-card{
  break-inside:avoid;background:var(--surface);
  border-radius:var(--r-md);padding:22px 22px 20px;
  border:1px solid var(--line-soft);
  margin-bottom:18px;display:flex;flex-direction:column;gap:12px;
  transition:transform .25s var(--ease-out),border-color .25s var(--ease-out);
}
.review-card:hover{transform:translateY(-2px);border-color:var(--warm-gold)}
.review-card .head{display:flex;align-items:center;gap:12px}
.review-card .av{
  width:42px;height:42px;border-radius:50%;
  background:linear-gradient(135deg,var(--warm-gold),var(--coral));
  display:grid;place-items:center;color:#fff;font-weight:800;font-size:14px;
}
.review-card .who{display:flex;flex-direction:column}
.review-card .who b{font-size:14px}
.review-card .who span{font-size:12px;color:var(--ink-2)}
.review-card .stars{color:var(--warm-gold-deep);letter-spacing:2px;margin-left:auto;font-size:14px}
.review-card .title{font-size:16px;font-weight:700;letter-spacing:-.01em;line-height:1.3}
.review-card .text{color:var(--ink-2);font-size:14.5px;line-height:1.6}
.review-card .meta{display:flex;gap:14px;color:var(--ink-2);font-size:12px;font-family:var(--f-mono);letter-spacing:.05em;margin-top:4px}

/* === Big CTA === */
.cta-band{
  position:relative;border-radius:var(--r-xl);overflow:hidden;
  padding:clamp(48px,7vw,96px) clamp(28px,5vw,64px);
  background:var(--deep-ocean);color:var(--cream);
  isolation:isolate;
}
.cta-band::before{
  content:"";position:absolute;inset:0;z-index:-1;
  background:
    radial-gradient(700px 400px at 90% 10%,rgba(232,181,96,.32),transparent 60%),
    radial-gradient(500px 320px at 0% 100%,rgba(255,107,91,.2),transparent 60%);
}
.cta-band h2{
  font-size:clamp(32px,4vw,56px);font-weight:800;letter-spacing:-.02em;line-height:1.05;
}
.cta-band h2 em{font-family:var(--f-italic);font-style:italic;font-weight:400;color:var(--warm-gold)}
.cta-band p{margin-top:18px;font-size:16px;color:rgba(255,249,238,.78);max-width:520px;line-height:1.6}
.cta-band .actions{display:flex;flex-wrap:wrap;gap:12px;margin-top:32px}
.cta-band .num{
  position:absolute;top:24px;right:32px;
  font-family:var(--f-italic);font-style:italic;
  font-size:clamp(80px,12vw,180px);color:var(--warm-gold);opacity:.18;font-weight:300;line-height:.8;
}

/* === Footer === */
.site-footer{
  background:var(--deep-ocean-2);color:rgba(255,249,238,.72);
  padding:64px 0 32px;margin-top:0;
}
.foot-grid{
  display:grid;gap:32px;
  grid-template-columns:1fr;
}
@media(min-width:760px){.foot-grid{grid-template-columns:1.4fr repeat(3,1fr)}}
.site-footer h5{color:var(--cream);font-size:13px;letter-spacing:.06em;margin-bottom:14px;font-weight:700;text-transform:uppercase;font-family:var(--f-mono)}
.site-footer ul li{padding:5px 0;font-size:14px}
.site-footer ul li a:hover{color:var(--warm-gold)}
.site-footer .brand{color:var(--cream);font-size:22px;margin-bottom:12px}
.foot-bottom{
  border-top:1px solid rgba(232,181,96,.18);
  margin-top:48px;padding-top:24px;
  display:flex;justify-content:space-between;flex-wrap:wrap;gap:16px;
  font-size:12px;font-family:var(--f-mono);letter-spacing:.05em;color:rgba(255,249,238,.5);
}

/* === Floating chat (mobile-friendly) === */
.fab-chat{
  position:fixed;bottom:20px;right:20px;z-index:60;
  display:inline-flex;align-items:center;gap:10px;
  padding:14px 20px;border-radius:var(--r-pill);
  background:#FEE500;color:#181600;font-weight:700;
  box-shadow:0 18px 36px -10px rgba(0,0,0,.3);
  transition:transform .25s var(--ease-out);
}
.fab-chat:hover{transform:translateY(-2px)}
@media(min-width:980px){.fab-chat{bottom:32px;right:32px}}
