/* ============================================================
   THE SIMPLE STUDIO — brand component layer for the block theme
   theme.json supplies color/type/spacing PRESETS; this file adds
   the component styling those presets can't express: the signature
   stacked-shadow buttons, soft cards, hero splashes, the rainbow
   footer stripe, and restyled WooCommerce product cards.
   Self-contained (no @import) so the theme ships standalone.
   ============================================================ */

:root{
  --pink:#ec3f8f; --teal:#1ba6bd; --coral:#ff6f5e; --gold:#f6b32e; --green:#5cb846; --laven:#9a6fd4;
  --navy:#163a61; --ink:#1f3a55; --muted:#6a7d8f; --line:#eceef0; --bg:#fff; --soft:#f6f8fa;
  --tint-pink:#fff4f8; --tint-teal:#eef6f8; --tint-green:#eef9f3; --tint-gold:#fff8ec; --tint-laven:#f4f0fb;
  --coral-shadow:#e0543f; --teal-shadow:#15879b; --pink-shadow:#cf2c79;
  --font-display:'Caveat Brush',cursive; --font-ui:'Fredoka',system-ui,sans-serif; --font-body:'Nunito',system-ui,sans-serif;
  --radius-pill:40px; --radius-card:26px; --radius-panel:22px; --radius-input:14px;
  --shadow-card:0 16px 40px rgba(22,58,97,.06); --shadow-hover:0 18px 38px rgba(22,58,97,.10);
  --rainbow-stripe:repeating-linear-gradient(90deg,var(--pink) 0 14.28%,var(--coral) 0 28.56%,var(--gold) 0 42.84%,var(--green) 0 57.12%,var(--teal) 0 71.4%,var(--laven) 0 100%);
}

body{ font-family:var(--font-body); color:var(--ink); -webkit-font-smoothing:antialiased; }

/* ---- brand display helper for hand-brushed headings in patterns ---- */
.tss-display{ font-family:var(--font-display); font-weight:400; letter-spacing:.005em; line-height:.96; }
.tss-kicker{ font-family:var(--font-ui); font-weight:600; font-size:14px; letter-spacing:.16em;
  text-transform:uppercase; color:var(--teal); }
.tss-rainbow > *:nth-child(6n+1){ color:var(--pink); }
.tss-rainbow > *:nth-child(6n+2){ color:var(--gold); }
.tss-rainbow > *:nth-child(6n+3){ color:var(--teal); }
.tss-rainbow > *:nth-child(6n+4){ color:var(--laven); }
.tss-rainbow > *:nth-child(6n+5){ color:var(--green); }
.tss-rainbow > *:nth-child(6n+6){ color:var(--coral); }

/* ---- paint-splash decoration (place inside a position:relative group) ---- */
.tss-splash{ position:absolute; border-radius:50%; pointer-events:none; z-index:0; }

/* ============================================================
   BUTTONS — signature stacked offset shadow that presses on click
   ============================================================ */
.wp-block-button__link{ font-family:var(--font-ui); font-weight:600; border-radius:var(--radius-pill);
  padding:13px 26px; transition:transform .12s, box-shadow .12s; }
.is-style-stacked-coral .wp-block-button__link{ background:var(--coral); color:#fff; box-shadow:0 5px 0 var(--coral-shadow); }
.is-style-stacked-coral .wp-block-button__link:hover{ box-shadow:0 7px 0 var(--coral-shadow); transform:translateY(-1px); }
.is-style-stacked-teal .wp-block-button__link{ background:var(--teal); color:#fff; box-shadow:0 5px 0 var(--teal-shadow); }
.is-style-stacked-teal .wp-block-button__link:hover{ box-shadow:0 7px 0 var(--teal-shadow); transform:translateY(-1px); }
.is-style-stacked-pink .wp-block-button__link{ background:var(--pink); color:#fff; box-shadow:0 5px 0 var(--pink-shadow); }
.is-style-stacked-pink .wp-block-button__link:hover{ box-shadow:0 7px 0 var(--pink-shadow); transform:translateY(-1px); }
.wp-block-button__link:active{ transform:translateY(1px); }
.is-style-ghost .wp-block-button__link{ background:#fff; border:2.5px solid var(--pink); color:var(--pink); padding:10.5px 24px; }
.is-style-ghost .wp-block-button__link:hover{ background:var(--tint-pink); }

/* ============================================================
   CARDS — soft 26px container + tinted category card group styles
   ============================================================ */
.is-style-soft-card{ background:#fff; border:1.5px solid var(--line); border-radius:var(--radius-card);
  padding:26px 28px; box-shadow:var(--shadow-card); }
.is-style-tint-card{ border-radius:var(--radius-card); padding:16px 16px 24px; text-align:center; transition:transform .15s; }
.is-style-tint-card:hover{ transform:translateY(-4px); }

/* ============================================================
   HEADER — sticky, blurred, circular overhanging logo, nav
   ============================================================ */
.wp-site-blocks > header.wp-block-template-part,
header.wp-block-template-part{ position:sticky; top:0; z-index:40; background:rgba(255,255,255,.94);
  backdrop-filter:saturate(1.2) blur(6px); border-bottom:1px solid var(--line); }
.tss-logo img,.custom-logo{ border-radius:50%; filter:drop-shadow(0 8px 18px rgba(22,58,97,.18)); }
.wp-block-navigation a{ font-family:var(--font-ui); font-weight:500; color:var(--navy); }
.wp-block-navigation a:hover{ color:var(--pink); }
.wp-block-navigation .current-menu-item a{ color:var(--pink); }

/* mini-cart bubble */
.tss-cart{ position:relative; width:46px; height:46px; border-radius:50%; background:var(--soft);
  display:grid; place-items:center; color:var(--navy); }
.tss-cart .count{ position:absolute; top:-3px; right:-3px; min-width:21px; height:21px; padding:0 5px;
  background:var(--coral); color:#fff; border-radius:11px; font:600 12px/21px var(--font-ui); text-align:center; border:2px solid #fff; }

/* ============================================================
   FOOTER — rainbow stripe + navy band
   ============================================================ */
.tss-rainbow-stripe{ height:10px; background:var(--rainbow-stripe); }
footer.wp-block-template-part{ background:var(--navy); color:#cdd9e6; }
footer.wp-block-template-part a{ color:#aebccc; }
footer.wp-block-template-part a:hover{ color:#fff; }
footer.wp-block-template-part h2,footer.wp-block-template-part h3,footer.wp-block-template-part h4{ color:#fff; }

/* ============================================================
   WOOCOMMERCE — restyled product cards, badges, buttons
   ============================================================ */
.woocommerce ul.products li.product,
ul.wc-block-product-template li{ list-style:none; }
.woocommerce ul.products li.product{ border:1.5px solid var(--line); border-radius:var(--radius-panel);
  overflow:hidden; background:#fff; transition:transform .15s, box-shadow .15s; padding-bottom:16px; }
.woocommerce ul.products li.product:hover{ transform:translateY(-4px); box-shadow:var(--shadow-hover); }
.woocommerce ul.products li.product img{ border-radius:0; margin-bottom:12px; }
.woocommerce ul.products li.product .woocommerce-loop-product__title{ font-family:var(--font-ui); font-weight:600;
  font-size:18px; color:var(--navy); padding:0 16px; }
.woocommerce ul.products li.product .price{ color:var(--navy); font-family:var(--font-ui); font-weight:600; padding:0 16px; }
.woocommerce ul.products li.product .price del{ color:var(--muted); font-weight:500; }
.woocommerce span.onsale{ background:var(--coral); color:#fff; border-radius:30px; font-family:var(--font-body);
  font-weight:800; font-size:12.5px; letter-spacing:.04em; text-transform:uppercase; min-height:0; padding:6px 12px; top:12px; left:12px; right:auto; margin:0; }
.woocommerce ul.products li.product .button,
.woocommerce a.button, .woocommerce button.button.alt{ background:var(--coral); color:#fff; border-radius:var(--radius-pill);
  font-family:var(--font-ui); font-weight:600; box-shadow:0 5px 0 var(--coral-shadow); }
.woocommerce a.button:hover, .woocommerce button.button.alt:hover{ background:var(--coral); box-shadow:0 7px 0 var(--coral-shadow); transform:translateY(-1px); }
.woocommerce .star-rating span{ color:var(--gold); }

/* product detail title in brand display */
.woocommerce div.product .product_title{ font-family:var(--font-display); font-weight:400; letter-spacing:.005em; color:var(--navy); }

/* cart / checkout summary cards */
.wc-block-components-totals-wrapper, .cart_totals{ background:var(--soft); border-radius:var(--radius-card); padding:24px; }

/* ---- hatched photo placeholder (used in patterns until real images are set) ---- */
.tss-hatch{ position:relative; overflow:hidden; display:grid; place-items:center;
  background:repeating-linear-gradient(135deg,rgba(27,166,189,.12) 0 11px,rgba(27,166,189,.2) 11px 22px); }
.tss-hatch span{ font:600 11.5px/1 var(--font-ui); letter-spacing:.03em; text-transform:uppercase;
  color:rgba(22,58,97,.5); background:rgba(255,255,255,.7); padding:5px 10px; border-radius:6px; }

/* ============================================================
   STATUS TAGS — category pills used on camps + the calendar
   ============================================================ */
.tss-tag{ display:inline-flex; align-items:center; gap:6px; font-family:var(--font-ui); font-weight:600;
  font-size:12.5px; letter-spacing:.02em; padding:5px 12px; border-radius:30px; line-height:1; }
.tss-tag::before{ content:''; width:8px; height:8px; border-radius:50%; background:currentColor; opacity:.9; }
.tss-tag.camp{   color:var(--green);  background:var(--tint-green); }
.tss-tag.party{  color:var(--pink);   background:var(--tint-pink); }
.tss-tag.studio{ color:var(--teal);   background:var(--tint-teal); }
.tss-tag.event{  color:var(--laven);  background:var(--tint-laven); }
.tss-tag.full{   color:var(--muted);  background:#eef1f4; }
.tss-tag.full::before{ background:var(--muted); }

/* ============================================================
   PAGE HEADERS — soft "page-top" band + section headers
   ============================================================ */
.tss-page-top{ background:var(--soft); border-bottom:1px solid var(--line); }
.tss-crumbs{ font-size:14px; font-weight:700; color:var(--muted); }
.tss-crumbs a{ color:var(--teal); text-decoration:none; }
.tss-crumbs a:hover{ color:var(--pink); }
.tss-sec-head{ text-align:center; }
.tss-sec-head .tss-kicker{ display:block; }

/* lead hero with optional photo split */
.tss-lead-hero{ position:relative; overflow:hidden; }
.tss-split{ display:grid; grid-template-columns:1.05fr .95fr; gap:48px; align-items:center; }
.tss-media{ border-radius:var(--radius-card); overflow:hidden; min-height:380px; box-shadow:var(--shadow-card); }
.tss-media img{ width:100%; height:100%; object-fit:cover; display:block; }
@media (max-width:781px){ .tss-split{ grid-template-columns:1fr; } }

/* ============================================================
   FEATURE / STEP / VALUE ROWS  (how camp works, what we believe)
   ============================================================ */
.tss-feat{ text-align:center; }
.tss-feat .ic{ width:64px; height:64px; border-radius:50%; display:grid; place-items:center;
  margin:0 auto 14px; font-size:28px; }
.tss-feat h3{ font-family:var(--font-ui); font-weight:600; font-size:20px; color:var(--navy); margin:0 0 6px; }
.tss-feat p{ font-size:15px; font-weight:600; color:var(--muted); margin:0; line-height:1.5; }

/* ============================================================
   CAMP CARDS — themed week cards on the Camps landing
   ============================================================ */
.tss-camp-card{ border:1.5px solid var(--line); border-radius:var(--radius-card); overflow:hidden; background:#fff;
  display:flex; flex-direction:column; transition:transform .15s, box-shadow .15s; height:100%; }
.tss-camp-card:hover{ transform:translateY(-4px); box-shadow:var(--shadow-hover); }
.tss-camp-card .top{ position:relative; height:180px; }
.tss-camp-card .top .tss-tag{ position:absolute; top:12px; left:12px; z-index:2; }
.tss-camp-card .body{ padding:20px 22px 22px; display:flex; flex-direction:column; flex:1; }
.tss-camp-card h3{ font-family:var(--font-display); font-weight:400; font-size:30px; color:var(--navy);
  margin:0 0 5px; letter-spacing:.005em; line-height:1.04; }
.tss-camp-card .when{ display:block; font-size:13.5px; font-weight:700; color:var(--muted); line-height:1.4; }
.tss-camp-card p{ font-size:14.5px; font-weight:600; color:#46586a; line-height:1.5; margin:12px 0 16px; }
.tss-camp-card .foot{ display:flex; align-items:center; justify-content:space-between; margin-top:auto; gap:12px; }
.tss-camp-card .price{ font-family:var(--font-ui); font-weight:600; font-size:22px; color:var(--navy); }
.tss-camp-card .price small{ font-size:13px; font-weight:600; color:var(--muted); }

/* age bands */
.tss-age-pill{ border-radius:var(--radius-card); padding:22px 24px; }
.tss-age-pill .a{ font-family:var(--font-display); font-weight:400; font-size:38px; letter-spacing:.005em; line-height:1; }
.tss-age-pill .d{ font-size:14.5px; font-weight:700; margin-top:4px; }

/* ============================================================
   PARTY PACKAGES — pricing tiers
   ============================================================ */
.tss-pkg{ border:1.5px solid var(--line); border-radius:var(--radius-card); background:#fff; padding:28px 26px;
  display:flex; flex-direction:column; position:relative; height:100%; }
.tss-pkg.feature{ border-color:var(--pink); border-width:2.5px; box-shadow:var(--shadow-card); }
.tss-pkg .flag{ position:absolute; top:-13px; left:50%; transform:translateX(-50%); }
.tss-pkg h3{ font-family:var(--font-display); font-weight:400; font-size:30px; color:var(--navy); margin:0;
  letter-spacing:.005em; line-height:1.08; min-height:1.9em; }
.tss-pkg .price{ font-family:var(--font-ui); font-weight:600; font-size:40px; color:var(--navy); margin:8px 0 2px; }
.tss-pkg .per{ font-size:13.5px; font-weight:700; color:var(--muted); margin:0 0 18px; }
.tss-pkg ul{ list-style:none; margin:0 0 22px; padding:0; display:grid; gap:11px; }
.tss-pkg li{ display:flex; gap:10px; align-items:flex-start; font-size:14.5px; font-weight:600; color:var(--ink); line-height:1.4; }
.tss-pkg li::before{ content:'✓'; color:var(--green); flex:none; font-weight:800; }
.tss-pkg .tss-cta{ margin-top:auto; }
.tss-checklist{ list-style:none; padding:0; margin:0; display:grid; gap:13px; }
.tss-checklist li{ display:flex; gap:11px; align-items:flex-start; font-size:16px; font-weight:600; color:var(--ink); }
.tss-checklist li::before{ content:'✓'; color:var(--green); font-weight:800; flex:none; }

/* ============================================================
   SESSIONS CALENDAR — month grid + upcoming list (manual entry)
   ============================================================ */
.tss-cal-card{ border:1.5px solid var(--line); border-radius:26px; background:#fff; padding:24px 26px 28px; box-shadow:var(--shadow-card); }
.tss-cal-head{ display:flex; align-items:center; justify-content:space-between; margin-bottom:18px; }
.tss-cal-head h2{ font-family:var(--font-display); font-weight:400; letter-spacing:.005em; font-size:42px; color:var(--navy); margin:0; white-space:nowrap; }
.tss-cal-arrows{ display:flex; gap:10px; }
.tss-cal-arrow{ width:42px; height:42px; border-radius:50%; border:1.5px solid var(--line); background:#fff;
  display:grid; place-items:center; cursor:pointer; color:var(--navy); font-size:18px; }
.tss-cal-arrow:hover{ background:var(--soft); }
.tss-cal-grid{ display:grid; grid-template-columns:repeat(7,1fr); gap:8px; }
.tss-cal-dow{ font-family:var(--font-ui); font-weight:600; font-size:12.5px; letter-spacing:.08em;
  text-transform:uppercase; color:var(--muted); text-align:center; padding:6px 0 10px; }
.tss-cal-day{ position:relative; min-height:82px; border-radius:16px; border:1.5px solid var(--line); background:#fff; padding:8px 9px; }
.tss-cal-day .dnum{ font-family:var(--font-ui); font-weight:600; font-size:15px; color:var(--navy); }
.tss-cal-day.out{ visibility:hidden; }
.tss-cal-day.past{ background:var(--soft); border-color:transparent; }
.tss-cal-day.past .dnum{ color:#b9c4cd; }
.tss-cal-day.open{ cursor:pointer; transition:transform .12s, box-shadow .12s, border-color .12s; }
.tss-cal-day.open:hover{ transform:translateY(-2px); box-shadow:var(--shadow-hover); border-color:var(--teal); }
.tss-cal-day.today{ border-color:var(--teal); border-width:2px; }
.tss-cal-dots{ display:flex; flex-wrap:wrap; gap:5px; margin-top:7px; }
.tss-cal-dots i{ width:9px; height:9px; border-radius:50%; display:block; }
.tss-cal-dots i.camp{ background:var(--green); } .tss-cal-dots i.party{ background:var(--pink); }
.tss-cal-dots i.studio{ background:var(--teal); } .tss-cal-dots i.event{ background:var(--laven); }
.tss-cal-legend{ display:flex; flex-wrap:wrap; gap:14px; margin-top:18px; }
.tss-cal-legend .li{ display:flex; align-items:center; gap:7px; font-size:13px; font-weight:700; color:var(--muted); }
.tss-cal-legend .sw{ width:12px; height:12px; border-radius:50%; }
.tss-ev-panel{ border:1.5px solid var(--line); border-radius:22px; background:#fff; padding:20px 22px; }
.tss-ev-panel h3{ font-family:var(--font-display); font-weight:400; font-size:30px; color:var(--navy); margin:0 0 10px; }
.tss-ev-row{ display:flex; align-items:center; gap:12px; padding:11px 0; border-bottom:1px dashed var(--line); }
.tss-ev-row:last-child{ border-bottom:none; }
.tss-ev-row .datebox{ flex:none; width:48px; height:50px; border-radius:12px; display:grid; place-content:center; text-align:center; background:var(--soft); }
.tss-ev-row .datebox .m{ display:block; font-family:var(--font-ui); font-weight:600; font-size:10px; letter-spacing:.1em; text-transform:uppercase; }
.tss-ev-row .datebox .d{ display:block; font-family:var(--font-ui); font-weight:600; font-size:19px; line-height:1; }
.tss-ev-row .t{ min-width:0; }
.tss-ev-row .t .n{ font-family:var(--font-ui); font-weight:600; font-size:15px; line-height:1.2; color:var(--navy); white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.tss-ev-row .t .s{ font-size:12.5px; font-weight:700; line-height:1.3; color:var(--muted); margin-top:3px; }

/* ============================================================
   WOOCOMMERCE — single product detail (gallery, qty, perks)
   ============================================================ */
.woocommerce div.product div.images img{ border-radius:24px; border:1.5px solid var(--line); }
.woocommerce div.product .woocommerce-product-gallery__trigger{ display:none; }
.woocommerce div.product p.price, .woocommerce div.product span.price{ font-family:var(--font-ui); font-weight:600;
  font-size:34px; color:var(--navy); }
.woocommerce div.product p.price del{ font-size:22px; color:var(--muted); }
.woocommerce .woocommerce-product-rating .star-rating span{ color:var(--gold); }
.woocommerce div.product form.cart{ display:flex; align-items:center; gap:14px; flex-wrap:wrap; margin:20px 0; }
.woocommerce .quantity .qty{ width:74px; height:50px; border:1.5px solid var(--line); border-radius:var(--radius-pill);
  text-align:center; font-family:var(--font-ui); font-weight:600; font-size:17px; color:var(--navy); }
.woocommerce div.product form.cart .button{ padding:14px 30px; font-size:17px; }
.woocommerce div.product .woocommerce-tabs ul.tabs li{ border-radius:var(--radius-pill) var(--radius-pill) 0 0; }
.woocommerce div.product .woocommerce-tabs ul.tabs li.active{ background:var(--soft); border-color:var(--line); }
/* perks row (pattern below the add-to-cart) */
.tss-perks{ display:flex; gap:10px; flex-wrap:wrap; }
.tss-perk{ display:flex; align-items:center; gap:8px; font-size:13.5px; font-weight:700; color:var(--navy);
  background:var(--soft); padding:9px 14px; border-radius:30px; }

/* ============================================================
   WOOCOMMERCE — archive filters sidebar
   ============================================================ */
.wc-block-product-collection .wc-block-product, .woocommerce .products .product{ text-align:left; }
.wp-block-woocommerce-filter-wrapper, .wc-block-filter-title{ font-family:var(--font-ui); }
.wc-block-components-product-sort-select select, .orderby{ border:1.5px solid var(--line); border-radius:var(--radius-pill);
  font-family:var(--font-ui); font-weight:600; padding:8px 16px; color:var(--navy); }

/* ============================================================
   WOOCOMMERCE — cart, checkout, my-account
   ============================================================ */
.woocommerce-account .woocommerce-MyAccount-navigation ul{ list-style:none; margin:0; padding:0; display:grid; gap:4px; }
.woocommerce-account .woocommerce-MyAccount-navigation li a{ display:block; padding:12px 16px; border-radius:14px;
  font-family:var(--font-ui); font-weight:600; font-size:15px; color:var(--navy); text-decoration:none; }
.woocommerce-account .woocommerce-MyAccount-navigation li a:hover{ background:var(--soft); }
.woocommerce-account .woocommerce-MyAccount-navigation li.is-active a{ background:var(--tint-pink); color:var(--pink); }
.woocommerce-account .woocommerce-MyAccount-content{ font-weight:600; }
.woocommerce table.shop_table{ border-radius:var(--radius-card); border:1.5px solid var(--line); border-collapse:separate; }
.woocommerce-checkout #payment, .woocommerce .cart-collaterals .cart_totals{ background:var(--soft); border-radius:var(--radius-card); }
.wc-block-checkout__actions_row .wc-block-components-button, .wc-block-cart__submit-button{ border-radius:var(--radius-pill);
  background:var(--coral); box-shadow:0 5px 0 var(--coral-shadow); font-family:var(--font-ui); font-weight:600; }

/* ============================================================
   TESTIMONIALS — quote cards with rainbow stars
   ============================================================ */
.tss-testimonial{ background:#fff; border:1.5px solid var(--line); border-radius:var(--radius-card);
  padding:24px 26px; box-shadow:var(--shadow-card); display:flex; flex-direction:column; gap:10px; }
.tss-testimonial .stars{ display:flex; gap:2px; color:var(--gold); font-size:18px; line-height:1; }
.tss-testimonial .q{ font-size:15.5px; font-weight:600; color:var(--ink); line-height:1.55; margin:6px 0 4px;
  text-wrap:pretty; }
.tss-testimonial .name{ font-family:var(--font-ui); font-weight:600; font-size:14px; color:var(--muted); }

/* ============================================================
   GALLERY — CSS-columns masonry of studio + finished-art photos
   ============================================================ */
.tss-gallery{ column-count:3; column-gap:18px; }
.tss-gallery .tss-gallery-tile{ break-inside:avoid; margin:0 0 18px; border-radius:var(--radius-panel);
  overflow:hidden; border:1.5px solid var(--line); background:#fff; display:block; transition:transform .15s, box-shadow .15s; }
.tss-gallery .tss-gallery-tile:hover{ transform:translateY(-3px); box-shadow:var(--shadow-hover); }
.tss-gallery .tss-gallery-tile img{ width:100%; height:100%; object-fit:cover; display:block; }
@media (max-width:960px){ .tss-gallery{ column-count:2; } }
@media (max-width:560px){ .tss-gallery{ column-count:1; } }

/* ============================================================
   FAQ — accordion using native <details>
   ============================================================ */
.tss-faq{ display:flex; flex-direction:column; gap:12px; }
.tss-faq-item{ border:1.5px solid var(--line); border-radius:var(--radius-panel); background:#fff; overflow:hidden; }
.tss-faq-item summary{ list-style:none; cursor:pointer; padding:18px 22px;
  font-family:var(--font-ui); font-weight:600; font-size:17px; color:var(--navy);
  display:flex; align-items:center; justify-content:space-between; gap:16px; }
.tss-faq-item summary::-webkit-details-marker{ display:none; }
.tss-faq-item summary .pm{ flex:none; width:28px; height:28px; border-radius:50%; background:var(--tint-pink); color:var(--pink);
  display:grid; place-items:center; font-size:18px; line-height:1; transition:transform .18s; }
.tss-faq-item[open] summary .pm{ transform:rotate(45deg); }
.tss-faq-item .ans{ padding:0 22px 20px; }
.tss-faq-item .ans p{ margin:0; font-size:15.5px; font-weight:600; color:#46586a; line-height:1.6; }

/* ============================================================
   CONTACT — form + info card
   ============================================================ */
.tss-contact{ display:grid; grid-template-columns:1fr 380px; gap:40px; align-items:start; }
.tss-contact-form{ padding:28px 30px; }
.tss-contact-form .tss-fields{ display:grid; grid-template-columns:1fr 1fr; gap:16px; }
.tss-contact-form .tss-field{ display:flex; flex-direction:column; gap:7px; }
.tss-contact-form .tss-field.full{ grid-column:1/-1; }
.tss-contact-form label{ font-family:var(--font-ui); font-weight:600; font-size:14px; color:var(--navy); }
.tss-contact-form input,
.tss-contact-form select,
.tss-contact-form textarea{ width:100%; border:1.5px solid var(--line); border-radius:var(--radius-input);
  padding:13px 16px; font:600 15.5px/1.4 var(--font-body); color:var(--ink); background:#fff;
  transition:border-color .15s, box-shadow .15s; }
.tss-contact-form textarea{ min-height:128px; resize:vertical; font-family:var(--font-body); }
.tss-contact-form input:focus,
.tss-contact-form select:focus,
.tss-contact-form textarea:focus{ outline:none; border-color:var(--teal); box-shadow:0 0 0 4px rgba(27,166,189,.16); }
.tss-contact-form .tss-submit{ margin-top:6px; }
.tss-contact-form .tss-sent{ text-align:center; padding:30px 0; }
.tss-contact-form .tss-sent .ic{ font-size:46px; line-height:1; }
.tss-contact-form .tss-sent h3{ font-family:var(--font-display); font-weight:400; font-size:36px;
  color:var(--navy); margin:10px 0 6px; letter-spacing:.005em; }
.tss-contact-form .tss-sent p{ font-weight:600; color:var(--muted); margin:0; }

.tss-info-card{ border:1.5px solid var(--line); border-radius:var(--radius-card); overflow:hidden; background:#fff;
  box-shadow:var(--shadow-card); }
.tss-info-card .map{ height:180px; }
.tss-info-card .rows{ padding:22px 24px; display:grid; gap:18px; }
.tss-info-row{ display:flex; gap:13px; align-items:flex-start; }
.tss-info-row .ic{ flex:none; width:40px; height:40px; border-radius:12px; display:grid; place-items:center;
  background:var(--soft); font-size:18px; }
.tss-info-row .t{ min-width:0; }
.tss-info-row .t b{ display:block; font-family:var(--font-ui); font-weight:600; font-size:15px; color:var(--navy); line-height:1.3; }
.tss-info-row .t span{ font-size:14px; font-weight:600; color:var(--muted); line-height:1.4; }
@media (max-width:781px){
  .tss-contact{ grid-template-columns:1fr; }
  .tss-contact-form .tss-fields{ grid-template-columns:1fr; }
}

/* ============================================================
   ARTICLE — single Tips / blog post body
   ============================================================ */
.tss-article{ font-size:17px; font-weight:500; color:var(--ink); line-height:1.7; }
.tss-article p{ margin:0 0 1.1em; }
.tss-article h2{ font-family:var(--font-ui); font-weight:600; font-size:28px; color:var(--navy);
  margin:1.6em 0 .5em; letter-spacing:.002em; }
.tss-article h3{ font-family:var(--font-ui); font-weight:600; font-size:22px; color:var(--navy); margin:1.4em 0 .5em; }
.tss-article a{ color:var(--pink); text-decoration:underline; text-decoration-thickness:1.5px; text-underline-offset:3px; }
.tss-article a:hover{ color:var(--coral); }
.tss-article blockquote{ border-left:4px solid var(--teal); background:var(--tint-teal); border-radius:0 14px 14px 0;
  margin:1.4em 0; padding:18px 22px; font-family:var(--font-ui); font-weight:500; color:var(--navy); }
.tss-article blockquote p{ margin:0; }
.tss-article ul,.tss-article ol{ padding-left:1.3em; margin:0 0 1.1em; }
.tss-article ul li,.tss-article ol li{ margin:.4em 0; }
.tss-article ul li::marker{ color:var(--pink); }
.tss-article img,.tss-article figure{ border-radius:18px; overflow:hidden; }
.tss-article hr{ border:none; height:10px; background:var(--rainbow-stripe); border-radius:6px; opacity:.7; margin:2em 0; }

/* ============================================================
   404 — "happy accident" splash treatment
   ============================================================ */
.tss-404{ text-align:center; margin:0 auto 18px; }
.tss-404 .splat{ display:inline-flex; align-items:center; gap:6px; font-family:var(--font-display); font-weight:400;
  font-size:clamp(120px,18vw,200px); line-height:1; color:var(--navy); letter-spacing:.005em; }
.tss-404 .d1{ color:var(--pink); }
.tss-404 .d2{ color:var(--teal); }
.tss-404 .o{ position:relative; width:.7em; height:.7em; border-radius:50%;
  background:radial-gradient(circle at 38% 36%,var(--gold) 0 40%,var(--coral) 41% 70%,var(--pink) 71% 100%);
  box-shadow:0 14px 0 rgba(255,111,94,.18); }

/* ============================================================
   SEARCH — restyle the core search block on archive/search pages
   ============================================================ */
.wp-block-search__inside-wrapper{ border:1.5px solid var(--line); border-radius:var(--radius-pill); background:#fff;
  padding:6px 6px 6px 18px; max-width:560px; box-shadow:var(--shadow-card); }
.wp-block-search__input{ border:none; outline:none; font:600 16px/1.4 var(--font-body); color:var(--ink); background:transparent; }
.wp-block-search__button{ border-radius:var(--radius-pill); background:var(--coral); color:#fff;
  font-family:var(--font-ui); font-weight:600; padding:10px 22px; box-shadow:0 5px 0 var(--coral-shadow); border:none; }

/* ============================================================
   RESPONSIVE — collapse two-column page layouts on small screens
   ============================================================ */
@media (max-width:781px){
  .tss-cal-grid .tss-cal-day{ min-height:62px; }
  .tss-cal-layout{ grid-template-columns:1fr !important; }
  .tss-camp-collection{ grid-template-columns:1fr !important; }
}
@media (max-width:600px){
  .tss-cal-grid{ gap:5px; }
  .tss-cal-day .tss-cal-dots i{ width:7px; height:7px; }
}
