/*
Theme Name: Luck of the Roll
Theme URI: https://luckoftheroll.com
Description: Child theme of Hello Elementor for Luck of the Roll — online D&D campaigns for kids & teens. Punk-zine / indie tabletop aesthetic: Bagel Fat One headlines, Nunito body, thick black borders, hard offset shadows. All page content is built from native Elementor widgets; this stylesheet carries the entire visual design via lotr-* CSS classes.
Author: Luck of the Roll
Author URI: https://luckoftheroll.com
Template: hello-elementor
Version: 2.0.0
License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Text Domain: luck-of-the-roll
*/

/* =========================================================================
   DESIGN TOKENS
   ========================================================================= */
:root{
  --mint:#d6f0c8; --teal:#bfe9e0; --lav:#e2d6f5; --cream:#f6f2e3;
  --acid:#5cf062; --magenta:#e83bb6; --magenta-dk:#b51d8c;
  --violet:#7a3bd9; --violet-dk:#5a26b0; --ink:#1a1325;
  --border:3px solid var(--ink);
  --border-thick:4px solid var(--ink);
  --shadow:5px 5px 0 var(--ink);
  --shadow-lg:7px 7px 0 var(--ink);
}

/* =========================================================================
   BASE TYPOGRAPHY (applies inside Elementor pages)
   ========================================================================= */
.elementor-element.lotr-display .elementor-heading-title,
.lotr-display .elementor-heading-title{font-family:'Bagel Fat One',cursive;font-weight:400;line-height:.95;margin:0}

/* Text Editor body copy */
.lotr-body{font-family:'Nunito',system-ui,sans-serif;font-weight:600;color:var(--ink);font-size:15px;line-height:1.6}
.lotr-body p{margin:0 0 12px}
.lotr-body p:last-child{margin-bottom:0}
.lotr-body a{color:var(--magenta);text-decoration:underline}
.lotr-body strong{font-weight:900}
.lotr-body.lotr-body-lg{font-size:17px;line-height:1.65}
.lotr-body.lotr-body-violet{color:var(--violet);font-weight:800}
.lotr-body.lotr-on-dark,.lotr-body.lotr-on-dark p{color:var(--lav)}

/* =========================================================================
   SECTION SCAFFOLDING
   Sections use Content Width = Full; we re-box the inner container.
   ========================================================================= */
.lotr-section{padding:80px 72px}
.lotr-section > .elementor-container{max-width:1180px;margin-left:auto;margin-right:auto}
.lotr-head{padding:80px 72px 0}
.lotr-head > .elementor-container{max-width:1180px;margin-left:auto;margin-right:auto}
.lotr-tail{padding:36px 72px 90px}
.lotr-tail > .elementor-container{max-width:1180px;margin-left:auto;margin-right:auto}
.lotr-wrap > .elementor-container{max-width:1180px;margin-left:auto;margin-right:auto}

/* Background utilities */
.lotr-bg-cream{background:var(--cream)}
.lotr-bg-mint{background:var(--mint)}
.lotr-bg-lav{background:var(--lav)}
.lotr-bg-teal{background:var(--teal)}
.lotr-bg-ink{background:var(--ink)}
.lotr-bg-magenta{background:var(--magenta)}
.lotr-bg-acid{background:var(--acid)}
.lotr-border-top{border-top:var(--border-thick)}
.lotr-border-bottom{border-bottom:var(--border-thick)}

/* =========================================================================
   GRID LAYOUTS  (neutralise Elementor column widths, drive with CSS grid)
   ========================================================================= */
.lotr-grid > .elementor-container{
  display:grid !important;gap:28px;max-width:1180px;margin-left:auto;margin-right:auto;align-items:stretch;
}
.lotr-grid > .elementor-container > .elementor-column{
  width:100% !important;max-width:100% !important;margin:0;
}
.lotr-grid-2 > .elementor-container{grid-template-columns:1fr 1fr !important}
.lotr-grid-3 > .elementor-container{grid-template-columns:repeat(3,1fr) !important}
.lotr-grid-5 > .elementor-container{grid-template-columns:repeat(5,1fr) !important;gap:20px}
.lotr-grid-portrait > .elementor-container{grid-template-columns:1fr 1.4fr !important;gap:64px;align-items:start}
.lotr-grid-split > .elementor-container{grid-template-columns:1fr 1fr !important;gap:56px;align-items:start}
.lotr-grid-faq > .elementor-container{grid-template-columns:280px 1fr !important;gap:64px;align-items:start}
.lotr-grid > .elementor-container > .elementor-column > .elementor-widget-wrap{align-content:start}

/* =========================================================================
   SECTION TAG / EYEBROW  (Heading widget + .lotr-eyebrow)
   ========================================================================= */
.lotr-eyebrow .elementor-heading-title{
  display:inline-flex;align-items:center;gap:8px;
  font-family:'Special Elite',monospace;font-weight:400;font-size:12px;
  text-transform:uppercase;letter-spacing:3px;color:var(--magenta);line-height:1;
}
.lotr-eyebrow .elementor-heading-title::before{
  content:"";display:inline-block;width:24px;height:2px;background:currentColor;flex-shrink:0;
}
.lotr-eyebrow{margin-bottom:16px}
.lotr-eyebrow.is-acid .elementor-heading-title{color:var(--acid)}
.lotr-eyebrow.is-violet .elementor-heading-title{color:var(--violet)}
.lotr-eyebrow.is-violet-dk .elementor-heading-title{color:var(--violet-dk)}
.lotr-eyebrow.is-ink .elementor-heading-title{color:var(--ink)}

/* =========================================================================
   DISPLAY HEADINGS
   ========================================================================= */
.lotr-h1 .elementor-heading-title{font-family:'Bagel Fat One',cursive;font-weight:400;line-height:.95;text-transform:uppercase;font-size:clamp(44px,6vw,88px);color:var(--ink)}
.lotr-h2 .elementor-heading-title{font-family:'Bagel Fat One',cursive;font-weight:400;line-height:.97;text-transform:uppercase;font-size:clamp(32px,4.5vw,58px);color:var(--ink)}
.lotr-h3 .elementor-heading-title{font-family:'Bagel Fat One',cursive;font-weight:400;line-height:1;text-transform:uppercase;font-size:clamp(28px,3.4vw,40px);color:var(--ink)}
.lotr-color-magenta .elementor-heading-title{color:var(--magenta)}
.lotr-color-violet .elementor-heading-title{color:var(--violet)}
.lotr-color-acid .elementor-heading-title{color:var(--acid)}
.lotr-color-cream .elementor-heading-title{color:var(--cream)}
.lotr-color-ink .elementor-heading-title{color:var(--ink)}

/* Big hero stacked rows (homepage) */
.lotr-hero-row1 .elementor-heading-title{font-family:'Bagel Fat One',cursive;text-transform:uppercase;font-size:clamp(58px,8vw,120px);color:var(--ink);transform:rotate(-1deg);line-height:.9}
.lotr-hero-row2 .elementor-heading-title{font-family:'Special Elite',monospace;letter-spacing:6px;font-size:clamp(24px,3.4vw,50px);color:var(--violet);text-transform:uppercase}
.lotr-hero-row3 .elementor-heading-title{font-family:'Bagel Fat One',cursive;text-transform:uppercase;font-size:clamp(58px,8vw,120px);color:var(--magenta);-webkit-text-stroke:3px var(--ink);paint-order:stroke fill;transform:rotate(2deg);line-height:.9}

/* Stroked / outline headline treatment (CTA strips, safety) */
.lotr-stroke .elementor-heading-title{-webkit-text-stroke:3px var(--ink);paint-order:stroke fill}
.lotr-stroke-cream .elementor-heading-title{color:var(--cream)}
.lotr-stroke-2 .elementor-heading-title{-webkit-text-stroke:2px var(--ink);paint-order:stroke fill}

/* =========================================================================
   BUTTONS  (Button widget + .lotr-btn + variant)
   ========================================================================= */
.lotr-btn .elementor-button-wrapper{display:flex}
.lotr-btn .elementor-button{
  font-family:'Bagel Fat One',cursive;font-weight:400;font-size:18px;
  text-transform:uppercase;letter-spacing:1px;line-height:1.15;
  padding:14px 24px;border:var(--border-thick);border-radius:0;
  box-shadow:var(--shadow-lg);transition:all .12s ease;
  display:inline-flex;align-items:center;gap:10px;
}
.lotr-btn .elementor-button:hover{transform:translate(-2px,-2px);box-shadow:9px 9px 0 var(--ink)}
.lotr-btn .elementor-button:active{transform:translate(2px,2px);box-shadow:2px 2px 0 var(--ink)}
.lotr-btn-pink .elementor-button{background:var(--magenta);color:var(--cream)}
.lotr-btn-acid .elementor-button{background:var(--acid);color:var(--ink)}
.lotr-btn-outline .elementor-button{background:var(--cream);color:var(--ink)}
.lotr-btn-dk .elementor-button{background:var(--ink);color:var(--cream)}
.lotr-btn-dk-cream .elementor-button{background:var(--ink);color:var(--cream);box-shadow:5px 5px 0 var(--cream)}
.lotr-btn-lg .elementor-button{font-size:22px;padding:18px 32px}

/* =========================================================================
   CARDS  (cards are Elementor columns inside a grid)
   ========================================================================= */
.lotr-card{
  border:var(--border-thick);box-shadow:var(--shadow-lg);
  padding:32px 28px;background:var(--cream);overflow:hidden;position:relative;
  transition:transform .15s ease,box-shadow .15s ease;
}
.lotr-card:hover{transform:translate(-3px,-3px);box-shadow:10px 10px 0 var(--ink)}
.lotr-card-mint{background:var(--mint)}
.lotr-card-teal{background:var(--teal)}
.lotr-card-lav{background:var(--lav)}
.lotr-card-cream{background:var(--cream)}
.lotr-card-ink{background:var(--ink)}
.lotr-card-rot-l{transform:rotate(-.5deg)}
.lotr-card-rot-r{transform:rotate(.5deg)}
.lotr-card-rot-l:hover,.lotr-card-rot-r:hover{transform:translate(-3px,-3px) rotate(0)}
.lotr-card > .elementor-widget-wrap{gap:0}
.lotr-card .elementor-widget{margin-bottom:14px}
.lotr-card .elementor-widget:last-child{margin-bottom:0}

/* Card display titles inside cards inherit lotr-h3 sizing when tagged */
.lotr-card .lotr-h3 .elementor-heading-title{font-size:clamp(24px,2.6vw,30px)}

/* Big faint roman/index numeral on a card (Heading + .lotr-card-num) */
.lotr-card-num .elementor-heading-title{
  font-family:'Bagel Fat One',cursive;font-size:64px;color:var(--ink);
  opacity:.12;line-height:1;position:absolute;right:16px;top:6px;pointer-events:none;
}

/* Little rotated tag chip (Heading + .lotr-chip) */
.lotr-chip .elementor-heading-title{
  display:inline-block;font-family:'Special Elite',monospace;font-size:10px;letter-spacing:2px;
  text-transform:uppercase;background:var(--cream);border:2px solid var(--ink);
  padding:3px 10px;box-shadow:2px 2px 0 var(--ink);transform:rotate(-2deg);color:var(--ink);
}
.lotr-chip-magenta .elementor-heading-title{background:var(--magenta);color:var(--cream);box-shadow:none;border-color:var(--ink)}
.lotr-chip-acid .elementor-heading-title{background:var(--acid);color:var(--ink);box-shadow:none}

/* Corner ribbon tag (Heading + .lotr-corner) */
.lotr-corner .elementor-heading-title{
  position:absolute;top:0;right:0;font-family:'Special Elite',monospace;font-size:11px;
  letter-spacing:2px;text-transform:uppercase;color:var(--cream);background:var(--ink);padding:6px 14px;
}
.lotr-corner-violet .elementor-heading-title{background:var(--violet)}
.lotr-corner-magenta .elementor-heading-title{background:var(--magenta)}

/* =========================================================================
   PROCESS STEPS (grid of 5)
   ========================================================================= */
.lotr-step-num .elementor-heading-title{
  font-family:'Bagel Fat One',cursive;font-size:50px;color:var(--magenta);
  -webkit-text-stroke:2px var(--ink);paint-order:stroke fill;line-height:1;
}
.lotr-step-title .elementor-heading-title{font-family:'Bagel Fat One',cursive;font-size:20px;text-transform:uppercase;color:var(--ink);line-height:1}
.lotr-step{position:relative}
.lotr-step .elementor-widget{margin-bottom:10px}
.lotr-step-body{font-size:13px}

/* =========================================================================
   PRICE BLOCK (Heading + .lotr-price)
   ========================================================================= */
.lotr-price .elementor-heading-title{font-family:'Bagel Fat One',cursive;font-size:52px;color:var(--ink);line-height:1}
.lotr-meta{font-family:'Special Elite',monospace;font-size:12px;letter-spacing:1.5px;text-transform:uppercase;color:var(--ink);opacity:.8;border-top:2px dashed var(--ink);border-bottom:2px dashed var(--ink);padding:12px 0}
.lotr-meta p{margin:0}
.lotr-rating{font-family:'Special Elite',monospace;font-size:11px;letter-spacing:1.5px;text-transform:uppercase;opacity:.8;padding:10px 14px;border:2px solid var(--ink);background:var(--cream);display:inline-block}
.lotr-rating p{margin:0}

/* =========================================================================
   ICON LIST  (Icon List widget + .lotr-list)
   ========================================================================= */
.lotr-list .elementor-icon-list-items{display:flex;flex-direction:column;gap:10px}
.lotr-list .elementor-icon-list-item{align-items:flex-start}
.lotr-list .elementor-icon-list-icon{padding-top:2px}
.lotr-list .elementor-icon-list-icon i,
.lotr-list .elementor-icon-list-icon svg{color:var(--violet);fill:var(--violet);font-size:15px;width:15px;height:15px}
.lotr-list .elementor-icon-list-text{font-family:'Nunito',sans-serif;font-weight:700;font-size:14px;color:var(--ink);line-height:1.5}
.lotr-list-magenta .elementor-icon-list-icon i,
.lotr-list-magenta .elementor-icon-list-icon svg{color:var(--magenta);fill:var(--magenta)}
.lotr-list-no .elementor-icon-list-icon i,
.lotr-list-no .elementor-icon-list-icon svg{color:var(--magenta);fill:var(--magenta)}
.lotr-list-boxed .elementor-icon-list-item{border:2px solid var(--ink);background:var(--cream);padding:12px 16px}
.lotr-list-boxed .elementor-icon-list-text{font-size:15px}
.lotr-list-on-dark .elementor-icon-list-text{color:var(--lav)}

/* =========================================================================
   ACCORDION / FAQ  (Accordion widget + .lotr-faq)
   ========================================================================= */
.lotr-faq .elementor-accordion .elementor-accordion-item{
  border:var(--border-thick);margin-bottom:-3px;background:var(--cream);
}
.lotr-faq .elementor-accordion-item:nth-child(2n){background:var(--lav)}
.lotr-faq .elementor-accordion-item:nth-child(3n){background:var(--mint)}
.lotr-faq .elementor-accordion-item:nth-child(4n){background:var(--teal)}
.lotr-faq .elementor-tab-title{
  font-family:'Bagel Fat One',cursive;font-weight:400;font-size:20px;text-transform:uppercase;
  padding:20px 24px;border:none;background:transparent;color:var(--ink);line-height:1.1;
}
.lotr-faq .elementor-tab-title.elementor-active{border:none}
.lotr-faq .elementor-accordion-icon{color:var(--magenta);font-size:20px}
.lotr-faq .elementor-tab-content{
  border:none;border-top:2px dashed var(--ink);padding:16px 24px 24px;
  font-family:'Nunito',sans-serif;font-weight:600;font-size:15px;line-height:1.65;color:var(--ink);background:transparent;
}
.lotr-faq .elementor-tab-content a{color:var(--magenta);text-decoration:underline}
.lotr-faq .elementor-tab-content p{margin:0}

/* =========================================================================
   STAT BLOCK (Text Editor + .lotr-statblock) — Meet Theo
   ========================================================================= */
.lotr-statblock{background:var(--cream);border:var(--border-thick);box-shadow:var(--shadow);padding:24px 28px}
.lotr-statblock .sb-title{font-family:'Special Elite',monospace;font-size:11px;letter-spacing:3px;text-transform:uppercase;color:var(--magenta);display:block;margin-bottom:16px}
.lotr-statblock .sb-row{display:flex;flex-wrap:wrap;border:2px solid var(--ink)}
.lotr-statblock .sb-cell{flex:1;min-width:74px;text-align:center;padding:12px 10px;border-right:2px solid var(--ink)}
.lotr-statblock .sb-cell:last-child{border-right:none}
.lotr-statblock .sb-cell .sb-label{font-family:'Special Elite',monospace;font-size:9px;letter-spacing:2px;text-transform:uppercase;opacity:.7;display:block;margin-bottom:4px}
.lotr-statblock .sb-cell .sb-val{font-family:'Bagel Fat One',cursive;font-size:30px;color:var(--violet);line-height:1;display:block}
.lotr-statblock .sb-cell .sb-mod{font-size:12px;font-weight:900;color:var(--magenta)}
.lotr-statblock .sb-traits{margin-top:16px;display:flex;flex-direction:column;gap:10px}
.lotr-statblock .sb-trait{font-family:'Nunito',sans-serif;font-weight:600;font-size:14px;line-height:1.55}
.lotr-statblock .sb-trait b{font-family:'Special Elite',monospace;font-size:11px;letter-spacing:1px;text-transform:uppercase;color:var(--magenta);display:block;margin-bottom:2px}

/* Acid call-out note box (Text Editor + .lotr-note) */
.lotr-note{background:var(--acid);border:var(--border-thick);padding:20px 24px;box-shadow:var(--shadow)}
.lotr-note strong{font-family:'Bagel Fat One',cursive;font-weight:400;font-size:18px;display:block;margin-bottom:6px}
.lotr-note p{font-family:'Nunito',sans-serif;font-weight:700;font-size:15px;line-height:1.55;margin:0}

/* Dark stats / platform card (Elementor column + .lotr-darkcard) */
.lotr-darkcard{background:var(--ink);border:var(--border-thick);box-shadow:var(--shadow-lg);padding:36px}
.lotr-darkcard .lotr-h3 .elementor-heading-title{color:var(--acid)}
.lotr-darkcard .elementor-widget{margin-bottom:18px}
.lotr-darkcard .elementor-widget:last-child{margin-bottom:0}

/* Trust signal rows on the dark safety strip / platform card */
.lotr-trust .elementor-icon-list-items{display:flex;flex-direction:column;gap:16px}
.lotr-trust .elementor-icon-list-icon i,
.lotr-trust .elementor-icon-list-icon svg{color:var(--acid);fill:var(--acid);font-size:18px}
.lotr-trust .elementor-icon-list-text{color:var(--lav);font-weight:600;font-size:13px;line-height:1.5}
.lotr-trust .elementor-icon-list-text strong{color:var(--acid)}

/* Trust pillar rows (Safety) — Elementor column + .lotr-pillar */
.lotr-pillar{border:var(--border-thick);box-shadow:var(--shadow-lg);padding:36px 40px;background:var(--cream);margin-bottom:-3px}
.lotr-pillar-lav{background:var(--lav)}
.lotr-pillar-teal{background:var(--teal)}
.lotr-pillar-mint{background:var(--mint)}
.lotr-pillar .elementor-widget{margin-bottom:14px}
.lotr-pillar .elementor-widget:last-child{margin-bottom:0}
.lotr-pillar-detail{background:var(--cream);border:2px solid var(--ink);padding:14px 18px;font-family:'Nunito',sans-serif;font-weight:700;font-size:13px;line-height:1.65}
.lotr-pillar-detail strong{color:var(--magenta)}
.lotr-pillar-num .elementor-heading-title{font-family:'Special Elite',monospace;font-size:11px;letter-spacing:2px;text-transform:uppercase;color:var(--magenta)}

/* Rating badge (Heading + .lotr-rating-badge) */
.lotr-rating-badge .elementor-heading-title{font-family:'Bagel Fat One',cursive;font-size:48px;color:var(--ink);line-height:1}

/* Trust pillars stack in a single column */
.lotr-pillars > .elementor-container{grid-template-columns:1fr;gap:0}

/* FAQ category header row (inner section: numeral | title) */
.lotr-cathead{margin:32px 0 16px}
.lotr-cathead > .elementor-container{display:flex !important;align-items:center;gap:16px}
.lotr-cathead > .elementor-container > .elementor-column{width:auto !important;max-width:none !important}
.lotr-faq-sections .elementor-widget-accordion{margin-bottom:8px}
.lotr-faq-sections > .elementor-widget-wrap > .elementor-element:first-child .lotr-cathead,
.lotr-faq-sections .lotr-cathead:first-child{margin-top:0}

/* =========================================================================
   NAV BAR (native Image + Heading + Button widgets, in a 3-col grid)
   ========================================================================= */
.lotr-nav{background:var(--cream);border-bottom:var(--border-thick);padding:12px 40px;position:sticky;top:0;z-index:90}
.lotr-nav > .elementor-container{display:grid !important;grid-template-columns:auto 1fr auto !important;align-items:center;gap:24px;max-width:none}
.lotr-nav > .elementor-container > .elementor-column{width:100% !important;max-width:100% !important}
.lotr-nav-brand > .elementor-widget-wrap{display:flex;flex-direction:row;align-items:center;gap:10px;flex-wrap:nowrap}
.lotr-nav-brand .elementor-widget-image{width:42px;flex-shrink:0;margin:0}
.lotr-nav-brand .elementor-widget-image img{width:42px;height:42px}
.lotr-brandname .elementor-heading-title{font-family:'Bagel Fat One',cursive;font-size:22px;color:var(--violet);line-height:1;white-space:nowrap}
.lotr-nav-links > .elementor-widget-wrap{display:flex;flex-direction:row;justify-content:center;align-items:center;gap:4px;flex-wrap:wrap}
.lotr-nav-links .elementor-widget{margin:0;width:auto}
.lotr-navlink .elementor-button{
  background:transparent;color:var(--ink);border:2px solid transparent;border-radius:6px;box-shadow:none;
  font-family:'Nunito',sans-serif;font-weight:900;font-size:13px;text-transform:uppercase;letter-spacing:1.5px;
  padding:7px 14px;transition:all .12s ease;
}
.lotr-navlink .elementor-button:hover{background:var(--acid);border-color:var(--ink);transform:rotate(-1.5deg);box-shadow:none}
.lotr-navlink.is-active .elementor-button{background:var(--lav);border-color:var(--ink)}
.lotr-navcta > .elementor-widget-wrap{justify-content:flex-end}
.lotr-navcta .elementor-button{
  background:var(--ink);color:var(--cream);border:2px solid var(--ink);border-radius:0;box-shadow:none;
  font-family:'Nunito',sans-serif;font-weight:900;font-size:13px;text-transform:uppercase;letter-spacing:1.5px;padding:9px 18px;
}
.lotr-navcta .elementor-button:hover{background:var(--magenta);transform:none;box-shadow:none}

/* =========================================================================
   HERO (full-bleed) + wavy bottom divider
   ========================================================================= */
.lotr-hero{position:relative;overflow:hidden;padding:56px 72px 100px}
.lotr-hero > .elementor-container{max-width:1180px;margin-left:auto;margin-right:auto}
.lotr-hero-split > .elementor-container{display:grid !important;grid-template-columns:1fr 1fr !important;gap:24px;align-items:center}
.lotr-hero-split > .elementor-container > .elementor-column{width:100% !important;max-width:100% !important}
.lotr-hero::after{
  content:"";position:absolute;left:0;right:0;bottom:0;height:30px;background:var(--cream);
  border-top:var(--border-thick);z-index:2;
  clip-path:polygon(0 0,3% 60%,7% 18%,12% 78%,17% 30%,22% 70%,27% 22%,33% 76%,38% 28%,44% 74%,49% 26%,54% 72%,60% 24%,66% 74%,72% 26%,78% 72%,83% 26%,89% 76%,94% 28%,98% 70%,100% 40%,100% 100%,0 100%);
}
.lotr-hero-art img{display:block;width:100%;height:auto;max-width:560px;margin:0 auto;animation:lotr-float 5.5s ease-in-out infinite}
@keyframes lotr-float{0%,100%{transform:translateY(0) rotate(-.5deg)}50%{transform:translateY(-18px) rotate(.5deg)}}
.lotr-hero .elementor-widget{margin-bottom:18px}

/* Pill badge (Heading + .lotr-pill) */
.lotr-pill .elementor-heading-title{
  display:inline-flex;align-items:center;gap:8px;background:var(--cream);border:3px solid var(--ink);
  padding:6px 14px;font-family:'Special Elite',monospace;font-size:12px;text-transform:uppercase;letter-spacing:2px;
  box-shadow:3px 3px 0 var(--magenta);transform:rotate(-1.5deg);color:var(--ink);
}

/* Stat strip (Text Editor + .lotr-statstrip) */
.lotr-statstrip{display:flex;border:3px solid var(--ink);background:var(--cream);box-shadow:5px 5px 0 var(--violet);width:fit-content}
.lotr-statstrip .ss-cell{padding:10px 18px;border-right:3px solid var(--ink);min-width:90px;display:flex;flex-direction:column}
.lotr-statstrip .ss-cell:last-child{border-right:none}
.lotr-statstrip .ss-cell b{font-family:'Bagel Fat One',cursive;font-size:26px;color:var(--violet);line-height:1}
.lotr-statstrip .ss-cell span{font-family:'Special Elite',monospace;font-size:9px;text-transform:uppercase;letter-spacing:1.5px;margin-top:4px}

/* Photo box wrapper for Theo portrait (Image + .lotr-photo) */
.lotr-photo .elementor-widget-container{
  border:var(--border-thick);box-shadow:var(--shadow-lg);background:var(--lav);
  transform:rotate(-2deg);overflow:hidden;max-width:360px;
}
.lotr-photo img{display:block;width:100%;height:auto}

/* =========================================================================
   FAQ SIDEBAR (faq page) — Button widgets styled as jump links
   ========================================================================= */
.lotr-faqnav > .elementor-widget-wrap{display:flex;flex-direction:column;gap:4px;position:sticky;top:100px}
.lotr-faqnav .elementor-widget{margin:0}
.lotr-faqnav-label .elementor-heading-title{font-family:'Special Elite',monospace;font-size:10px;letter-spacing:3px;text-transform:uppercase;color:var(--ink);opacity:.6;padding:0 14px;margin-bottom:8px}
.lotr-jumplink .elementor-button{
  background:transparent;border:2px solid transparent;border-radius:0;box-shadow:none;justify-content:flex-start;
  font-family:'Special Elite',monospace;font-size:11px;text-transform:uppercase;letter-spacing:2px;padding:10px 14px;color:var(--violet);
}
.lotr-jumplink .elementor-button:hover{background:var(--acid);border-color:var(--ink);color:var(--ink);transform:none;box-shadow:none}

/* FAQ category section heading row */
.lotr-catnum .elementor-heading-title{font-family:'Bagel Fat One',cursive;font-size:64px;color:var(--ink);opacity:.1;line-height:1}

/* Quick-link cards (faq) */
.lotr-quick .lotr-h3 .elementor-heading-title{color:var(--violet);font-size:22px}
.lotr-quick-link .elementor-heading-title{font-family:'Special Elite',monospace;font-size:11px;letter-spacing:2px;text-transform:uppercase;color:var(--magenta)}

/* =========================================================================
   CTA STRIP
   ========================================================================= */
.lotr-cta{padding:64px 72px;text-align:center}
.lotr-cta > .elementor-container{max-width:1180px;margin-left:auto;margin-right:auto}
.lotr-cta .elementor-widget{margin-bottom:10px}
.lotr-cta-sub .elementor-heading-title{font-family:'Special Elite',monospace;font-size:13px;letter-spacing:3px;text-transform:uppercase;color:var(--ink)}
.lotr-cta-note .elementor-heading-title{font-family:'Special Elite',monospace;font-size:11px;letter-spacing:1.5px;text-transform:uppercase;color:var(--ink);opacity:.8}
.lotr-cta .lotr-btn .elementor-button-wrapper{justify-content:center}

/* =========================================================================
   FOOTER
   ========================================================================= */
.lotr-footer{background:var(--ink);padding:56px 72px 32px;border-top:var(--border-thick)}
.lotr-footer > .elementor-container{display:grid !important;grid-template-columns:1.4fr 1fr 1fr 1fr !important;gap:40px;max-width:1180px;margin-left:auto;margin-right:auto}
.lotr-footer > .elementor-container > .elementor-column{width:100% !important;max-width:100% !important}
.lotr-foot-brand{margin-bottom:10px}
.lotr-foot-brand > .elementor-container{display:flex !important;flex-direction:row;align-items:center;gap:10px;flex-wrap:nowrap}
.lotr-foot-brand > .elementor-container > .elementor-column{width:auto !important;max-width:none !important}
.lotr-foot-brand .elementor-widget-image{width:32px;margin:0}
.lotr-foot-brand .elementor-widget-image img{width:32px;height:32px}
.lotr-foot-name .elementor-heading-title{font-family:'Bagel Fat One',cursive;font-size:22px;color:var(--acid)}
.lotr-foot-blurb{font-family:'Special Elite',monospace;font-size:12px;letter-spacing:1.5px;line-height:1.7;color:var(--lav);text-transform:uppercase;max-width:230px}
.lotr-foot-blurb p{margin:8px 0 0}
.lotr-foot-h .elementor-heading-title{font-family:'Bagel Fat One',cursive;font-size:16px;text-transform:uppercase;color:var(--acid);letter-spacing:1px;margin-bottom:14px}
.lotr-foot-links{font-family:'Nunito',sans-serif}
.lotr-foot-links ul{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:8px}
.lotr-foot-links a{font-size:13px;font-weight:700;color:var(--lav);text-decoration:none;transition:color .12s}
.lotr-foot-links a:hover{color:var(--acid)}
.lotr-foot-bottom{border-top:2px solid var(--violet-dk);margin-top:8px;padding:24px 72px 0;display:flex;justify-content:space-between;flex-wrap:wrap;gap:12px}
.lotr-foot-bottom > .elementor-container{max-width:1180px;margin-left:auto;margin-right:auto;display:flex !important;justify-content:space-between;flex-wrap:wrap;align-items:center;gap:12px}
.lotr-foot-bottom > .elementor-container > .elementor-column{width:auto !important;max-width:none !important}
.lotr-foot-copy .elementor-heading-title{font-family:'Special Elite',monospace;font-size:11px;letter-spacing:2px;text-transform:uppercase;color:var(--violet-dk);font-weight:400}
.lotr-foot-credit{font-family:'Special Elite',monospace;font-size:11px;letter-spacing:2px;text-transform:uppercase;color:var(--violet-dk)}
.lotr-foot-credit p{margin:0}
.lotr-foot-credit a{color:var(--acid);text-decoration:none}
.lotr-foot-credit a:hover{text-decoration:underline}

/* =========================================================================
   RESPONSIVE
   ========================================================================= */
@media(max-width:1024px){
  .lotr-section,.lotr-cta{padding:60px 28px}
  .lotr-head{padding:60px 28px 0}
  .lotr-tail{padding:32px 28px 70px}
  .lotr-hero{padding:40px 28px 80px}
  .lotr-nav{padding:12px 18px}
  .lotr-footer{padding:48px 28px 28px}
  .lotr-foot-bottom{padding:24px 28px 0}
  .lotr-grid-3 > .elementor-container,
  .lotr-grid-2 > .elementor-container,
  .lotr-grid-5 > .elementor-container,
  .lotr-grid-portrait > .elementor-container,
  .lotr-grid-split > .elementor-container,
  .lotr-grid-faq > .elementor-container,
  .lotr-hero-split > .elementor-container{grid-template-columns:1fr;gap:28px}
  .lotr-footer > .elementor-container{grid-template-columns:1fr 1fr}
  .lotr-faqnav > .elementor-widget-wrap{position:static;flex-direction:row;flex-wrap:wrap}
}
@media(max-width:600px){
  .lotr-footer > .elementor-container{grid-template-columns:1fr}
  .lotr-statstrip{flex-wrap:wrap}
}
