/*
Theme Name: Ripple Cream
Theme URI: https://example.com/ripple-cream
Author: OpenAI
Author URI: https://openai.com
Description: A warm cream, rounded, attractive WordPress theme designed to pair well with Ripple Social.
Version: 1.0.0
Requires at least: 6.0
Tested up to: 6.6
Requires PHP: 7.4
Text Domain: ripple-cream
Tags: blog, one-column, two-columns, custom-logo, custom-menu, featured-images, full-site-editing, threaded-comments, translation-ready
*/

:root {
  --rc-bg: #fbf5ec;
  --rc-bg-soft: #fffaf3;
  --rc-surface: #fffdf8;
  --rc-surface-2: #f6ede0;
  --rc-border: #e6d8c5;
  --rc-text: #3b3127;
  --rc-text-soft: #7c6a58;
  --rc-accent: #b9784e;
  --rc-accent-2: #8f5e3e;
  --rc-shadow: 0 14px 40px rgba(82, 57, 34, 0.08);
  --rc-radius: 22px;
  --rc-radius-sm: 14px;
  --rc-content: 1180px;
}

html { box-sizing: border-box; }
*, *:before, *:after { box-sizing: inherit; }
html, body { margin: 0; padding: 0; }
body {
  font-family: Georgia, "Times New Roman", serif;
  background: linear-gradient(180deg, var(--rc-bg) 0%, #f8f0e4 100%);
  color: var(--rc-text);
  line-height: 1.65;
}

a { color: var(--rc-accent-2); text-decoration-thickness: 1px; text-underline-offset: 3px; }
a:hover { color: var(--rc-accent); }
img { max-width: 100%; height: auto; }

.site-wrap { min-height: 100vh; display: flex; flex-direction: column; }
.site-header {
  position: sticky; top: 0; z-index: 40;
  backdrop-filter: blur(10px);
  background: rgba(251,245,236,0.84);
  border-bottom: 1px solid rgba(230,216,197,0.85);
}
.header-inner, .site-main-inner, .site-footer-inner, .hero-inner, .promo-inner {
  width: min(calc(100% - 32px), var(--rc-content));
  margin: 0 auto;
}
.header-inner {
  display: grid;
  grid-template-columns: auto 1fr auto;
  gap: 20px;
  align-items: center;
  padding: 14px 0;
}
.site-branding a {
  text-decoration: none;
  color: var(--rc-text);
}
.site-title {
  margin: 0;
  font-size: 1.65rem;
  letter-spacing: 0.02em;
}
.site-description {
  margin: 2px 0 0;
  font-size: 0.95rem;
  color: var(--rc-text-soft);
}
.custom-logo-link img { max-height: 54px; width: auto; border-radius: 12px; }

.main-navigation ul {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  gap: 14px;
  flex-wrap: wrap;
  justify-content: center;
}
.main-navigation a {
  text-decoration: none;
  color: var(--rc-text);
  padding: 10px 14px;
  border-radius: 999px;
  display: inline-flex;
  align-items: center;
  gap: 8px;
}
.main-navigation a:hover,
.main-navigation .current-menu-item > a {
  background: var(--rc-surface);
  box-shadow: var(--rc-shadow);
}

.header-actions {
  display: flex;
  gap: 10px;
  align-items: center;
}
.rc-button,
button,
input[type="submit"],
.wp-block-button__link,
.read-more-link {
  appearance: none;
  border: 1px solid var(--rc-accent);
  background: var(--rc-accent);
  color: #fffaf5;
  border-radius: 999px;
  padding: 12px 18px;
  font: inherit;
  line-height: 1;
  text-decoration: none;
  box-shadow: var(--rc-shadow);
  cursor: pointer;
}
.rc-button--ghost {
  background: transparent;
  color: var(--rc-accent-2);
  border-color: var(--rc-border);
  box-shadow: none;
}
.rc-button:hover,
button:hover,
input[type="submit"]:hover,
.wp-block-button__link:hover,
.read-more-link:hover {
  background: var(--rc-accent-2);
  border-color: var(--rc-accent-2);
}
.rc-button--ghost:hover {
  background: var(--rc-surface);
  color: var(--rc-accent-2);
  border-color: var(--rc-border);
}

.hero {
  padding: 36px 0 24px;
}
.hero-card, .promo-card, .content-card, .widget, .comments-area, .post-navigation, .page-links {
  background: var(--rc-surface);
  border: 1px solid var(--rc-border);
  border-radius: var(--rc-radius);
  box-shadow: var(--rc-shadow);
}
.hero-card {
  padding: 34px;
  display: grid;
  grid-template-columns: 1.25fr 0.85fr;
  gap: 24px;
  align-items: center;
}
.hero-kicker {
  display: inline-flex;
  padding: 8px 12px;
  background: var(--rc-surface-2);
  border-radius: 999px;
  color: var(--rc-accent-2);
  font-size: 0.92rem;
  margin-bottom: 14px;
}
.hero h1 {
  margin: 0 0 12px;
  font-size: clamp(2rem, 4vw, 3.6rem);
  line-height: 1.05;
}
.hero p {
  margin: 0 0 16px;
  color: var(--rc-text-soft);
  font-size: 1.05rem;
}
.hero-actions {
  display: flex;
  gap: 12px;
  flex-wrap: wrap;
}
.hero-panel {
  padding: 22px;
  border-radius: var(--rc-radius);
  background: linear-gradient(180deg, #fff8ef 0%, #f6eadb 100%);
  border: 1px solid var(--rc-border);
}
.hero-stats {
  display: grid;
  grid-template-columns: repeat(2, minmax(0,1fr));
  gap: 14px;
}
.hero-stat {
  background: rgba(255,255,255,0.68);
  padding: 16px;
  border-radius: var(--rc-radius-sm);
}
.hero-stat strong {
  display: block;
  font-size: 1.5rem;
}
.hero-stat span { color: var(--rc-text-soft); font-size: 0.95rem; }

.promo { padding: 12px 0 6px; }
.promo-card {
  padding: 22px 26px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
}

.site-main { flex: 1; padding: 24px 0 42px; }
.site-main-inner {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 320px;
  gap: 28px;
}
body.no-sidebar .site-main-inner,
body.page-template-page-ripple-app.no-sidebar .site-main-inner {
  grid-template-columns: minmax(0, 1fr);
}
.content-card {
  padding: 28px;
}
.entry-title, .page-title {
  margin-top: 0;
  line-height: 1.15;
}
.entry-meta, .entry-footer, .wp-block-latest-posts__post-date {
  color: var(--rc-text-soft);
  font-size: 0.95rem;
}
.entry-content > *:first-child { margin-top: 0; }
.entry-content > *:last-child { margin-bottom: 0; }

.posts-grid {
  display: grid;
  gap: 22px;
}
.post-card {
  padding: 24px;
  background: var(--rc-surface);
  border: 1px solid var(--rc-border);
  border-radius: var(--rc-radius);
  box-shadow: var(--rc-shadow);
}
.post-card .entry-title { font-size: 1.6rem; }
.read-more-link { display: inline-flex; margin-top: 14px; }

.widget {
  padding: 20px;
  margin-bottom: 20px;
}
.widget-title {
  margin-top: 0;
  margin-bottom: 12px;
  font-size: 1.2rem;
}

.site-footer {
  border-top: 1px solid rgba(230,216,197,0.85);
  padding: 28px 0;
  background: rgba(255,251,244,0.86);
}
.site-footer-inner {
  display: flex;
  justify-content: space-between;
  gap: 16px;
  flex-wrap: wrap;
  color: var(--rc-text-soft);
}

input[type="text"], input[type="email"], input[type="url"], input[type="search"], input[type="password"], textarea, select {
  width: 100%;
  max-width: 100%;
  border: 1px solid var(--rc-border);
  border-radius: 16px;
  padding: 12px 14px;
  background: #fffdf9;
  color: var(--rc-text);
  font: inherit;
}
textarea { min-height: 140px; }

/* Ripple plugin matching */
body .ripple-shell,
body .ripple-marketing-shell {
  max-width: 1180px;
}
body .ripple-app-nav,
body .ripple-brand-head,
body .ripple-post-card,
body .ripple-profile-card,
body .ripple-admin-card,
body .ripple-composer,
body .ripple-messages-sidebar,
body .ripple-messages-main,
body .ripple-bookmarks-sidebar,
body .ripple-bookmarks-main,
body .ripple-creator-overview,
body .ripple-creator-settings,
body .ripple-auth-required,
body .ripple-notification-item,
body .ripple-comment-item,
body .ripple-hero-card,
body .ripple-join-card,
body .ripple-welcome-card,
body .ripple-feature-card,
body .ripple-mini-card {
  border-radius: var(--rc-radius) !important;
  border-color: var(--rc-border) !important;
  background: var(--rc-surface) !important;
  box-shadow: var(--rc-shadow) !important;
}
body .ripple-post-submit-btn,
body .ripple-save-creator-btn,
body .ripple-create-invite-btn,
body .ripple-join-submit,
body .ripple-cta-primary {
  background: var(--rc-accent) !important;
  border-color: var(--rc-accent) !important;
  color: #fffaf5 !important;
}
body .ripple-profile-tab-btn.is-active,
body .ripple-unread-badge,
body .ripple-nav-badge,
body .ripple-onboarding-progress-fill,
body .ripple-app-nav-links a:hover,
body .ripple-app-nav-links .current-menu-item a {
  background: var(--rc-accent) !important;
  border-color: var(--rc-accent) !important;
  color: #fffaf5 !important;
}
body .ripple-hashtag-link,
body .ripple-profile-about-card a,
body .ripple-cta-secondary,
body .ripple-support-note,
body .ripple-brand-meta p,
body .ripple-post-time,
body .ripple-post-author span,
body .ripple-message-meta,
body .ripple-notification-time {
  color: var(--rc-text-soft) !important;
}
body .ripple-composer-text,
body .ripple-comment-form textarea,
body .ripple-chat-composer textarea,
body .ripple-new-collection input,
body .ripple-creator-settings input,
body .ripple-creator-settings textarea,
body .ripple-redeem-code-input,
body .ripple-search-input,
body .ripple-profile-editor input,
body .ripple-profile-editor textarea,
body .ripple-join-fields input {
  background: #fffdf8 !important;
  border-color: var(--rc-border) !important;
  color: var(--rc-text) !important;
}
body .ripple-app-nav {
  margin-top: 24px !important;
  background: rgba(255,253,248,0.94) !important;
}
body .ripple-app-nav-brand span,
body .ripple-profile-name,
body .ripple-brand-meta h1,
body .ripple-section-title {
  color: var(--rc-text) !important;
}
body .ripple-profile-avatar,
body .ripple-brand-mark {
  background: var(--rc-surface-2) !important;
}
body .ripple-toast-success { background: #7d5b44 !important; }
body .ripple-toast-error { background: #8b4f43 !important; }

/* Full-width app template */
body.page-template-page-ripple-app {
  background: linear-gradient(180deg, #fbf5ec 0%, #f6eedf 100%);
}
body.page-template-page-ripple-app .site-main { padding-top: 12px; }
body.page-template-page-ripple-app .content-card {
  background: transparent;
  box-shadow: none;
  border: none;
  padding: 0;
}
body.page-template-page-ripple-app .site-main-inner { grid-template-columns: 1fr; }

.screen-reader-text {
  position: absolute;
  left: -9999px;
}

@media (max-width: 980px) {
  .hero-card,
  .site-main-inner,
  body.no-sidebar .site-main-inner,
  body.page-template-page-ripple-app.no-sidebar .site-main-inner {
    grid-template-columns: 1fr;
  }
  .header-inner { grid-template-columns: 1fr; }
  .main-navigation ul { justify-content: flex-start; }
}

@media (max-width: 782px) {
  .hero-card, .content-card, .widget, .comments-area, .post-card { padding: 20px; }
  .promo-card { flex-direction: column; align-items: flex-start; }
  .hero-stats { grid-template-columns: 1fr 1fr; }
  .site-main { padding-bottom: 28px; }
  .site-main-inner, .site-footer-inner { gap: 18px; }
}
