/* =========================================================
   Fun Coffee — Campaign page
   ========================================================= */

/* ---------- HERO ---------- */
.cmp-hero{
  position:relative;
  min-height:560px;
  background:
    linear-gradient(120deg, rgba(42,31,23,.85) 0%, rgba(42,31,23,.65) 50%, rgba(201,123,63,.55) 100%),
    url('https://images.unsplash.com/photo-1442550528053-c431ecb55509?w=1800&q=80') center/cover no-repeat;
  color:#fff;
  display:flex;
  align-items:center;
  overflow:hidden;
}
.cmp-hero::before,
.cmp-hero::after{
  content:"";
  position:absolute;
  border-radius:50%;
  pointer-events:none;
}
.cmp-hero::before{
  width:520px;height:520px;
  background:radial-gradient(circle, rgba(255,215,150,.18) 0%, transparent 70%);
  top:-200px;right:-200px;
}
.cmp-hero::after{
  width:380px;height:380px;
  background:radial-gradient(circle, rgba(255,180,90,.16) 0%, transparent 70%);
  bottom:-200px;left:-100px;
}
.cmp-hero-inner{
  max-width:1280px;
  margin:0 auto;
  padding:60px 24px;
  position:relative;
  z-index:1;
  width:100%;
}
.cmp-hero-label{
  display:inline-block;
  background:#fff;
  color:var(--c-coffee-900);
  font-size:11px;
  font-weight:700;
  letter-spacing:.2em;
  padding:6px 14px;
  border-radius:999px;
  margin-bottom:18px;
}
.cmp-hero-title{
  font-family:var(--font-serif);
  font-size:64px;
  font-weight:600;
  line-height:1.15;
  letter-spacing:.01em;
  margin-bottom:18px;
}
.cmp-hero-title em{
  font-style:normal;
  color:#ffd8a8;
}
.cmp-hero-sub{
  font-size:16px;
  line-height:1.9;
  color:#f0e6d6;
  margin-bottom:36px;
  max-width:580px;
}
.cmp-hero-period{
  display:inline-block;
  font-family:var(--font-sans);
  font-size:13px;
  letter-spacing:.08em;
  background:rgba(255,255,255,.12);
  border:1px solid rgba(255,255,255,.25);
  padding:8px 16px;
  border-radius:6px;
  margin-bottom:28px;
}

/* Countdown */
.countdown{
  display:flex;
  gap:14px;
  margin-bottom:32px;
}
.cd-cell{
  background:rgba(255,255,255,.1);
  backdrop-filter:blur(4px);
  border:1px solid rgba(255,255,255,.2);
  border-radius:8px;
  padding:14px 18px;
  text-align:center;
  min-width:80px;
}
.cd-num{
  font-family:var(--font-sans);
  font-size:36px;
  font-weight:700;
  line-height:1;
  letter-spacing:-.02em;
  color:#fff;
}
.cd-label{
  font-size:10px;
  letter-spacing:.2em;
  margin-top:4px;
  color:#f0d4a8;
  text-transform:uppercase;
}

.cmp-hero-cta{display:flex;gap:12px;flex-wrap:wrap}

/* ---------- Active campaigns grid ---------- */
.cmp-section{padding:80px 0;background:var(--c-bg)}
.cmp-section-alt{background:var(--c-bg-alt)}
.cmp-section .container{position:relative}

.cmp-grid{
  display:grid;
  grid-template-columns:repeat(2, 1fr);
  gap:24px;
}

.cmp-card{
  background:#fff;
  border-radius:var(--radius-lg);
  overflow:hidden;
  box-shadow:var(--shadow-sm);
  display:flex;
  flex-direction:column;
  position:relative;
  transition:transform .2s, box-shadow .2s;
}
.cmp-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-md)}

.cmp-card-img{
  aspect-ratio:16/9;
  background-size:cover;
  background-position:center;
  position:relative;
  overflow:hidden;
}
.cmp-card-img::before{
  content:"";
  position:absolute;inset:0;
  background:linear-gradient(180deg, rgba(0,0,0,0) 30%, rgba(0,0,0,.55) 100%);
}
.cmp-card-tag{
  position:absolute;top:14px;left:14px;
  padding:5px 12px;
  border-radius:4px;
  font-size:11px;
  font-weight:700;
  letter-spacing:.1em;
  background:#fff;
  color:var(--c-coffee-900);
  z-index:2;
}
.cmp-card-tag.hot{
  background:var(--c-red);
  color:#fff;
}
.cmp-card-tag.new{
  background:var(--c-coffee-900);
  color:#fff;
}
.cmp-card-deal{
  position:absolute;
  right:-26px;
  bottom:14px;
  background:var(--c-accent);
  color:#fff;
  padding:6px 30px;
  font-family:var(--font-serif);
  font-size:20px;
  font-weight:700;
  letter-spacing:.02em;
  transform:rotate(-3deg);
  z-index:2;
  box-shadow:0 4px 12px rgba(201,123,63,.4);
}
.cmp-card-deal small{font-size:12px;font-weight:500;display:block;text-align:center;margin-top:-2px}

.cmp-card-body{
  padding:24px 26px 28px;
  flex:1;
  display:flex;
  flex-direction:column;
}
.cmp-card-period{
  font-family:var(--font-sans);
  font-size:11px;
  color:var(--c-muted);
  letter-spacing:.1em;
  margin-bottom:8px;
}
.cmp-card-title{
  font-family:var(--font-serif);
  font-size:24px;
  font-weight:600;
  color:var(--c-coffee-900);
  line-height:1.3;
  margin-bottom:10px;
}
.cmp-card-desc{
  font-size:13px;
  line-height:1.8;
  color:var(--c-coffee-700);
  margin-bottom:18px;
  flex:1;
}
.cmp-card-points{
  list-style:none;
  padding:0;
  margin:0 0 20px;
}
.cmp-card-points li{
  font-size:13px;
  color:var(--c-coffee-800);
  padding:5px 0 5px 22px;
  position:relative;
  line-height:1.6;
}
.cmp-card-points li::before{
  content:"";
  position:absolute;
  left:0;top:9px;
  width:14px;height:8px;
  border-left:2px solid var(--c-accent);
  border-bottom:2px solid var(--c-accent);
  transform:rotate(-45deg);
}
.cmp-card-cta{
  display:flex;
  gap:10px;
  align-items:center;
}

/* Sub campaigns row (smaller cards) */
.cmp-mini-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:18px;
}
.cmp-mini{
  background:#fff;
  border:1px solid var(--c-line);
  border-radius:var(--radius);
  padding:24px 22px;
  display:flex;
  flex-direction:column;
  gap:12px;
  position:relative;
  overflow:hidden;
}
.cmp-mini::before{
  content:"";
  position:absolute;
  width:120px;height:120px;
  border-radius:50%;
  top:-50px;right:-50px;
  background:var(--c-coffee-50);
  z-index:0;
}
.cmp-mini > *{position:relative;z-index:1}
.cmp-mini-icon{
  width:42px;height:42px;
  border-radius:8px;
  background:var(--c-coffee-900);
  color:#fff;
  display:flex;align-items:center;justify-content:center;
  font-size:20px;
  flex-shrink:0;
}
.cmp-mini-icon.accent{background:var(--c-accent)}
.cmp-mini-icon.green{background:var(--c-green)}
.cmp-mini-icon.red{background:var(--c-red)}
.cmp-mini h4{
  font-family:var(--font-serif);
  font-size:18px;
  font-weight:600;
  color:var(--c-coffee-900);
  line-height:1.3;
}
.cmp-mini p{
  font-size:12.5px;
  color:var(--c-coffee-700);
  line-height:1.7;
  flex:1;
}
.cmp-mini .pct{
  font-family:var(--font-sans);
  font-size:11px;
  font-weight:700;
  letter-spacing:.05em;
  color:var(--c-accent);
}

/* ---------- Bundle deals ---------- */
.bundle{
  padding:80px 0;
  background:var(--c-coffee-50);
}
.bundle-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:24px;
}
.bundle-card{
  background:#fff;
  border-radius:var(--radius-lg);
  overflow:hidden;
  position:relative;
  transition:transform .2s;
}
.bundle-card:hover{transform:translateY(-4px)}
.bundle-card.featured{
  border:2px solid var(--c-accent);
  box-shadow:0 12px 32px rgba(201,123,63,.15);
}
.bundle-saving{
  position:absolute;
  top:16px;right:16px;
  background:var(--c-red);
  color:#fff;
  padding:6px 12px;
  border-radius:99px;
  font-size:12px;
  font-weight:700;
  letter-spacing:.05em;
  z-index:2;
  box-shadow:0 4px 10px rgba(200,74,58,.3);
}
.bundle-img{
  aspect-ratio:4/3;
  background:var(--c-coffee-50);
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:2px;
}
.bundle-img > div{
  background-size:cover;
  background-position:center;
}
.bundle-body{padding:22px}
.bundle-body h4{
  font-family:var(--font-serif);
  font-size:20px;
  color:var(--c-coffee-900);
  margin-bottom:10px;
  line-height:1.3;
  font-weight:600;
}
.bundle-items{
  list-style:none;padding:0;margin:0 0 16px;
}
.bundle-items li{
  font-size:12px;
  color:var(--c-coffee-700);
  padding:4px 0 4px 18px;
  position:relative;
  line-height:1.5;
}
.bundle-items li::before{
  content:"+";
  position:absolute;left:0;top:3px;
  color:var(--c-accent);
  font-weight:700;
}
.bundle-items li:first-child::before{content:"";}
.bundle-price{
  display:flex;
  align-items:baseline;
  gap:10px;
  margin-bottom:16px;
  padding-top:14px;
  border-top:1px dashed var(--c-line);
}
.bundle-old{
  font-size:14px;
  color:var(--c-muted);
  text-decoration:line-through;
}
.bundle-new{
  font-family:var(--font-sans);
  font-size:26px;
  font-weight:700;
  color:var(--c-red);
  letter-spacing:-.02em;
}
.bundle-new small{font-size:12px;color:var(--c-muted);font-weight:400;margin-left:4px}

/* ---------- SNS / Instagram giveaway ---------- */
.sns-giveaway{
  padding:80px 0;
  background:linear-gradient(135deg, #FF6B6B 0%, #FFA94D 50%, #FFD380 100%);
  color:#fff;
  position:relative;
  overflow:hidden;
}
.sns-giveaway::before{
  content:"";
  position:absolute;
  inset:0;
  background:url("data:image/svg+xml,%3Csvg width='80' height='80' viewBox='0 0 80 80' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M0 0h40v40H0zM40 40h40v40H40z' fill='%23ffffff' fill-opacity='.04'/%3E%3C/svg%3E");
}
.sns-giveaway .container{position:relative;z-index:1}
.sns-inner{
  display:grid;
  grid-template-columns:1.2fr 1fr;
  gap:48px;
  align-items:center;
}
.sns-text .sns-tag{
  display:inline-block;
  background:rgba(255,255,255,.25);
  color:#fff;
  font-size:11px;letter-spacing:.2em;
  padding:5px 14px;
  border-radius:99px;
  margin-bottom:16px;
}
.sns-text h2{
  font-family:var(--font-serif);
  font-size:42px;
  font-weight:600;
  line-height:1.2;
  margin-bottom:16px;
}
.sns-text h2 .big{font-size:54px;display:block}
.sns-text p{
  font-size:14px;
  line-height:1.9;
  margin-bottom:24px;
}
.sns-steps{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:14px;
  margin-bottom:28px;
}
.sns-step{
  background:rgba(255,255,255,.15);
  border:1px solid rgba(255,255,255,.3);
  border-radius:8px;
  padding:14px;
  text-align:center;
}
.sns-step-num{
  font-family:var(--font-serif);
  font-size:24px;
  font-weight:700;
  display:block;
  margin-bottom:4px;
}
.sns-step-text{font-size:11px;line-height:1.5}
.sns-prize{
  background:#fff;
  color:var(--c-coffee-900);
  border-radius:var(--radius-lg);
  padding:28px;
  text-align:center;
  box-shadow:0 12px 40px rgba(0,0,0,.15);
}
.sns-prize-title{
  font-family:var(--font-sans);
  font-size:11px;letter-spacing:.3em;
  color:var(--c-accent);
  text-transform:uppercase;
  margin-bottom:10px;
}
.sns-prize-name{
  font-family:var(--font-serif);
  font-size:26px;
  font-weight:600;
  margin-bottom:6px;
  line-height:1.3;
}
.sns-prize-count{
  font-family:var(--font-sans);
  font-size:36px;
  font-weight:700;
  color:var(--c-accent);
  margin:6px 0;
  letter-spacing:-.02em;
}
.sns-prize-img{
  aspect-ratio:1/1;
  margin:14px auto 0;
  max-width:200px;
  background:var(--c-coffee-50);
  border-radius:50%;
  overflow:hidden;
}
.sns-prize-img img{width:100%;height:100%;object-fit:cover}

.sns-tag-text{
  font-family:monospace;
  background:rgba(255,255,255,.18);
  padding:3px 10px;
  border-radius:4px;
  font-size:13px;
  margin:0 4px;
}

/* ---------- Repeater rewards ---------- */
.repeater{
  padding:64px 0;
  background:var(--c-coffee-50);
}
.repeater-inner{
  background:#fff;
  border-radius:var(--radius-lg);
  padding:40px;
  display:grid;
  grid-template-columns:1fr 1.4fr;
  gap:40px;
  align-items:center;
  box-shadow:var(--shadow-sm);
}
.repeater-img{
  aspect-ratio:4/5;
  background:var(--c-coffee-50);
  border-radius:var(--radius);
  overflow:hidden;
}
.repeater-img img{width:100%;height:100%;object-fit:cover}
.repeater-text h3{
  font-family:var(--font-serif);
  font-size:32px;
  color:var(--c-coffee-900);
  margin-bottom:8px;
  font-weight:600;
}
.repeater-text > p{
  font-size:14px;color:var(--c-coffee-700);
  line-height:1.8;margin-bottom:24px;
}
.tier-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:12px;
  margin-bottom:24px;
}
.tier{
  background:var(--c-coffee-50);
  border-radius:8px;
  padding:16px 14px;
  text-align:center;
  position:relative;
}
.tier.gold{
  background:linear-gradient(135deg, #d4af3733 0%, #ffe39933 100%);
  border:1px solid #d4af37;
}
.tier-name{
  font-family:var(--font-serif);
  font-size:16px;
  font-weight:600;
  color:var(--c-coffee-900);
  margin-bottom:4px;
}
.tier-condition{
  font-size:10px;letter-spacing:.05em;
  color:var(--c-muted);
  margin-bottom:8px;
}
.tier-back{
  font-family:var(--font-sans);
  font-size:22px;
  font-weight:700;
  color:var(--c-coffee-900);
  line-height:1;
}
.tier-back small{font-size:11px;color:var(--c-muted);font-weight:400;margin-left:2px}

/* ---------- FAQ ---------- */
.cmp-faq{padding:64px 0;background:var(--c-bg)}
.cmp-faq .container{max-width:880px}
.faq-item{
  border-bottom:1px solid var(--c-line);
  padding:18px 0;
}
.faq-q{
  display:flex;
  align-items:center;
  gap:14px;
  cursor:pointer;
  font-weight:600;
  color:var(--c-coffee-900);
  font-size:15px;
}
.faq-q::before{
  content:"Q";
  font-family:var(--font-serif);
  font-size:24px;
  color:var(--c-accent);
  width:32px;
  flex-shrink:0;
}
.faq-q::after{
  content:"+";
  margin-left:auto;
  font-size:22px;
  font-weight:300;
  color:var(--c-muted);
  transition:transform .2s;
}
.faq-item.open .faq-q::after{transform:rotate(45deg)}
.faq-a{
  display:none;
  padding:14px 0 0 46px;
  font-size:13px;
  line-height:1.9;
  color:var(--c-coffee-700);
}
.faq-item.open .faq-a{display:block}

/* ---------- Responsive ---------- */
@media(max-width:1024px){
  .cmp-hero-title{font-size:42px}
  .cmp-grid{grid-template-columns:1fr}
  .cmp-mini-grid{grid-template-columns:1fr 1fr}
  .bundle-grid{grid-template-columns:1fr;max-width:480px;margin:0 auto}
  .sns-inner{grid-template-columns:1fr;gap:32px}
  .sns-text h2{font-size:32px}
  .sns-text h2 .big{font-size:40px}
  .repeater-inner{grid-template-columns:1fr;padding:24px}
  .repeater-img{aspect-ratio:16/9;max-width:none}
}
@media(max-width:768px){
  .cmp-hero{min-height:480px}
  .cmp-hero-inner{padding:40px 16px}
  .cmp-hero-title{font-size:30px}
  .cmp-hero-sub{font-size:13px}
  .countdown{gap:8px}
  .cd-cell{padding:10px 6px;min-width:64px}
  .cd-num{font-size:24px}
  .cmp-section{padding:48px 0}
  .cmp-mini-grid{grid-template-columns:1fr}
  .cmp-card-body{padding:20px}
  .cmp-card-title{font-size:20px}
  .bundle{padding:48px 0}
  .sns-giveaway{padding:48px 0}
  .sns-text h2{font-size:24px}
  .sns-text h2 .big{font-size:32px}
  .sns-steps{grid-template-columns:1fr 1fr 1fr;gap:6px}
  .sns-step{padding:10px 6px}
  .sns-prize{padding:20px}
  .repeater{padding:48px 0}
  .repeater-text h3{font-size:24px}
  .tier-grid{grid-template-columns:1fr;gap:8px}
  .tier{display:flex;align-items:center;text-align:left;gap:14px}
  .tier-name{margin-bottom:0}
}
