/*
 Theme Name:   Form & Paper
 Theme URI:    https://formandpaper.com
 Description:  Editorial child theme for Form & Paper — curated books and objects for considered living. Built on Blocksy.
 Author:       Form & Paper
 Author URI:   https://formandpaper.com
 Template:     blocksy
 Version:      1.0.0
 License:      GNU General Public License v2 or later
 License URI:  http://www.gnu.org/licenses/gpl-2.0.html
 Text Domain:  formandpaper-child
*/

/* ==========================================================================
   DESIGN TOKENS
   ========================================================================== */

:root {
  /* Colors */
  --fp-paper:        #F6F3EE;
  --fp-paper-dark:   #EDE9E2;
  --fp-ink:          #1A1A1A;
  --fp-ink-light:    #3D3D3D;
  --fp-ink-muted:    #6B6B6B;
  --fp-olive:        #4A5A4D;
  --fp-olive-light:  #5E7062;
  --fp-olive-faint:  rgba(74, 90, 77, 0.08);
  --fp-border:       rgba(26, 26, 26, 0.1);
  --fp-border-hover: rgba(26, 26, 26, 0.25);
  --fp-white:        #FFFFFF;

  /* Typography Scale */
  --fp-font-display: 'Source Serif 4', 'Georgia', serif;
  --fp-font-body:    'Inter', -apple-system, BlinkMacSystemFont, sans-serif;

  --fp-text-xs:   0.75rem;    /* 12px */
  --fp-text-sm:   0.8125rem;  /* 13px */
  --fp-text-base: 0.9375rem;  /* 15px */
  --fp-text-md:   1.0625rem;  /* 17px */
  --fp-text-lg:   1.25rem;    /* 20px */
  --fp-text-xl:   1.5rem;     /* 24px */
  --fp-text-2xl:  2rem;       /* 32px */
  --fp-text-3xl:  2.5rem;     /* 40px */
  --fp-text-4xl:  3.25rem;    /* 52px */

  /* Spacing */
  --fp-space-xs:  0.5rem;
  --fp-space-sm:  1rem;
  --fp-space-md:  1.5rem;
  --fp-space-lg:  2.5rem;
  --fp-space-xl:  4rem;
  --fp-space-2xl: 6rem;
  --fp-space-3xl: 8rem;

  /* Layout */
  --fp-content-width:  1200px;
  --fp-narrow-width:   800px;
  --fp-wide-width:     1400px;

  /* Transitions */
  --fp-ease:     cubic-bezier(0.25, 0.1, 0.25, 1);
  --fp-duration: 0.3s;
}


/* ==========================================================================
   GLOBAL RESET & BASE
   ========================================================================== */

body,
.ct-body {
  background-color: var(--fp-paper) !important;
  color: var(--fp-ink);
  font-family: var(--fp-font-body);
  font-size: var(--fp-text-base);
  line-height: 1.7;
  letter-spacing: -0.01em;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

*::selection {
  background-color: var(--fp-olive);
  color: var(--fp-paper);
}


/* ==========================================================================
   TYPOGRAPHY
   ========================================================================== */

h1, h2, h3, h4, h5, h6,
.wp-block-heading {
  font-family: var(--fp-font-display);
  font-weight: 400;
  color: var(--fp-ink);
  letter-spacing: -0.02em;
  line-height: 1.2;
}

h1, .has-huge-font-size   { font-size: var(--fp-text-4xl); }
h2, .has-large-font-size  { font-size: var(--fp-text-3xl); }
h3, .has-medium-font-size { font-size: var(--fp-text-2xl); }
h4 { font-size: var(--fp-text-xl); }
h5 { font-size: var(--fp-text-lg); }
h6 { font-size: var(--fp-text-md); }

p {
  font-family: var(--fp-font-body);
  font-size: var(--fp-text-base);
  line-height: 1.75;
  color: var(--fp-ink-light);
  max-width: 65ch;
}

/* Editorial lead paragraph */
.fp-lead,
.has-large-font-size p:first-child {
  font-family: var(--fp-font-display);
  font-size: var(--fp-text-lg);
  line-height: 1.6;
  color: var(--fp-ink-muted);
}

/* Overline / Kicker labels */
.fp-overline,
.wp-block-post-terms {
  font-family: var(--fp-font-body);
  font-size: var(--fp-text-xs);
  font-weight: 500;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--fp-olive);
}

/* Links */
a {
  color: var(--fp-ink);
  text-decoration: none;
  transition: color var(--fp-duration) var(--fp-ease);
}

a:hover {
  color: var(--fp-olive);
}

/* Article / editorial body links */
.entry-content a,
.wp-block-post-content a {
  color: var(--fp-ink);
  text-decoration: underline;
  text-decoration-color: var(--fp-border-hover);
  text-underline-offset: 3px;
  transition: text-decoration-color var(--fp-duration) var(--fp-ease);
}

.entry-content a:hover,
.wp-block-post-content a:hover {
  text-decoration-color: var(--fp-olive);
  color: var(--fp-olive);
}


/* ==========================================================================
   HEADER / NAVIGATION
   ========================================================================== */

/* Top-level header container */
header[data-id="type-1"],
.ct-header {
  background-color: var(--fp-paper) !important;
  border-bottom: 1px solid var(--fp-border);
}

/* Logo / Site title */
.site-title,
.ct-header .site-branding .site-title-container a {
  font-family: var(--fp-font-display);
  font-size: var(--fp-text-xl);
  font-weight: 400;
  letter-spacing: -0.02em;
  color: var(--fp-ink) !important;
}

/* Primary nav links */
.ct-header nav a,
.ct-header .ct-menu > li > a,
[data-id="menu"] a {
  font-family: var(--fp-font-body) !important;
  font-size: var(--fp-text-sm) !important;
  font-weight: 400 !important;
  letter-spacing: 0.04em !important;
  text-transform: uppercase !important;
  color: var(--fp-ink) !important;
  transition: color var(--fp-duration) var(--fp-ease);
}

.ct-header nav a:hover,
.ct-header .ct-menu > li > a:hover,
[data-id="menu"] a:hover {
  color: var(--fp-olive) !important;
}

/* Dropdown / submenu */
.ct-header .sub-menu,
.ct-header .ct-menu .sub-menu {
  background: var(--fp-white) !important;
  border: 1px solid var(--fp-border) !important;
  border-radius: 0 !important;
  box-shadow: 0 8px 32px rgba(0,0,0,0.06) !important;
  padding: var(--fp-space-sm) 0 !important;
  min-width: 220px;
}

.ct-header .sub-menu a,
.ct-header .ct-menu .sub-menu a {
  font-size: var(--fp-text-sm) !important;
  text-transform: none !important;
  letter-spacing: 0 !important;
  padding: 0.5rem 1.5rem !important;
  color: var(--fp-ink-light) !important;
}

.ct-header .sub-menu a:hover,
.ct-header .ct-menu .sub-menu a:hover {
  color: var(--fp-olive) !important;
  background: var(--fp-olive-faint) !important;
}

/* Search icon in header */
.ct-header [data-id="search"] svg {
  color: var(--fp-ink);
}


/* ==========================================================================
   BUTTONS
   ========================================================================== */

/* Primary CTA */
.wp-block-button__link,
.fp-btn-primary,
button.fp-btn-primary {
  font-family: var(--fp-font-body);
  font-size: var(--fp-text-sm);
  font-weight: 500;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  background-color: var(--fp-ink) !important;
  color: var(--fp-paper) !important;
  border: 1px solid var(--fp-ink) !important;
  border-radius: 0 !important;
  padding: 0.875rem 2rem !important;
  transition: all var(--fp-duration) var(--fp-ease);
  cursor: pointer;
}

.wp-block-button__link:hover,
.fp-btn-primary:hover {
  background-color: var(--fp-olive) !important;
  border-color: var(--fp-olive) !important;
  color: var(--fp-white) !important;
}

/* Outline / Secondary */
.is-style-outline .wp-block-button__link,
.fp-btn-outline {
  background-color: transparent !important;
  color: var(--fp-ink) !important;
  border: 1px solid var(--fp-ink) !important;
}

.is-style-outline .wp-block-button__link:hover,
.fp-btn-outline:hover {
  background-color: var(--fp-ink) !important;
  color: var(--fp-paper) !important;
}

/* Text arrow link */
.fp-link-arrow {
  font-family: var(--fp-font-body);
  font-size: var(--fp-text-sm);
  font-weight: 500;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  color: var(--fp-ink);
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  transition: gap var(--fp-duration) var(--fp-ease),
              color var(--fp-duration) var(--fp-ease);
}

.fp-link-arrow:hover {
  gap: 0.75rem;
  color: var(--fp-olive);
}

.fp-link-arrow::after {
  content: '→';
}


/* ==========================================================================
   HOMEPAGE SECTIONS
   ========================================================================== */

/* Generic section spacing */
.fp-section {
  padding: var(--fp-space-2xl) 0;
}

.fp-section-tight {
  padding: var(--fp-space-xl) 0;
}

/* Section headings */
.fp-section-title {
  font-family: var(--fp-font-display);
  font-size: var(--fp-text-2xl);
  font-weight: 400;
  text-align: center;
  margin-bottom: var(--fp-space-lg);
  color: var(--fp-ink);
}

.fp-section-subtitle {
  font-family: var(--fp-font-body);
  font-size: var(--fp-text-sm);
  color: var(--fp-ink-muted);
  text-align: center;
  margin-top: -1.5rem;
  margin-bottom: var(--fp-space-lg);
}

/* Divider between sections */
.fp-divider {
  width: 60px;
  height: 1px;
  background: var(--fp-border);
  margin: var(--fp-space-2xl) auto;
}


/* ==========================================================================
   HERO SECTION
   ========================================================================== */

.fp-hero {
  position: relative;
  min-height: 70vh;
  display: flex;
  align-items: center;
  justify-content: center;
  text-align: center;
  overflow: hidden;
  background-color: var(--fp-paper-dark);
}

.fp-hero-content {
  position: relative;
  z-index: 2;
  max-width: 720px;
  padding: var(--fp-space-xl) var(--fp-space-md);
}

.fp-hero h1 {
  font-family: var(--fp-font-display);
  font-size: clamp(2.25rem, 5vw, var(--fp-text-4xl));
  font-weight: 400;
  line-height: 1.15;
  margin-bottom: var(--fp-space-md);
  color: var(--fp-ink);
}

.fp-hero p {
  font-family: var(--fp-font-display);
  font-size: var(--fp-text-lg);
  color: var(--fp-ink-muted);
  margin: 0 auto var(--fp-space-lg);
  max-width: 520px;
}

.fp-hero-buttons {
  display: flex;
  justify-content: center;
  gap: var(--fp-space-sm);
  flex-wrap: wrap;
}


/* ==========================================================================
   GIFT COLLECTION GRID (4-column)
   ========================================================================== */

.fp-gift-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: var(--fp-space-md);
  max-width: var(--fp-content-width);
  margin: 0 auto;
  padding: 0 var(--fp-space-md);
}

.fp-gift-card {
  position: relative;
  overflow: hidden;
  aspect-ratio: 3 / 4;
  cursor: pointer;
}

.fp-gift-card img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 0.6s var(--fp-ease);
}

.fp-gift-card:hover img {
  transform: scale(1.04);
}

.fp-gift-card-label {
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  padding: var(--fp-space-md);
  background: linear-gradient(to top, rgba(26,26,26,0.5) 0%, transparent 100%);
}

.fp-gift-card-label span {
  font-family: var(--fp-font-display);
  font-size: var(--fp-text-lg);
  color: var(--fp-white);
  font-weight: 400;
}


/* ==========================================================================
   EDITOR'S PICKS (3-column cards)
   ========================================================================== */

.fp-picks-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--fp-space-lg);
  max-width: var(--fp-content-width);
  margin: 0 auto;
  padding: 0 var(--fp-space-md);
}

.fp-pick-card {
  text-align: left;
}

.fp-pick-card-image {
  aspect-ratio: 4 / 5;
  overflow: hidden;
  margin-bottom: var(--fp-space-sm);
  background-color: var(--fp-paper-dark);
}

.fp-pick-card-image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 0.6s var(--fp-ease);
}

.fp-pick-card:hover .fp-pick-card-image img {
  transform: scale(1.03);
}

.fp-pick-card h4 {
  font-family: var(--fp-font-display);
  font-size: var(--fp-text-md);
  margin-bottom: 0.25rem;
}

.fp-pick-card p {
  font-size: var(--fp-text-sm);
  color: var(--fp-ink-muted);
  line-height: 1.5;
}


/* ==========================================================================
   SPLIT SECTION (Coffee Table Books Spotlight)
   ========================================================================== */

.fp-split {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 0;
  max-width: var(--fp-wide-width);
  margin: 0 auto;
  min-height: 500px;
}

.fp-split-image {
  overflow: hidden;
  background-color: var(--fp-paper-dark);
}

.fp-split-image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.fp-split-content {
  display: flex;
  flex-direction: column;
  justify-content: center;
  padding: var(--fp-space-xl);
}

.fp-split-content h2 {
  font-family: var(--fp-font-display);
  font-size: var(--fp-text-3xl);
  margin-bottom: var(--fp-space-lg);
}

.fp-category-list {
  list-style: none;
  padding: 0;
  margin: 0 0 var(--fp-space-lg);
}

.fp-category-list li {
  border-bottom: 1px solid var(--fp-border);
}

.fp-category-list li a {
  display: block;
  padding: 0.75rem 0;
  font-family: var(--fp-font-body);
  font-size: var(--fp-text-base);
  color: var(--fp-ink-light);
  transition: color var(--fp-duration) var(--fp-ease),
              padding-left var(--fp-duration) var(--fp-ease);
}

.fp-category-list li a:hover {
  color: var(--fp-olive);
  padding-left: 0.5rem;
}


/* ==========================================================================
   AESTHETIC TILES (4-tile minimal grid)
   ========================================================================== */

.fp-aesthetic-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 2px;
  max-width: var(--fp-wide-width);
  margin: 0 auto;
}

.fp-aesthetic-tile {
  position: relative;
  aspect-ratio: 1;
  overflow: hidden;
  cursor: pointer;
}

.fp-aesthetic-tile img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 0.8s var(--fp-ease);
}

.fp-aesthetic-tile:hover img {
  transform: scale(1.06);
}

.fp-aesthetic-tile-label {
  position: absolute;
  inset: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  background: rgba(26, 26, 26, 0.15);
  transition: background var(--fp-duration) var(--fp-ease);
}

.fp-aesthetic-tile:hover .fp-aesthetic-tile-label {
  background: rgba(26, 26, 26, 0.3);
}

.fp-aesthetic-tile-label span {
  font-family: var(--fp-font-display);
  font-size: var(--fp-text-xl);
  color: var(--fp-white);
  letter-spacing: 0.02em;
}


/* ==========================================================================
   EDITORIAL GRID (Paper & Stationery / Objects)
   ========================================================================== */

.fp-editorial-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: var(--fp-space-md);
  max-width: var(--fp-content-width);
  margin: 0 auto;
  padding: 0 var(--fp-space-md);
}

.fp-editorial-card {
  text-align: center;
}

.fp-editorial-card-image {
  aspect-ratio: 1;
  overflow: hidden;
  margin-bottom: var(--fp-space-sm);
  background-color: var(--fp-paper-dark);
}

.fp-editorial-card-image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 0.6s var(--fp-ease);
}

.fp-editorial-card:hover .fp-editorial-card-image img {
  transform: scale(1.03);
}

.fp-editorial-card h5 {
  font-family: var(--fp-font-body);
  font-size: var(--fp-text-sm);
  font-weight: 500;
  letter-spacing: 0.04em;
  text-transform: uppercase;
}


/* ==========================================================================
   ARTICLE PREVIEWS (Magazine-style)
   ========================================================================== */

.fp-articles-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--fp-space-lg);
  max-width: var(--fp-content-width);
  margin: 0 auto;
  padding: 0 var(--fp-space-md);
}

.fp-article-card {
  border-bottom: 1px solid var(--fp-border);
  padding-bottom: var(--fp-space-md);
}

.fp-article-card-image {
  aspect-ratio: 16 / 10;
  overflow: hidden;
  margin-bottom: var(--fp-space-sm);
  background-color: var(--fp-paper-dark);
}

.fp-article-card-image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 0.6s var(--fp-ease);
}

.fp-article-card:hover .fp-article-card-image img {
  transform: scale(1.03);
}

.fp-article-card .fp-overline {
  margin-bottom: 0.375rem;
  display: block;
}

.fp-article-card h4 {
  font-family: var(--fp-font-display);
  font-size: var(--fp-text-lg);
  line-height: 1.35;
  margin-bottom: 0.5rem;
}

.fp-article-card p {
  font-size: var(--fp-text-sm);
  color: var(--fp-ink-muted);
  line-height: 1.6;
}


/* ==========================================================================
   SEASONAL STRIP
   ========================================================================== */

.fp-seasonal-strip {
  background-color: var(--fp-paper-dark);
  text-align: center;
  padding: var(--fp-space-xl) var(--fp-space-md);
}

.fp-seasonal-strip .fp-overline {
  margin-bottom: var(--fp-space-xs);
  display: block;
}

.fp-seasonal-strip h3 {
  font-family: var(--fp-font-display);
  font-size: var(--fp-text-2xl);
  margin-bottom: var(--fp-space-sm);
}


/* ==========================================================================
   NEWSLETTER
   ========================================================================== */

.fp-newsletter {
  text-align: center;
  max-width: 480px;
  margin: 0 auto;
  padding: var(--fp-space-2xl) var(--fp-space-md);
}

.fp-newsletter h3 {
  font-family: var(--fp-font-display);
  font-size: var(--fp-text-xl);
  margin-bottom: var(--fp-space-xs);
}

.fp-newsletter p {
  font-family: var(--fp-font-display);
  font-size: var(--fp-text-base);
  color: var(--fp-ink-muted);
  margin: 0 auto var(--fp-space-md);
}

.fp-newsletter-form {
  display: flex;
  gap: 0;
  max-width: 400px;
  margin: 0 auto;
}

.fp-newsletter-form input[type="email"] {
  flex: 1;
  font-family: var(--fp-font-body);
  font-size: var(--fp-text-sm);
  padding: 0.875rem 1rem;
  border: 1px solid var(--fp-border);
  border-right: none;
  background: var(--fp-white);
  color: var(--fp-ink);
  outline: none;
  transition: border-color var(--fp-duration) var(--fp-ease);
}

.fp-newsletter-form input[type="email"]:focus {
  border-color: var(--fp-olive);
}

.fp-newsletter-form input[type="email"]::placeholder {
  color: var(--fp-ink-muted);
}

.fp-newsletter-form button {
  font-family: var(--fp-font-body);
  font-size: var(--fp-text-sm);
  font-weight: 500;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  padding: 0.875rem 1.5rem;
  background: var(--fp-ink);
  color: var(--fp-paper);
  border: 1px solid var(--fp-ink);
  cursor: pointer;
  transition: background var(--fp-duration) var(--fp-ease);
}

.fp-newsletter-form button:hover {
  background: var(--fp-olive);
  border-color: var(--fp-olive);
}


/* ==========================================================================
   FOOTER
   ========================================================================== */

footer,
.ct-footer {
  background-color: var(--fp-ink) !important;
  color: var(--fp-paper) !important;
}

.ct-footer a {
  color: rgba(246, 243, 238, 0.7) !important;
  transition: color var(--fp-duration) var(--fp-ease);
}

.ct-footer a:hover {
  color: var(--fp-paper) !important;
}

.ct-footer .ct-widget-title,
.ct-footer h2,
.ct-footer h3 {
  font-family: var(--fp-font-body) !important;
  font-size: var(--fp-text-xs) !important;
  font-weight: 500 !important;
  letter-spacing: 0.1em !important;
  text-transform: uppercase !important;
  color: rgba(246, 243, 238, 0.5) !important;
  margin-bottom: var(--fp-space-sm) !important;
}

/* Footer copyright bar */
.ct-footer [data-column="copyright"] {
  font-size: var(--fp-text-xs);
  color: rgba(246, 243, 238, 0.4);
}


/* ==========================================================================
   AMAZON AFFILIATE DISCLOSURE
   ========================================================================== */

.fp-affiliate-disclosure {
  font-family: var(--fp-font-body);
  font-size: var(--fp-text-xs);
  color: var(--fp-ink-muted);
  border-top: 1px solid var(--fp-border);
  padding-top: var(--fp-space-sm);
  margin-top: var(--fp-space-lg);
  line-height: 1.5;
}


/* ==========================================================================
   PRODUCT CARDS (for affiliate links)
   ========================================================================== */

.fp-product-card {
  text-align: left;
}

.fp-product-card-image {
  aspect-ratio: 3 / 4;
  overflow: hidden;
  margin-bottom: var(--fp-space-sm);
  background-color: var(--fp-paper-dark);
  display: flex;
  align-items: center;
  justify-content: center;
}

.fp-product-card-image img {
  width: 100%;
  height: 100%;
  object-fit: contain;
  padding: var(--fp-space-md);
  transition: transform 0.6s var(--fp-ease);
}

.fp-product-card:hover .fp-product-card-image img {
  transform: scale(1.05);
}

.fp-product-card h5 {
  font-family: var(--fp-font-display);
  font-size: var(--fp-text-base);
  font-weight: 400;
  line-height: 1.4;
  margin-bottom: 0.25rem;
}

.fp-product-card .fp-product-source {
  font-size: var(--fp-text-xs);
  color: var(--fp-ink-muted);
  letter-spacing: 0.02em;
}


/* ==========================================================================
   WORDPRESS BLOCK OVERRIDES
   ========================================================================== */

/* Cover block */
.wp-block-cover {
  border-radius: 0 !important;
}

/* Separator */
.wp-block-separator {
  border-color: var(--fp-border) !important;
  max-width: 60px;
  margin: var(--fp-space-xl) auto !important;
}

/* Quote block */
.wp-block-quote {
  border-left: 2px solid var(--fp-olive) !important;
  padding-left: var(--fp-space-md) !important;
  font-family: var(--fp-font-display);
  font-size: var(--fp-text-lg);
  font-style: italic;
  color: var(--fp-ink-light);
}

/* Group block backgrounds */
.wp-block-group.has-background {
  border-radius: 0 !important;
}

/* Columns block gap */
.wp-block-columns {
  gap: var(--fp-space-lg) !important;
}

/* Image block */
.wp-block-image img {
  border-radius: 0 !important;
}

/* Gallery */
.wp-block-gallery {
  gap: var(--fp-space-sm) !important;
}

/* Table */
.wp-block-table table {
  font-family: var(--fp-font-body);
  font-size: var(--fp-text-sm);
  border-color: var(--fp-border);
}

.wp-block-table th {
  font-weight: 500;
  text-transform: uppercase;
  font-size: var(--fp-text-xs);
  letter-spacing: 0.06em;
}


/* ==========================================================================
   POST / PAGE TEMPLATES
   ========================================================================== */

/* Single post */
.single-post .entry-header,
.single-post .wp-block-post-title {
  font-family: var(--fp-font-display);
  font-size: clamp(2rem, 4vw, var(--fp-text-4xl));
  text-align: center;
  max-width: var(--fp-narrow-width);
  margin: 0 auto;
}

.single-post .entry-content {
  max-width: var(--fp-narrow-width);
  margin: 0 auto;
}

/* Category / archive page */
.archive .page-title,
.category .page-title {
  font-family: var(--fp-font-display);
  font-size: var(--fp-text-3xl);
  text-align: center;
}

.archive .archive-description {
  text-align: center;
  max-width: var(--fp-narrow-width);
  margin: 0 auto var(--fp-space-xl);
}


/* ==========================================================================
   RESPONSIVE
   ========================================================================== */

@media (max-width: 999px) {
  .fp-gift-grid,
  .fp-editorial-grid,
  .fp-aesthetic-grid {
    grid-template-columns: repeat(2, 1fr);
  }

  .fp-picks-grid,
  .fp-articles-grid {
    grid-template-columns: repeat(2, 1fr);
  }

  .fp-split {
    grid-template-columns: 1fr;
  }

  .fp-split-content {
    padding: var(--fp-space-lg) var(--fp-space-md);
  }
}

@media (max-width: 689px) {
  :root {
    --fp-text-4xl: 2.25rem;
    --fp-text-3xl: 1.75rem;
    --fp-text-2xl: 1.5rem;
  }

  .fp-gift-grid {
    grid-template-columns: repeat(2, 1fr);
    gap: var(--fp-space-xs);
  }

  .fp-picks-grid {
    grid-template-columns: 1fr;
    gap: var(--fp-space-md);
  }

  .fp-articles-grid {
    grid-template-columns: 1fr;
  }

  .fp-editorial-grid {
    grid-template-columns: repeat(2, 1fr);
  }

  .fp-aesthetic-grid {
    grid-template-columns: repeat(2, 1fr);
  }

  .fp-hero {
    min-height: 60vh;
  }

  .fp-newsletter-form {
    flex-direction: column;
  }

  .fp-newsletter-form input[type="email"] {
    border-right: 1px solid var(--fp-border);
  }
}


/* ==========================================================================
   UTILITY CLASSES
   ========================================================================== */

.fp-container {
  max-width: var(--fp-content-width);
  margin: 0 auto;
  padding: 0 var(--fp-space-md);
}

.fp-container-narrow {
  max-width: var(--fp-narrow-width);
  margin: 0 auto;
  padding: 0 var(--fp-space-md);
}

.fp-container-wide {
  max-width: var(--fp-wide-width);
  margin: 0 auto;
  padding: 0 var(--fp-space-md);
}

.fp-text-center { text-align: center; }
.fp-mt-sm  { margin-top: var(--fp-space-sm); }
.fp-mt-md  { margin-top: var(--fp-space-md); }
.fp-mt-lg  { margin-top: var(--fp-space-lg); }
.fp-mt-xl  { margin-top: var(--fp-space-xl); }
.fp-mb-sm  { margin-bottom: var(--fp-space-sm); }
.fp-mb-md  { margin-bottom: var(--fp-space-md); }
.fp-mb-lg  { margin-bottom: var(--fp-space-lg); }
.fp-mb-xl  { margin-bottom: var(--fp-space-xl); }
.fp-pt-sm  { padding-top: var(--fp-space-sm); }
.fp-pt-lg  { padding-top: var(--fp-space-lg); }
.fp-pb-lg  { padding-bottom: var(--fp-space-lg); }
.fp-bg-paper { background-color: var(--fp-paper); }
.fp-bg-paper-dark { background-color: var(--fp-paper-dark); }

/* Fade-in animation for sections */
@keyframes fp-fade-up {
  from {
    opacity: 0;
    transform: translateY(20px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

.fp-animate {
  animation: fp-fade-up 0.6s var(--fp-ease) both;
}


/* ==========================================================================
   SCHEMA / SEO HIDDEN MARKUP
   ========================================================================== */

.fp-sr-only {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border: 0;
}
