/* ==========================================================================
   home.css — landing page + palettes page (uses Eves brand chrome)
   ========================================================================== */

/* ---------- Landing hero ---------- */
.home-hero {
  position: relative; overflow: hidden;
  background: radial-gradient(120% 130% at 85% -10%, rgba(19, 146, 122, 0.35), transparent 55%),
              linear-gradient(140deg, #0e1526 0%, #14203a 60%, #0e1526 100%);
  color: #fff; padding: 5rem 1.4rem 4rem;
  border-bottom: 1px solid var(--doc-line);
}
.home-hero .wrap { max-width: 1180px; margin: 0 auto; display: grid; grid-template-columns: 1.2fr .8fr; gap: 2.5rem; align-items: center; }
.home-hero .logo-lockup { display: flex; align-items: center; gap: 1rem; margin-bottom: 1.4rem; }
.home-hero .logo-lockup img { width: 64px; height: 64px; }
.home-hero .logo-lockup b { font-family: var(--font-head); font-size: 1.5rem; font-weight: 800; }
.home-hero .logo-lockup span { display: block; color: var(--es-emerald); font-size: .9rem; font-weight: 600; }
.home-hero h1 { font-size: clamp(2.3rem, 5.5vw, 3.8rem); line-height: 1.05; margin-bottom: 1rem; }
.home-hero h1 em { font-style: normal; background: linear-gradient(90deg, #13927a, #4fd1b3); -webkit-background-clip: text; background-clip: text; color: transparent; }
.home-hero p { color: var(--doc-muted); font-size: 1.12rem; max-width: 54ch; margin-bottom: 1.8rem; }
.home-hero .cta-row { display: flex; gap: .8rem; flex-wrap: wrap; }
.home-cta { display: inline-flex; align-items: center; gap: .5rem; font-family: var(--font-head); font-weight: 700; text-decoration: none; padding: .85rem 1.5rem; border-radius: var(--radius-pill); transition: transform var(--dur) var(--ease), box-shadow var(--dur); }
.home-cta.solid { background: var(--es-emerald); color: #06231c; }
.home-cta.outline { background: transparent; color: #fff; border: 1px solid rgba(255,255,255,0.3); }
.home-cta:hover { transform: translateY(-2px); box-shadow: 0 10px 26px rgba(0,0,0,0.35); }

/* Floating logo panel */
.home-hero .visual { display: grid; place-items: center; }
.home-hero .visual .glow {
  width: 100%; max-width: 320px; aspect-ratio: 1; border-radius: 28px;
  background: linear-gradient(145deg, rgba(255,255,255,0.08), rgba(255,255,255,0.02));
  border: 1px solid rgba(255,255,255,0.12); display: grid; place-items: center;
  box-shadow: 0 30px 80px rgba(0,0,0,0.4);
}
.home-hero .visual img { width: 55%; filter: drop-shadow(0 12px 30px rgba(0,0,0,0.45)); }

/* ---------- Section wrappers ---------- */
.home-section { max-width: 1180px; margin: 0 auto; padding: 3.4rem 1.4rem; }
.home-section-head { text-align: center; margin-bottom: 2.2rem; }
.home-section-head .eyebrow { color: var(--es-emerald); font-weight: 700; letter-spacing: .12em; text-transform: uppercase; font-size: .78rem; }
.home-section-head h2 { font-size: clamp(1.6rem, 3.5vw, 2.4rem); color: var(--color-text); margin: .4rem 0 .5rem; }
.home-section-head p { color: var(--color-muted); max-width: 60ch; margin: 0 auto; }

/* ---------- Theme cards ---------- */
.theme-cards { display: grid; gap: 1.4rem; grid-template-columns: repeat(auto-fill, minmax(300px, 1fr)); }
.theme-card {
  display: flex; flex-direction: column; text-decoration: none; color: inherit;
  background: #fff; border: 1px solid var(--color-border); border-radius: var(--radius-lg);
  overflow: hidden; box-shadow: var(--shadow-sm);
  transition: transform var(--dur) var(--ease), box-shadow var(--dur);
}
.theme-card:hover { transform: translateY(-6px); box-shadow: var(--shadow-lg); }
.theme-card .preview { height: 150px; position: relative; display: grid; place-items: center; overflow: hidden; }
.theme-card .preview .chip { padding: .5rem 1.1rem; border-radius: 999px; font-weight: 700; font-size: .85rem; }
.theme-card .swatch-row { display: flex; height: 8px; }
.theme-card .swatch-row i { flex: 1; }
.theme-card .body { padding: 1.3rem 1.4rem 1.5rem; }
.theme-card .body h3 { font-size: 1.3rem; margin-bottom: .4rem; color: var(--color-text); }
.theme-card .body p { color: var(--color-muted); font-size: .93rem; margin-bottom: 1rem; }
.theme-card .tags { display: flex; flex-wrap: wrap; gap: .4rem; margin-bottom: 1.1rem; }
.theme-card .tags span { font-size: .74rem; font-weight: 600; padding: .25rem .6rem; border-radius: 999px; background: var(--color-surface-2); color: var(--color-muted); }
.theme-card .go { margin-top: auto; font-family: var(--font-head); font-weight: 700; color: var(--es-teal); display: inline-flex; align-items: center; gap: .4rem; }
.theme-card:hover .go { gap: .7rem; }

/* Theme-specific preview flavours */
.pv-professional { background: linear-gradient(135deg, #1a3059, #085c67 55%, #13927a); }
.pv-professional .chip { background: #fff; color: #1a3059; }
.pv-vintage { background: repeating-linear-gradient(45deg, #e7dbc2 0 10px, #efe6d3 10px 20px); }
.pv-vintage .chip { background: #7c2b23; color: #f8f1e2; font-family: "Playfair Display", serif; border: 2px solid #3a2c1e; }
.pv-abstract { background: linear-gradient(135deg, #7b2ff7 0 33%, #ff2d78 33% 66%, #00b3c6 66%); }
.pv-abstract .chip { background: #fff; color: #170f2e; border: 2.5px solid #170f2e; box-shadow: 4px 4px 0 #170f2e; }
.pv-minimal { background: #fafafa; border-bottom: 1px solid var(--color-border); }
.pv-minimal .chip { background: #111; color: #fff; }
.pv-dark { background: radial-gradient(circle at 30% 20%, rgba(0,217,255,0.35), transparent 50%), linear-gradient(135deg, #0a0e17, #1b2334); }
.pv-dark .chip { background: rgba(0,217,255,0.15); color: #00d9ff; border: 1px solid rgba(0,217,255,0.4); }
.pv-playful { background: radial-gradient(#ffb703 2px, transparent 2px) 0 0/22px 22px, linear-gradient(135deg, #ff5a5f, #00b4d8); }
.pv-playful .chip { background: #fff; color: #ff5a5f; border-radius: 999px; font-family: "Fredoka", sans-serif; }
.pv-luxury { background: radial-gradient(120% 120% at 100% 0%, rgba(201,162,39,0.35), transparent 55%), linear-gradient(135deg, #1b1815, #12100e); }
.pv-luxury .chip { background: transparent; color: #e6c66b; border: 1px solid #c9a227; letter-spacing: .18em; text-transform: uppercase; font-family: "Cormorant Garamond", serif; }
.pv-nature { background: linear-gradient(135deg, #2f5d3a, #7d9a5f 60%, #c96f4a); }
.pv-nature .chip { background: #fbf8f0; color: #2f5d3a; border-radius: 999px; font-family: "Fraunces", serif; }
.pv-retro { background: linear-gradient(rgba(255,46,151,0.15) 1px, transparent 1px) 0 0/22px 22px, radial-gradient(circle at 50% 130%, rgba(255,46,151,0.5), transparent 55%), linear-gradient(180deg, #2a1c58, #160d2e); }
.pv-retro .chip { background: #ff2e97; color: #16021a; font-family: "Orbitron", sans-serif; text-transform: uppercase; letter-spacing: .1em; font-size: .78rem; box-shadow: 0 0 18px rgba(255,46,151,0.7); }
.pv-pastel { background: linear-gradient(135deg, #e7ddf7, #d6efe8 55%, #ffe4d6); }
.pv-pastel .chip { background: #fff; color: #7a6ca8; border-radius: 999px; font-family: "Quicksand", sans-serif; }
.pv-editorial { background: repeating-linear-gradient(0deg, #16130e 0 3px, #f7f4ee 3px 8px); }
.pv-editorial .chip { background: #f7f4ee; color: #16130e; border: 1.5px solid #16130e; border-radius: 0; font-family: "DM Serif Display", serif; }

/* ---------- Feature strip ---------- */
.home-features { background: var(--color-surface-2); border-block: 1px solid var(--color-border); }
.feature-grid { display: grid; gap: 1.4rem; grid-template-columns: repeat(auto-fit, minmax(220px, 1fr)); }
.feature { text-align: center; padding: 1.4rem; }
.feature .ic { width: 48px; height: 48px; margin: 0 auto .8rem; border-radius: 14px; display: grid; place-items: center; background: linear-gradient(135deg, var(--es-navy), var(--es-emerald)); color: #fff; font-size: 1.3rem; font-weight: 800; }
.feature h3 { font-size: 1.1rem; margin-bottom: .3rem; }
.feature p { color: var(--color-muted); font-size: .9rem; margin: 0; }

/* ==========================================================================
   PALETTES PAGE
   ========================================================================== */
.palette-grid { display: grid; gap: 1.6rem; grid-template-columns: repeat(auto-fill, minmax(320px, 1fr)); }
.palette-card { background: #fff; border: 1px solid var(--color-border); border-radius: var(--radius-lg); overflow: hidden; box-shadow: var(--shadow-sm); }
.palette-head { padding: 1.1rem 1.3rem; display: flex; align-items: center; justify-content: space-between; gap: .6rem; border-bottom: 1px solid var(--color-border); }
.palette-head h3 { margin: 0; font-size: 1.2rem; }
.palette-head .pill { font-size: .72rem; font-weight: 700; text-transform: uppercase; letter-spacing: .06em; color: var(--es-teal); background: color-mix(in srgb, var(--es-teal) 12%, #fff); padding: .25rem .6rem; border-radius: 999px; }
.palette-bar { display: flex; height: 92px; }
.palette-bar i { flex: 1; transition: flex var(--dur) var(--ease); }
.palette-bar i:hover { flex: 1.6; }
.swatch-list { padding: 1rem 1.3rem 1.3rem; display: grid; gap: .5rem; }
.swatch {
  display: flex; align-items: center; gap: .8rem; padding: .5rem .6rem; border-radius: var(--radius-sm);
  cursor: pointer; border: 1px solid transparent; transition: background var(--dur), border-color var(--dur);
}
.swatch:hover { background: var(--color-surface-2); border-color: var(--color-border); }
.swatch .dot { width: 30px; height: 30px; border-radius: 8px; border: 1px solid rgba(0,0,0,0.1); flex: 0 0 auto; }
.swatch .meta { display: flex; flex-direction: column; }
.swatch .role { font-size: .74rem; color: var(--color-muted); text-transform: uppercase; letter-spacing: .05em; }
.swatch .hex { font-family: ui-monospace, Menlo, monospace; font-weight: 700; font-size: .95rem; color: var(--color-text); }
.swatch .copy-tag { margin-left: auto; font-size: .74rem; font-weight: 700; color: var(--es-teal); opacity: 0; transition: opacity var(--dur); }
.swatch:hover .copy-tag { opacity: 1; }
.swatch.copied { background: color-mix(in srgb, var(--es-emerald) 12%, #fff); border-color: color-mix(in srgb, var(--es-emerald) 40%, transparent); }
.swatch.copied .copy-tag { opacity: 1; color: var(--es-emerald); }

@media (max-width: 820px) {
  .home-hero .wrap { grid-template-columns: 1fr; }
  .home-hero .visual { display: none; }
}
