/* ═══════════════════════════════════════════════════════════
   FEATURES.CSS — Shared styles for all feature pages
   ═══════════════════════════════════════════════════════════ */

/* ── Steps ── */
.feat-steps { display:grid; grid-template-columns:repeat(4,1fr); gap:20px; }
@media(max-width:860px){ .feat-steps{grid-template-columns:repeat(2,1fr)} }
@media(max-width:480px){ .feat-steps{grid-template-columns:1fr} }
.feat-step { background:var(--card); border:1px solid var(--line); border-radius:var(--radius); padding:28px; position:relative; box-shadow:var(--shadow-sm); }
.step-num { position:absolute; top:16px; right:16px; font-family:var(--serif); font-size:36px; color:var(--line2); line-height:1; }
.step-icon { font-size:36px; margin-bottom:16px; }
.feat-step h3 { font-family:var(--serif); font-weight:500; font-size:18px; margin-bottom:10px; color:var(--ink); }
.feat-step p  { font-size:14px; color:var(--ink2); line-height:1.6; }

/* ── CTA box ── */
.feat-cta-box { background:linear-gradient(145deg,#1a3a28,#0d2519); border:1px solid rgba(184,137,42,.25); border-radius:24px; padding:52px 48px; text-align:center; position:relative; overflow:hidden; }
.feat-cta-box::before { content:''; position:absolute; inset:0; background:radial-gradient(ellipse 60% 60% at 80% 50%,rgba(201,168,76,.12),transparent); }
.feat-cta-box .pred-h, .feat-cta-box h2 { color:#fff; position:relative; z-index:1; }
.feat-cta-box p { position:relative; z-index:1; }
.feat-cta-box .btn-primary, .feat-cta-box .btn-ghost { position:relative; z-index:1; }
@media(max-width:600px){ .feat-cta-box{padding:36px 24px} }

/* ── Sticker cards ── */
.sticker-grid { display:grid; grid-template-columns:repeat(6,1fr); gap:14px; margin-top:32px; }
@media(max-width:1000px){ .sticker-grid{grid-template-columns:repeat(3,1fr)} }
@media(max-width:560px){  .sticker-grid{grid-template-columns:repeat(2,1fr)} }
.sticker-card { border-radius:var(--radius); padding:20px 16px; text-align:center; position:relative; overflow:hidden; cursor:pointer; border:2px solid transparent; transition:transform .2s, box-shadow .2s; }
.sticker-card:hover { transform:translateY(-5px) rotate(-1deg); }
.sticker-shine { position:absolute; inset:0; background:linear-gradient(135deg,rgba(255,255,255,.12) 0%,transparent 60%); pointer-events:none; }
.sticker-rarity { font-size:10px; font-weight:800; letter-spacing:.06em; text-transform:uppercase; margin-bottom:12px; opacity:.85; }
.sticker-flag { font-size:44px; margin-bottom:10px; display:block; filter:drop-shadow(0 2px 8px rgba(0,0,0,.3)); }
.sticker-name { font-family:var(--serif); font-weight:500; font-size:15px; color:#fff; margin-bottom:4px; }
.sticker-sub  { font-size:10px; color:rgba(255,255,255,.6); }
.sticker-card.bronze  { background:linear-gradient(145deg,#3d2200,#5a3500); border-color:#b87333; box-shadow:0 4px 20px rgba(184,115,51,.3); }
.sticker-card.silver  { background:linear-gradient(145deg,#1a2a3a,#2a3a4a); border-color:#c0c8d4; box-shadow:0 4px 20px rgba(192,200,212,.2); }
.sticker-card.gold    { background:linear-gradient(145deg,#2a1a00,#3a2800); border-color:var(--gold); box-shadow:0 4px 24px rgba(201,168,76,.35); }
.sticker-card.legendary { background:linear-gradient(145deg,#1a0a3a,#2a1050); border-color:#9b59b6; box-shadow:0 4px 28px rgba(155,89,182,.4); animation:legend-pulse 3s ease-in-out infinite; }
.sticker-card.ultra { background:linear-gradient(145deg,#0a2a3a,#0d3a4a); border-color:#1fc585; box-shadow:0 4px 28px rgba(31,197,133,.4); }
@keyframes legend-pulse { 0%,100%{box-shadow:0 4px 28px rgba(155,89,182,.4)} 50%{box-shadow:0 8px 40px rgba(155,89,182,.7)} }

/* ── Passport visual ── */
.passport-visual { display:flex; justify-content:center; margin-top:56px; }
.passport-book { display:flex; gap:0; box-shadow:0 24px 60px rgba(0,0,0,.25); border-radius:12px; overflow:hidden; max-width:600px; width:100%; }
.passport-cover { background:linear-gradient(145deg,#1a3a28,#0d2519); width:200px; flex-shrink:0; padding:32px 24px; display:flex; flex-direction:column; align-items:center; justify-content:center; gap:12px; text-align:center; }
.passport-emblem { font-size:40px; }
.passport-title  { font-family:var(--serif); font-size:13px; color:var(--gold2); letter-spacing:.12em; text-transform:uppercase; }
.passport-subtitle { font-size:11px; color:rgba(255,255,255,.55); }
.passport-edition  { font-size:10px; color:rgba(255,255,255,.4); letter-spacing:.06em; }
.passport-pages { background:var(--card); flex:1; padding:24px; }
.stamp-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:10px; }
.passport-stamp { background:var(--deep); border:1.5px dashed var(--line2); border-radius:8px; padding:12px 8px; text-align:center; font-size:18px; color:var(--ink3); font-size:11px; line-height:1.4; }
.passport-stamp.stamped { border-color:var(--gold); background:rgba(184,137,42,.08); color:var(--ink); }
.passport-stamp.stamped small { color:var(--gold); }
@media(max-width:600px){ .passport-book{flex-direction:column} .passport-cover{width:100%;padding:24px} }

/* ── Poster builder ── */
.poster-builder { display:grid; grid-template-columns:1fr 1fr; gap:32px; }
@media(max-width:760px){ .poster-builder{grid-template-columns:1fr} }
.poster-controls { background:var(--card); border:1px solid var(--line); border-radius:var(--radius); padding:28px; }
.poster-field { margin-bottom:18px; }
.poster-field label { display:block; font-size:12px; font-weight:700; letter-spacing:.06em; text-transform:uppercase; color:var(--ink3); margin-bottom:8px; }
.poster-select, .poster-input { width:100%; padding:11px 14px; border:1.5px solid var(--line2); border-radius:var(--radius-sm); background:var(--deep); color:var(--ink); font-size:14px; font-family:var(--sans); outline:none; transition:border-color .2s; }
.poster-select:focus, .poster-input:focus { border-color:var(--gold); }
.poster-input::placeholder { color:var(--ink3); }
.style-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:8px; }
.style-btn { padding:8px; border-radius:var(--radius-sm); border:1.5px solid var(--line2); background:var(--deep); color:var(--ink2); font-size:13px; font-weight:600; cursor:pointer; transition:all .15s; }
.style-btn:hover, .style-btn.active { border-color:var(--gold); color:var(--gold); background:rgba(184,137,42,.08); }
.poster-preview { display:flex; flex-direction:column; gap:12px; }
.poster-canvas { aspect-ratio:1; background:var(--deep); border:1.5px solid var(--line); border-radius:var(--radius); overflow:hidden; display:flex; align-items:center; justify-content:center; }
.poster-placeholder { text-align:center; color:var(--ink3); }
.poster-placeholder p { margin-top:12px; font-size:14px; }

/* ── Scoring table ── */
.score-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:16px; }
@media(max-width:700px){ .score-grid{grid-template-columns:1fr 1fr} }
@media(max-width:480px){ .score-grid{grid-template-columns:1fr} }
.score-item { background:var(--card); border:1px solid var(--line); border-radius:var(--radius-sm); padding:20px; text-align:center; }
.score-pts  { font-family:var(--serif); font-size:30px; font-weight:400; margin-bottom:8px; }
.score-label { font-size:13px; color:var(--ink2); }

/* ── Brand tiers ── */
.brand-stats { display:grid; grid-template-columns:repeat(4,1fr); gap:16px; margin-bottom:8px; }
@media(max-width:700px){ .brand-stats{grid-template-columns:repeat(2,1fr)} }
.brand-stat { background:var(--card); border:1px solid var(--line); border-radius:var(--radius-sm); padding:20px; text-align:center; }
.brand-stat-num { font-family:var(--serif); font-size:36px; line-height:1; }
.brand-stat-lbl { font-size:12px; color:var(--ink2); margin-top:6px; line-height:1.5; }
.brand-stat-lbl small { color:var(--ink3); font-size:11px; }
.brand-tiers { display:grid; grid-template-columns:repeat(3,1fr); gap:20px; margin-top:32px; }
@media(max-width:760px){ .brand-tiers{grid-template-columns:1fr} }
.brand-tier { background:var(--card); border:1px solid var(--line); border-radius:var(--radius); padding:28px; position:relative; }
.brand-tier.popular-tier { border-color:var(--gold); box-shadow:0 0 0 1px rgba(184,137,42,.2), var(--shadow-lg); }
.tier-badge { position:absolute; top:-12px; left:50%; transform:translateX(-50%); background:linear-gradient(135deg,var(--gold),var(--gold2)); color:var(--on-gold); font-size:11px; font-weight:800; padding:5px 14px; border-radius:100px; white-space:nowrap; }
.tier-icon { font-size:36px; margin-bottom:14px; }
.brand-tier h3 { font-family:var(--serif); font-weight:500; font-size:20px; color:var(--ink); margin-bottom:10px; }
.brand-tier p  { font-size:14px; color:var(--ink2); margin-bottom:16px; }
.brand-tier ul { list-style:none; display:flex; flex-direction:column; gap:7px; }
.brand-tier li { font-size:13px; color:var(--ink2); }

/* ── Brand contact form ── */
.brand-form { display:grid; grid-template-columns:1fr 1fr; gap:12px; max-width:560px; margin:0 auto; position:relative; z-index:1; }
@media(max-width:560px){ .brand-form{grid-template-columns:1fr} }
.brand-input { padding:12px 16px; border:1.5px solid rgba(255,255,255,.15); border-radius:var(--radius-sm); background:rgba(255,255,255,.08); color:#fff; font-size:14px; font-family:var(--sans); outline:none; transition:border-color .2s; }
.brand-input::placeholder { color:rgba(255,255,255,.35); }
.brand-input:focus { border-color:rgba(255,255,255,.4); }
.brand-textarea { grid-column:1/-1; resize:vertical; }
.brand-form .btn-primary { grid-column:1/-1; }

/* ── Interactive passport stamps ── */
.stamp-counter-bar {
  display: flex; align-items: center; justify-content: space-between;
  margin-bottom: 20px; padding: 10px 16px;
  background: var(--card); border: 1px solid var(--line);
  border-radius: var(--radius-sm);
}
.interactive-stamp-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 12px;
}
@media (max-width: 700px) { .interactive-stamp-grid { grid-template-columns: repeat(3, 1fr); } }
@media (max-width: 480px) { .interactive-stamp-grid { grid-template-columns: repeat(2, 1fr); } }

.interactive-stamp {
  display: flex; flex-direction: column; align-items: center;
  gap: 4px; padding: 14px 10px;
  background: var(--card); border: 2px dashed var(--line2);
  border-radius: var(--radius-sm); cursor: pointer;
  text-align: center; position: relative;
  transition: border-color .2s, background .2s, transform .15s;
  user-select: none;
}
.interactive-stamp:hover { border-color: var(--gold); transform: translateY(-2px); }
.interactive-stamp.stamped {
  border-style: solid;
  border-color: var(--gold);
  background: rgba(184,137,42,.08);
}
.stamp-check {
  position: absolute; top: 6px; right: 8px;
  font-size: 12px; color: var(--gold); font-weight: 800;
}

/* ── Brand form responsive fix in dark CTA ── */
@media (max-width: 560px) {
  .feat-cta-box [style*="grid-template-columns:1fr 1fr"] {
    grid-template-columns: 1fr !important;
  }
}

/* ── Sticker flag size ── */
.sticker-flag { font-size: 40px; display: block; margin: 8px auto 10px; }
