/*
Theme Name: ColorsPanda
Theme URI: https://colorspanda.com
Description: Child theme of GeneratePress for ColorsPanda — a friendly kids' coloring-pages site. Skins the Razvivashka Coloring Pages plugin (CPT coloring_page + taxonomies + online editor) with the ColorsPanda brand: panda mascot, Fredoka/Nunito/Caveat, warm cream palette, rainbow wordmark.
Author: ColorsPanda
Template: generatepress
Version: 0.1.0
Text Domain: colorspanda
*/

/* =========================================================================
   ColorsPanda — design tokens
   ========================================================================= */
:root {
  --cp-bg:        #FFF8EE;
  --cp-ink:       #2B2A28;
  --cp-muted:     #6B6862;
  --cp-faint:     #9A938A;
  --cp-card:      #FFFFFF;
  --cp-line:      #F0E7D6;
  --cp-line-2:    #EFE6D6;
  --cp-wash:      #FBF4E8;

  --cp-green:     #5BB377;
  --cp-green-ink: #3E8F5A;
  --cp-green-2:   #5BB94A;
  --cp-green-bg:  #DFF3E4;
  --cp-blue:      #3E9BE0;
  --cp-blue-bg:   #DCEEF8;
  --cp-pink:      #C2569A;
  --cp-pink-bg:   #FBE6F1;
  --cp-orange:    #E07A4E;
  --cp-orange-bg: #FFE3D6;
  --cp-yellow-bg: #FFF1D6;

  --cp-radius:    20px;
  --cp-radius-lg: 26px;
  --cp-shadow:    0 6px 18px rgba(43,42,40,.05);
  --cp-shadow-lg: 0 14px 40px rgba(43,42,40,.08);

  --cp-font:      'Nunito', system-ui, -apple-system, sans-serif;
  --cp-display:   'Fredoka', 'Nunito', sans-serif;
  --cp-accent:    'Caveat', cursive;
  --cp-wrap:      1180px;
}

/* =========================================================================
   Base
   ========================================================================= */
body.colorspanda,
body {
  font-family: var(--cp-font);
  color: var(--cp-ink);
  background: var(--cp-bg);
  -webkit-font-smoothing: antialiased;
}
.colorspanda h1, .colorspanda h2, .colorspanda h3,
.cp-display { font-family: var(--cp-display); font-weight: 700; letter-spacing: -.5px; }

.cp-wrap { max-width: var(--cp-wrap); margin: 0 auto; padding-left: 24px; padding-right: 24px; }
.cp-accent { font-family: var(--cp-accent); font-weight: 700; color: var(--cp-pink); }

@keyframes cp-bob  { 0%,100%{ transform:translateY(0) rotate(-2deg);} 50%{ transform:translateY(-12px) rotate(2deg);} }
@keyframes cp-float{ 0%,100%{ transform:translateY(0) rotate(var(--r,0deg)); } 50%{ transform:translateY(-16px) rotate(var(--r,0deg)); } }
@media (prefers-reduced-motion: reduce){ *,::before,::after{ animation-duration:.001ms !important; animation-iteration-count:1 !important; } }

/* =========================================================================
   Buttons (shared brand button system)
   ========================================================================= */
.cp-btn,
.colorspanda .rcp-btn {
  display: inline-flex; align-items: center; justify-content: center; gap: 10px;
  font-family: var(--cp-display); font-weight: 600; font-size: 17px;
  border: none; border-radius: 16px; padding: 14px 26px; cursor: pointer;
  text-decoration: none; line-height: 1; transition: transform .12s ease, box-shadow .15s ease;
}
.cp-btn--primary,
.colorspanda .rcp-btn--primary,
.colorspanda .rcp-btn--hero {
  background: var(--cp-green); color: #fff; box-shadow: 0 10px 24px rgba(91,179,119,.38);
}
.cp-btn--primary:hover,
.colorspanda .rcp-btn--primary:hover,
.colorspanda .rcp-btn--hero:hover { transform: translateY(-2px); box-shadow: 0 14px 28px rgba(91,179,119,.46); color:#fff; }
.cp-btn--ghost,
.colorspanda .rcp-btn--secondary {
  background: #fff; color: var(--cp-ink); border: 2px solid var(--cp-line-2);
}
.cp-btn--ghost:hover,
.colorspanda .rcp-btn--secondary:hover { transform: translateY(-2px); color: var(--cp-ink); }
.colorspanda .rcp-btn--ghost { background: none; color: var(--cp-faint); font-weight: 800; box-shadow:none; }
.colorspanda .rcp-btn--chip { background:#fff; border:2px solid var(--cp-line-2); color:var(--cp-ink); font-size:14px; padding:8px 14px; border-radius:999px; }

/* =========================================================================
   Pills / badges
   ========================================================================= */
.cp-pill { display:inline-flex; align-items:center; gap:7px; font-weight:800; font-size:14px; padding:6px 14px; border-radius:999px; white-space:nowrap; }
.cp-pill--green { color: var(--cp-green-ink); background: var(--cp-green-bg); }
.cp-pill--blue  { color: #2F87BE; background: var(--cp-blue-bg); }
.cp-pill--pink  { color: var(--cp-pink); background: var(--cp-pink-bg); }
.cp-pill--orange{ color: var(--cp-orange); background: var(--cp-orange-bg); }
.cp-pill--age   { color: var(--cp-faint); background:#fff; border:1.5px solid var(--cp-line-2); }

/* Filter chips (catalog) */
.cp-chip { display:inline-flex; align-items:center; gap:6px; font-family:var(--cp-display); font-weight:600; font-size:15px; padding:9px 18px; border-radius:999px; cursor:pointer; white-space:nowrap; text-decoration:none; border:2px solid var(--cp-line-2); background:#fff; color:var(--cp-muted); transition:transform .12s ease; }
.cp-chip:hover { transform:translateY(-2px); color:var(--cp-ink); }
.cp-chip.is-active { border-color:var(--cp-green-ink); background:var(--cp-green); color:#fff; }

/* =========================================================================
   Breadcrumbs (custom + plugin .rcp-breadcrumbs)
   ========================================================================= */
.cp-crumbs,
.colorspanda .rcp-breadcrumbs {
  display:flex; flex-wrap:wrap; align-items:center; gap:8px;
  font-weight:800; font-size:14px; margin: 0 0 18px;
}
.cp-crumbs a,
.colorspanda .rcp-breadcrumbs a { color: var(--cp-muted); text-decoration:none; background:#fff; border:1.5px solid var(--cp-line); padding:6px 12px; border-radius:999px; }
.cp-crumbs a:hover,
.colorspanda .rcp-breadcrumbs a:hover { background: var(--cp-wash); }
.cp-crumbs span[aria-hidden],
.colorspanda .rcp-breadcrumbs span[aria-hidden] { color: var(--cp-faint); }

/* =========================================================================
   Card grid (custom shelves/hubs + plugin .rcp-colorings-grid/.rcp-coloring-card)
   ========================================================================= */
.cp-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(230px,1fr)); gap:22px; }
.cp-shelf { display:flex; gap:18px; overflow-x:auto; padding-bottom:10px; scroll-snap-type:x mandatory; }
.cp-shelf .cp-card { flex:none; width:210px; scroll-snap-align:start; }

.cp-card,
.colorspanda .rcp-coloring-card {
  display:block; background:var(--cp-card); border:2px solid var(--cp-line); border-radius:22px;
  overflow:hidden; cursor:pointer; text-decoration:none; color:inherit;
  box-shadow:var(--cp-shadow); transition:transform .14s ease, box-shadow .14s ease;
}
.cp-card:hover,
.colorspanda .rcp-coloring-card:hover { transform:translateY(-6px); box-shadow:0 16px 30px rgba(43,42,40,.12); }
.cp-card__thumb,
.colorspanda .rcp-coloring-card a { position:relative; display:block; }
.cp-card__thumb { aspect-ratio:4/3; background:var(--cp-wash); border-bottom:2px solid var(--cp-line); display:flex; align-items:center; justify-content:center; }
.cp-card__thumb img,
.colorspanda .rcp-coloring-card img { width:100%; height:100%; object-fit:contain; display:block; }
.cp-card__body { padding:16px 18px; display:flex; align-items:center; justify-content:space-between; gap:10px; }
.cp-card__title,
.colorspanda .rcp-coloring-card h2 { font-family:var(--cp-display); font-weight:600; font-size:19px; margin:0; }
.cp-card__cat { font-size:13px; font-weight:800; color:var(--cp-green); }
.cp-card__crayon { width:38px; height:38px; flex:none; border-radius:12px; background:var(--cp-green-bg); color:var(--cp-green-ink); display:flex; align-items:center; justify-content:center; font-size:20px; }
.cp-badge-new { position:absolute; bottom:10px; left:10px; background:#FF8A5B; color:#fff; font-size:11px; font-weight:900; letter-spacing:.5px; padding:3px 9px; border-radius:999px; }
.cp-badge-age { position:absolute; top:10px; right:10px; background:#fff; border:1.5px solid var(--cp-line-2); color:var(--cp-faint); font-size:12px; font-weight:800; padding:3px 9px; border-radius:999px; }

/* =========================================================================
   Section headers
   ========================================================================= */
.cp-section { padding: 28px 0 8px; }
.cp-section__head { display:flex; align-items:baseline; justify-content:space-between; gap:12px; margin-bottom:16px; }
.cp-section__head h2 { font-family:var(--cp-display); font-weight:600; font-size:30px; margin:0; }
.cp-section__more { background:none; border:none; font-family:var(--cp-font); font-weight:800; font-size:15px; color:var(--cp-green); cursor:pointer; text-decoration:none; }

/* =========================================================================
   HOME — hero
   ========================================================================= */
.cp-hero { display:flex; flex-wrap:wrap; align-items:center; gap:40px; padding:52px 0 28px; }
.cp-hero__col { flex:1; min-width:300px; }
.cp-hero__eyebrow { display:inline-flex; align-items:center; gap:8px; background:#fff; border:2px solid var(--cp-line); color:#E8485E; font-weight:900; font-size:14px; padding:8px 16px; border-radius:999px; margin-bottom:20px; letter-spacing:.3px; }
.cp-hero h1 { font-family:var(--cp-display); font-weight:700; font-size:clamp(40px,6vw,64px); line-height:1; letter-spacing:-1.5px; margin:0 0 18px; }
.cp-hero h1 .cp-hl { color:var(--cp-green-2); }
.cp-hero p { font-size:19px; line-height:1.55; color:var(--cp-muted); max-width:460px; margin:0 0 28px; }
.cp-hero__cta { display:flex; flex-wrap:wrap; gap:14px; }
.cp-hero__trust { display:flex; flex-wrap:wrap; gap:10px; margin-top:24px; }
.cp-hero__art { flex:1; min-width:300px; position:relative; display:flex; justify-content:center; align-items:center; min-height:420px; }
.cp-hero__disc { position:absolute; width:min(420px,92%); aspect-ratio:1; border-radius:50%; background:radial-gradient(circle at 50% 42%, #FFFFFF 0%, #FCEFD9 62%, #F8E4C4 100%); box-shadow:0 30px 70px rgba(43,42,40,.10); }
.cp-hero__panda { position:relative; width:min(380px,88%); height:auto; filter:drop-shadow(0 18px 26px rgba(43,42,40,.18)); animation:cp-bob 6s ease-in-out infinite; }
.cp-blob { position:absolute; border-radius:18px; box-shadow:0 8px 18px rgba(0,0,0,.12); animation:cp-float 6s ease-in-out infinite; }

/* HOME — how it works */
.cp-steps { display:grid; grid-template-columns:repeat(auto-fit,minmax(260px,1fr)); gap:18px; }
.cp-step { background:#fff; border:2px solid var(--cp-line); border-radius:24px; padding:28px 26px; text-align:center; }
.cp-step__disc { width:128px; height:128px; margin:0 auto 16px; border-radius:50%; display:flex; align-items:center; justify-content:center; }
.cp-step__disc img { width:86%; height:86%; object-fit:contain; }
.cp-step__num { display:inline-block; color:#fff; font-family:var(--cp-display); font-weight:700; font-size:14px; padding:3px 12px; border-radius:999px; margin-bottom:10px; white-space:nowrap; }
.cp-step h3 { font-family:var(--cp-display); font-weight:600; font-size:21px; margin:0 0 6px; }
.cp-step p { margin:0; color:var(--cp-muted); font-size:16px; line-height:1.5; }

/* HOME — FAQ */
.cp-faq { max-width:820px; margin:0 auto; }
.cp-faq__item { background:#fff; border:2px solid var(--cp-line); border-radius:18px; padding:22px 24px; margin-bottom:14px; }
.cp-faq__item h3 { font-family:var(--cp-display); font-weight:600; font-size:19px; margin:0 0 6px; }
.cp-faq__item p { margin:0; color:var(--cp-muted); font-size:16px; line-height:1.55; }

/* =========================================================================
   HUB (taxonomy archive) — plugin taxonomy-coloring.php override
   ========================================================================= */
.cp-hub__hero { padding:28px 0 36px; }
.cp-hub__badge { display:inline-block; background:#fff; font-weight:900; font-size:13px; padding:4px 12px; border-radius:999px; margin-bottom:8px; }
.cp-hub__hero h1 { font-family:var(--cp-display); font-weight:700; font-size:clamp(34px,5vw,46px); margin:0; letter-spacing:-1px; line-height:1; }
.cp-hub__intro { font-size:18px; line-height:1.55; color:#4A4843; max-width:600px; margin:16px 0 14px; }
.cp-hub__format { display:flex; flex-wrap:wrap; gap:8px; margin-bottom:6px; }
.cp-hub__format span { display:inline-flex; align-items:center; gap:6px; background:rgba(255,255,255,.7); color:#4A4843; font-weight:800; font-size:13px; padding:6px 12px; border-radius:999px; }
.cp-hub__icon { width:84px; height:84px; flex:none; border-radius:24px; background:#fff; display:flex; align-items:center; justify-content:center; font-size:44px; box-shadow:0 8px 22px rgba(43,42,40,.10); }

/* =========================================================================
   SINGLE coloring page — skin the plugin player + custom chrome
   ========================================================================= */
.cp-single { padding: 28px 0 64px; }
.cp-single__header { display:flex; flex-wrap:wrap; align-items:flex-start; justify-content:space-between; gap:14px; margin-bottom:18px; }
.cp-single__header h1 { font-family:var(--cp-display); font-weight:700; font-size:clamp(30px,4vw,40px); margin:0 0 12px; letter-spacing:-1px; }
.cp-single__tags { display:flex; flex-wrap:wrap; gap:8px; margin-bottom:8px; }

/* plugin workspace */
.colorspanda .rcp-coloring-workspace { display:flex; flex-wrap:wrap; gap:40px; align-items:flex-start; }
.colorspanda .rcp-player-column { flex:1; min-width:300px; }
.colorspanda .rcp-main-image,
.colorspanda .rcp-coloring-image { background:#fff; border:2px solid var(--cp-line); border-radius:var(--cp-radius-lg); padding:16px; box-shadow:var(--cp-shadow-lg); }
.colorspanda .rcp-coloring-image img { width:100%; height:auto; border-radius:14px; display:block; }
.colorspanda .rcp-player-tabs { display:inline-flex; gap:4px; padding:5px; background:#F3EADB; border-radius:18px; margin-bottom:16px; }
.colorspanda .rcp-player-tab { font-family:var(--cp-display); font-weight:600; font-size:16px; padding:9px 20px; border-radius:14px; cursor:pointer; border:none; background:transparent; color:var(--cp-muted); }
.colorspanda .rcp-player-tab.is-active { background:var(--cp-ink); color:#fff; }
.colorspanda .rcp-action-panel { flex:1; min-width:280px; background:#fff; border:2px solid var(--cp-line); border-radius:var(--cp-radius-lg); padding:24px; box-shadow:var(--cp-shadow); }
.colorspanda .rcp-action-panel h2 { font-family:var(--cp-display); font-weight:700; font-size:24px; margin:0 0 6px; }
.colorspanda .rcp-action-stack { display:flex; flex-direction:column; gap:12px; max-width:360px; margin-top:14px; }
.colorspanda .rcp-action-stack .rcp-btn { width:100%; font-size:18px; padding:16px 26px; border-radius:18px; }
.colorspanda .rcp-stats { display:flex; gap:18px; margin-top:18px; padding-top:16px; border-top:2px solid var(--cp-line); }
.colorspanda .rcp-stat-number { font-family:var(--cp-display); font-weight:700; font-size:24px; color:var(--cp-ink); }
.colorspanda .rcp-stat-item dt { font-size:13px; font-weight:800; color:var(--cp-faint); }
.colorspanda .rcp-description { margin-top:40px; }
.colorspanda .rcp-description h2 { font-family:var(--cp-display); font-weight:600; font-size:26px; }
.colorspanda .rcp-colorings-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(200px,1fr)); gap:18px; }

/* =========================================================================
   Header logo (fit the rainbow lockup nicely)
   ========================================================================= */
.colorspanda .site-logo img,
.colorspanda .header-image,
.colorspanda .site-header img { max-height:50px; width:auto; }

/* =========================================================================
   Branded footer (GeneratePress .site-info skin)
   ========================================================================= */
.colorspanda .site-footer, .colorspanda .footer-widgets { background:#2B2A28; color:#FFF8EE; }
.colorspanda .site-info { background:#2B2A28; color:#A8A39B; }
.colorspanda .site-info .inside-site-info { max-width:1180px; padding-left:24px; padding-right:24px; }
.cp-foot { display:flex; flex-wrap:wrap; align-items:center; justify-content:space-between; gap:18px; padding:20px 0; text-align:left; }
.cp-foot__brand { display:flex; align-items:center; gap:12px; }
.cp-foot__brand img { width:46px; height:46px; border-radius:13px; }
.cp-foot__word { font-family:var(--cp-display); font-weight:700; font-size:22px; display:block; line-height:1; }
.cp-foot__tag { color:#A8A39B; font-weight:800; font-size:12px; letter-spacing:.4px; }
.cp-foot__nav { display:flex; flex-wrap:wrap; gap:6px; }
.cp-foot__nav a { color:#D8D3CB; font-weight:700; font-size:15px; padding:8px 12px; text-decoration:none; }
.cp-foot__nav a:hover { color:#fff; }
.cp-foot__copy { color:#A8A39B; font-size:14px; width:100%; text-align:center; padding-top:8px; border-top:1px solid #43413D; }

/* rainbow wordmark helper (for logo text / footer) */
.cp-word b{font-weight:700;}
.cp-word .c1{color:#E8485E;} .cp-word .c2{color:#F18A3E;} .cp-word .c3{color:#F2B720;}
.cp-word .c4{color:#5BB94A;} .cp-word .c5{color:#3E9BE0;} .cp-word .c6{color:#8E5BC4;}

@media (max-width:720px){
  .cp-hero { padding-top:32px; }
  .cp-section__head h2 { font-size:26px; }
}
