/*
Theme Name: Comedy Lab
Theme URI: https://comedylab.pl
Author: Comedy Lab
Description: Motyw stowarzyszenia Comedy Lab — laboratorium komedii. Hard-edge, monochromatyczny, czterotematyczny system kolorów (orange / blue / violet / green) + jasne tło "butter". Strona główna, podstrony O nas / Wydarzenia / Open Mic / Kontakt oraz natywny blog. Animacje wejścia, pływające motywy, marquee.
Version: 1.0.0
Requires at least: 6.0
Tested up to: 6.5
Requires PHP: 7.4
License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Text Domain: comedy-lab
*/

/* ============================================================
   1. WEBFONTS
   ============================================================ */
@font-face{font-family:"PP Rader";src:url("assets/fonts/PPRader-Bold.otf") format("opentype");font-weight:700;font-style:normal;font-display:swap}
@font-face{font-family:"Neue Haas Grotesk Display";src:url("assets/fonts/NeueHaasDisplay-Light.ttf") format("truetype");font-weight:300;font-style:normal;font-display:swap}
@font-face{font-family:"Neue Haas Grotesk Display";src:url("assets/fonts/NeueHaasDisplay-Roman.ttf") format("truetype");font-weight:400;font-style:normal;font-display:swap}
@font-face{font-family:"Neue Haas Grotesk Display";src:url("assets/fonts/NeueHaasDisplay-RomanItalic.ttf") format("truetype");font-weight:400;font-style:italic;font-display:swap}
@font-face{font-family:"Neue Haas Grotesk Display";src:url("assets/fonts/NeueHaasDisplay-Medium.ttf") format("truetype");font-weight:500;font-style:normal;font-display:swap}
@font-face{font-family:"Neue Haas Grotesk Display";src:url("assets/fonts/NeueHaasDisplay-Bold.ttf") format("truetype");font-weight:700;font-style:normal;font-display:swap}
@font-face{font-family:"Neue Haas Grotesk Display";src:url("assets/fonts/NeueHaasDisplay-Black.ttf") format("truetype");font-weight:900;font-style:normal;font-display:swap}

/* ============================================================
   2. DESIGN TOKENS
   ============================================================ */
:root{
  /* base palette */
  --cl-ink:#101010;
  --cl-butter:#ffffb3;
  --cl-paper:#f3f3f3;
  --cl-black:#000000;
  --cl-white:#ffffff;

  /* theme — orange */
  --orange-bg:#1b0000;   --orange-accent:#ff9d65; --orange-icon:#ffa775; --orange-icon-deep:#2a0000;
  /* theme — blue */
  --blue-bg:#000333;     --blue-accent:#00c8ff;   --blue-icon:#35d3ff;   --blue-icon-deep:#00054e;
  /* theme — violet */
  --violet-bg:#20002d;   --violet-accent:#9b7fff; --violet-icon:#a188ff; --violet-icon-deep:#2a003a;
  /* theme — green */
  --green-bg:#001718;    --green-accent:#4eff8f;  --green-icon:#82ffb0;  --green-icon-deep:#092120;

  /* semantic defaults (theme = orange) */
  --surface:var(--orange-bg);
  --accent:var(--orange-accent);
  --motif:var(--orange-icon);
  --motif-deep:var(--orange-icon-deep);

  /* type */
  --font-display:"PP Rader","Neue Haas Grotesk Display",system-ui,sans-serif;
  --font-text:"Neue Haas Grotesk Display","Helvetica Neue",Arial,system-ui,sans-serif;

  /* motion */
  --ease-out:cubic-bezier(.2,.8,.2,1);
  --dur-fast:120ms;
}

/* theme scopes */
[data-theme="orange"]{--surface:var(--orange-bg);--accent:var(--orange-accent);--motif:var(--orange-icon);--motif-deep:var(--orange-icon-deep)}
[data-theme="blue"]{--surface:var(--blue-bg);--accent:var(--blue-accent);--motif:var(--blue-icon);--motif-deep:var(--blue-icon-deep)}
[data-theme="violet"]{--surface:var(--violet-bg);--accent:var(--violet-accent);--motif:var(--violet-icon);--motif-deep:var(--violet-icon-deep)}
[data-theme="green"]{--surface:var(--green-bg);--accent:var(--green-accent);--motif:var(--green-icon);--motif-deep:var(--green-icon-deep)}
[data-theme="butter"]{--surface:var(--cl-butter);--accent:var(--cl-ink);--motif:#efef9e;--motif-deep:var(--cl-ink)}

/* ============================================================
   3. RESET
   ============================================================ */
html,body{margin:0;padding:0}
*{box-sizing:border-box}
img{max-width:100%;height:auto}
a{color:inherit}
.cl-site ::placeholder{color:var(--accent);opacity:.55}

/* ============================================================
   4. KEYFRAMES
   ============================================================ */
@keyframes clFloaty{0%,100%{transform:translateY(0)}50%{transform:translateY(-22px)}}
@keyframes clSpin{to{transform:rotate(360deg)}}
@keyframes clDrift{0%,100%{transform:translate(0,0)}50%{transform:translate(20px,-16px)}}
@keyframes clPulse{0%,100%{transform:scale(1)}50%{transform:scale(1.07)}}
@keyframes clPageIn{from{transform:translateY(18px);opacity:.4}to{transform:none;opacity:1}}
@keyframes clMarquee{from{transform:translateX(0)}to{transform:translateX(-50%)}}
@media (prefers-reduced-motion:reduce){.cl-site *{animation:none !important;transition:none !important}}

/* ============================================================
   5. SHELL
   ============================================================ */
.cl-site{font-family:var(--font-text);background:var(--cl-ink);color:var(--cl-paper);min-height:100vh;overflow-x:clip}
.cl-page-in{animation:clPageIn .5s var(--ease-out) both}

/* ---- NAV ---- */
.cl-nav{position:sticky;top:0;z-index:60;display:flex;align-items:center;justify-content:space-between;gap:24px;padding:13px clamp(20px,7vw,90px);background:rgba(16,16,16,.82);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border-bottom:1px solid rgba(255,255,255,.09)}
.cl-nav__logo{cursor:pointer;display:flex;align-items:center;flex:none;text-decoration:none}
.cl-nav__links{display:flex;align-items:center;gap:clamp(8px,1.9vw,28px);flex-wrap:wrap;justify-content:flex-end}
.cl-navlink{position:relative;appearance:none;background:none;border:0;cursor:pointer;font-family:inherit;font-weight:700;font-size:14px;text-transform:uppercase;letter-spacing:.05em;color:var(--cl-paper);padding:6px 1px;border-bottom:2px solid transparent;transition:color .15s;text-decoration:none;line-height:1.2}
.cl-navlink:hover{color:var(--cl-butter)}
.cl-navlink.is-active::after{content:"";position:absolute;left:0;right:0;bottom:0;height:2px;background:var(--cl-butter)}
.cl-navlink--cta{font-size:13px;letter-spacing:.06em;color:var(--cl-ink);background:var(--cl-butter);border:2px solid var(--cl-butter);border-radius:2px;padding:10px 18px;transition:background .15s,color .15s}
.cl-navlink--cta:hover{background:transparent;color:var(--cl-butter)}
.cl-nav__burger{display:none;appearance:none;background:none;border:0;cursor:pointer;color:var(--cl-paper);padding:6px;flex:none}
.cl-nav__burger svg{display:block}

/* ============================================================
   6. SECTIONS / TYPOGRAPHY
   ============================================================ */
.cl-section{position:relative;overflow:hidden;padding:clamp(70px,9vh,120px) clamp(20px,7vw,90px)}
.cl-section--surface{background:var(--surface);color:var(--accent)}
.cl-section--ink{background:var(--cl-ink);color:var(--cl-paper)}
.cl-hero{min-height:84vh;display:flex;align-items:center;padding:clamp(110px,15vh,170px) clamp(20px,7vw,90px) clamp(70px,9vh,110px)}
.cl-subhero{padding:clamp(120px,16vh,190px) clamp(20px,7vw,90px) clamp(50px,7vh,80px)}

.cl-motifs{position:absolute;inset:0;pointer-events:none;color:var(--motif)}
.cl-motifs svg{position:absolute}

.cl-eyebrow{font-family:var(--font-display);font-weight:700;line-height:.85;color:var(--accent);font-size:clamp(18px,2vw,26px)}
.cl-eyebrow--lg{font-size:clamp(20px,2.4vw,34px)}
.cl-eyebrow--butter{color:var(--cl-butter)}

.cl-h1{margin:0;font-weight:900;text-transform:uppercase;line-height:.86;letter-spacing:-.025em;font-size:clamp(50px,8vw,128px);color:var(--accent);text-wrap:balance}
.cl-h1--on-ink{color:var(--cl-paper)}
.cl-h2{margin:0;font-weight:900;text-transform:uppercase;line-height:.9;letter-spacing:-.02em;font-size:clamp(38px,5.4vw,84px);color:var(--accent)}
.cl-h2--on-ink{color:var(--cl-paper)}
.cl-h3{margin:0;font-weight:900;text-transform:uppercase;line-height:.95;letter-spacing:-.01em;font-size:clamp(22px,2.2vw,30px)}
.cl-lead{margin:0;font-size:clamp(16px,1.5vw,22px);line-height:1.5;color:var(--accent)}
.cl-lead--on-ink{color:var(--cl-paper);opacity:.8}

.cl-section__head{display:flex;align-items:flex-end;justify-content:space-between;gap:24px;flex-wrap:wrap;margin-bottom:clamp(34px,5vh,56px)}
.cl-section__head-titles{display:flex;flex-direction:column;gap:14px}
.cl-link-more{appearance:none;background:none;border:0;cursor:pointer;font-family:inherit;font-weight:700;font-size:15px;text-transform:uppercase;letter-spacing:.05em;padding:6px 0;border-bottom:2px solid currentColor;text-decoration:none}
.cl-link-more:hover{opacity:.7}
.cl-link-more--butter{color:var(--cl-butter)}
.cl-link-more--accent{color:var(--accent)}

/* ============================================================
   7. COMPONENTS — Button / Tag
   ============================================================ */
.cl-btn{font-family:var(--font-text);font-weight:700;text-transform:uppercase;letter-spacing:.04em;border:2px solid var(--accent);border-radius:2px;cursor:pointer;line-height:1;display:inline-flex;align-items:center;gap:10px;white-space:nowrap;text-decoration:none;transition:background var(--dur-fast) var(--ease-out),color var(--dur-fast) var(--ease-out),opacity var(--dur-fast)}
.cl-btn--md{font-size:15px;padding:12px 22px}
.cl-btn--lg{font-size:18px;padding:16px 30px}
.cl-btn--solid{background:var(--accent);color:var(--surface)}
.cl-btn--solid:hover{background:transparent;color:var(--accent)}
.cl-btn--outline{background:transparent;color:var(--accent)}
.cl-btn--outline:hover{background:var(--accent);color:var(--surface)}
.cl-btn:active{opacity:.7}

.cl-tag{display:inline-flex;align-items:center;gap:12px;font-family:var(--font-text);font-weight:700;font-size:14px;text-transform:uppercase;letter-spacing:.04em;color:var(--accent)}
.cl-tag__dot{width:9px;height:9px;border-radius:999px;background:var(--accent);flex:none}

/* ============================================================
   8. HERO VARIANTS
   ============================================================ */
.cl-hero__stacked{position:relative;z-index:2;max-width:1140px;margin:0 auto;text-align:center;display:flex;flex-direction:column;align-items:center;gap:clamp(18px,3vh,32px)}
.cl-hero__display{font-family:var(--font-display);font-weight:700;line-height:.85;color:var(--accent);font-size:clamp(22px,2.7vw,38px)}
.cl-hero__title{margin:0;font-weight:900;text-transform:uppercase;line-height:.85;letter-spacing:-.025em;font-size:clamp(54px,9.4vw,148px);color:var(--accent);text-wrap:balance}
.cl-hero__tags{display:flex;flex-wrap:wrap;justify-content:center;gap:12px 26px;margin-top:2px}
.cl-hero__cta{display:flex;flex-wrap:wrap;justify-content:center;gap:14px;margin-top:10px}

/* ============================================================
   9. EVENT CARDS
   ============================================================ */
.cl-event-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:clamp(16px,2vw,24px)}
.cl-event-grid--fill{grid-template-columns:repeat(auto-fill,minmax(260px,1fr))}
.cl-event-card{background:var(--surface);color:var(--accent);border:2px solid var(--accent);border-radius:2px;padding:26px 24px;display:flex;flex-direction:column;gap:16px;cursor:pointer;transition:transform .25s var(--ease-out);text-decoration:none}
.cl-event-card:hover{transform:translateY(-7px)}
.cl-event-card__top{display:flex;align-items:baseline;justify-content:space-between;gap:10px}
.cl-event-card__date{font-weight:900;font-size:clamp(34px,3.4vw,46px);line-height:1;letter-spacing:-.02em}
.cl-event-card__dow{font-weight:700;text-transform:uppercase;letter-spacing:.05em;font-size:14px}
.cl-event-card__venue{font-weight:700;text-transform:uppercase;letter-spacing:.04em;font-size:14px;opacity:.85}

/* ============================================================
   10. STATS / ABOUT
   ============================================================ */
.cl-split{position:relative;z-index:2;display:grid;grid-template-columns:1.2fr .8fr;gap:clamp(28px,5vw,72px);align-items:center}
.cl-stack{display:flex;flex-direction:column;gap:22px}
.cl-stats{display:flex;flex-direction:column;gap:8px}
.cl-stat{border-top:2px solid var(--accent);padding:18px 0;display:flex;align-items:baseline;gap:16px}
.cl-stat--last{border-bottom:2px solid var(--accent)}
.cl-stat__num{font-weight:900;font-size:clamp(44px,5vw,76px);line-height:.9;letter-spacing:-.03em}
.cl-stat__label{font-weight:700;text-transform:uppercase;letter-spacing:.04em;font-size:14px;max-width:14ch}

/* ============================================================
   11. VIDEO / REALIZACJE
   ============================================================ */
.cl-video-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:clamp(16px,2vw,24px)}
.cl-video{display:flex;flex-direction:column;gap:14px;cursor:pointer;text-decoration:none}
.cl-video:hover{opacity:.9}
.cl-video__thumb{position:relative;aspect-ratio:16/9;border:2px solid var(--accent);border-radius:2px;background:repeating-linear-gradient(135deg,var(--motif-deep) 0 16px,transparent 16px 32px);display:flex;align-items:center;justify-content:center}
.cl-video__tag{position:absolute;inset:auto auto 12px 12px;font-family:ui-monospace,Menlo,monospace;font-size:12px;letter-spacing:.04em;color:var(--accent);opacity:.75}
.cl-video__play{font-weight:900;font-size:30px;color:var(--accent)}
.cl-video__title{margin:0;font-weight:900;text-transform:uppercase;line-height:1;letter-spacing:-.01em;font-size:clamp(18px,1.7vw,24px)}
.cl-video__meta{font-weight:700;text-transform:uppercase;letter-spacing:.04em;font-size:13px;opacity:.75}

/* ============================================================
   12. TEAM / EKIPA
   ============================================================ */
.cl-team-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:clamp(16px,2vw,24px)}
.cl-member{display:flex;flex-direction:column;gap:14px}
.cl-member__photo{aspect-ratio:1;border:2px solid var(--accent);border-radius:2px;background:repeating-linear-gradient(45deg,var(--motif-deep) 0 14px,transparent 14px 28px);display:flex;align-items:center;justify-content:center;overflow:hidden}
.cl-member__initials{font-family:var(--font-display);font-weight:700;font-size:clamp(40px,4vw,64px);color:var(--accent)}
.cl-member__name{font-weight:900;text-transform:uppercase;font-size:18px;letter-spacing:-.01em}
.cl-member__role{font-weight:700;text-transform:uppercase;letter-spacing:.04em;font-size:12px;opacity:.75}

/* ============================================================
   13. FORMS / NEWSLETTER
   ============================================================ */
.cl-center-block{position:relative;z-index:2;max-width:760px;margin:0 auto;text-align:center;display:flex;flex-direction:column;align-items:center;gap:24px}
.cl-form-row{display:flex;flex-wrap:wrap;gap:12px;justify-content:center;width:100%;max-width:560px;margin-top:6px}
.cl-input{font-family:inherit;font-size:16px;font-weight:500;color:var(--accent);background:transparent;border:2px solid var(--accent);border-radius:2px;padding:14px 18px}
.cl-input--grow{flex:1;min-width:220px}
.cl-form-stack{display:flex;flex-direction:column;gap:16px}
.cl-label{display:flex;flex-direction:column;gap:8px;font-weight:700;text-transform:uppercase;letter-spacing:.05em;font-size:12px;opacity:.85}
.cl-label .cl-input{text-transform:none;letter-spacing:0}
.cl-link-ghost{appearance:none;background:none;border:0;cursor:pointer;font-family:inherit;font-weight:700;font-size:14px;text-transform:uppercase;letter-spacing:.04em;color:var(--accent);opacity:.8;border-bottom:1px solid var(--accent);text-decoration:none}
.cl-link-ghost:hover{opacity:1}

/* ============================================================
   14. ABOUT / STEP COLUMNS
   ============================================================ */
.cl-cols{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:clamp(20px,3vw,40px)}
.cl-cols--steps{grid-template-columns:repeat(auto-fit,minmax(230px,1fr))}
.cl-col{display:flex;flex-direction:column;gap:12px;border-top:2px solid var(--accent);padding-top:18px}
.cl-col__title{font-family:var(--font-display);font-weight:700;font-size:clamp(22px,2.2vw,30px);line-height:.85}
.cl-col__body{margin:0;font-size:16px;line-height:1.5;opacity:.85}
.cl-step__num{font-family:var(--font-display);font-weight:700;font-size:clamp(40px,4vw,64px);line-height:.85}
.cl-step__title{margin:0;font-weight:900;text-transform:uppercase;font-size:20px;letter-spacing:-.01em}
.cl-callout{margin-top:clamp(40px,6vh,72px);border:2px solid var(--accent);border-radius:2px;padding:clamp(24px,3vw,40px);display:flex;flex-wrap:wrap;gap:20px;align-items:center;justify-content:space-between}
.cl-callout__kicker{font-weight:700;text-transform:uppercase;letter-spacing:.05em;font-size:14px;opacity:.8}
.cl-callout__title{font-weight:900;text-transform:uppercase;font-size:clamp(24px,2.8vw,38px);line-height:1;letter-spacing:-.01em}

/* ============================================================
   15. CONTACT
   ============================================================ */
.cl-contact-grid{position:relative;z-index:2;display:grid;grid-template-columns:1fr 1fr;gap:clamp(32px,5vw,72px);align-items:start;max-width:1200px}
.cl-contact-info{display:flex;flex-direction:column;gap:14px;margin-top:8px;border-top:2px solid var(--accent);padding-top:20px}
.cl-contact-info__item{display:flex;flex-direction:column;gap:4px}
.cl-contact-info__label{font-weight:700;text-transform:uppercase;letter-spacing:.05em;font-size:12px;opacity:.7}
.cl-contact-info__value{font-weight:700;font-size:18px}
.cl-social-row{display:flex;gap:18px;margin-top:6px}
.cl-social-row a{text-decoration:none;font-weight:700;text-transform:uppercase;letter-spacing:.04em;font-size:14px;color:var(--accent);border-bottom:2px solid var(--accent);padding-bottom:2px}
.cl-social-row a:hover{opacity:.7}

/* ============================================================
   16. BLOG
   ============================================================ */
.cl-blog-list{max-width:980px;display:flex;flex-direction:column}
.cl-blog-item{display:flex;gap:clamp(18px,3vw,48px);padding:clamp(24px,3vh,36px) 0;border-top:2px solid var(--accent);cursor:pointer;flex-wrap:wrap;text-decoration:none;color:inherit}
.cl-blog-item--last{border-bottom:2px solid var(--accent)}
.cl-blog-item:hover{opacity:.82}
.cl-blog-item__meta{min-width:120px;display:flex;flex-direction:column;gap:8px}
.cl-blog-item__day{font-weight:900;font-size:26px;line-height:1;letter-spacing:-.02em}
.cl-blog-item__sub{font-weight:700;text-transform:uppercase;letter-spacing:.04em;font-size:12px;opacity:.7}
.cl-blog-item__body{flex:1;min-width:240px;display:flex;flex-direction:column;gap:10px}
.cl-blog-item__title{margin:0;font-weight:900;text-transform:uppercase;line-height:.95;letter-spacing:-.01em;font-size:clamp(24px,2.8vw,38px)}
.cl-blog-item__excerpt{margin:0;font-size:16px;line-height:1.5;opacity:.85;max-width:60ch}
.cl-blog-item__more{font-weight:700;text-transform:uppercase;letter-spacing:.04em;font-size:13px;border-bottom:1px solid var(--accent);align-self:flex-start;padding-bottom:2px}
.cl-blog-thumb{aspect-ratio:16/9;border:2px solid var(--accent);border-radius:2px;background:repeating-linear-gradient(135deg,var(--motif-deep) 0 16px,transparent 16px 32px);overflow:hidden;margin-bottom:18px}
.cl-blog-thumb img{width:100%;height:100%;object-fit:cover;display:block}

/* ---- single post ---- */
.cl-article{max-width:820px;margin:0 auto;display:flex;flex-direction:column;gap:28px}
.cl-article__featured{border:2px solid var(--accent);border-radius:2px;overflow:hidden;aspect-ratio:16/9}
.cl-article__featured img{width:100%;height:100%;object-fit:cover;display:block}
.cl-prose{font-size:clamp(17px,1.4vw,19px);line-height:1.65;color:var(--accent)}
.cl-prose p{margin:0 0 1.1em}
.cl-prose h2{font-weight:900;text-transform:uppercase;letter-spacing:-.01em;font-size:clamp(26px,3vw,40px);line-height:1;margin:1.4em 0 .5em}
.cl-prose h3{font-weight:900;text-transform:uppercase;letter-spacing:-.01em;font-size:clamp(20px,2.2vw,28px);margin:1.2em 0 .4em}
.cl-prose a{text-decoration:underline;text-underline-offset:3px}
.cl-prose blockquote{margin:1.2em 0;padding:8px 0 8px 24px;border-left:3px solid var(--accent);font-family:var(--font-display);font-size:clamp(22px,2.4vw,32px);line-height:1.05}
.cl-prose img{border:2px solid var(--accent);border-radius:2px;margin:1.2em 0}
.cl-prose ul,.cl-prose ol{margin:0 0 1.1em;padding-left:1.3em}
.cl-prose li{margin:.3em 0}
.cl-prose code{font-family:ui-monospace,Menlo,monospace;font-size:.92em;background:rgba(0,0,0,.18);padding:2px 6px;border-radius:3px}

.cl-pagination{display:flex;gap:14px;flex-wrap:wrap;justify-content:center;margin-top:clamp(40px,6vh,72px)}
.cl-tagrow{display:flex;flex-wrap:wrap;gap:10px 16px}

/* ============================================================
   17. FOOTER
   ============================================================ */
.cl-footer{background:var(--cl-black);color:var(--cl-paper);padding:clamp(56px,7vh,88px) clamp(20px,7vw,90px) 40px}
.cl-footer__grid{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:clamp(28px,5vw,64px);align-items:start}
.cl-footer__brand{display:flex;flex-direction:column;gap:18px}
.cl-footer__about{margin:0;max-width:34ch;font-size:15px;line-height:1.5;opacity:.7}
.cl-footer__col{display:flex;flex-direction:column;gap:12px}
.cl-footer__col-title{font-weight:700;text-transform:uppercase;letter-spacing:.06em;font-size:13px;color:var(--cl-butter);margin-bottom:4px}
.cl-footer__link{appearance:none;background:none;border:0;text-align:left;cursor:pointer;font-family:inherit;font-size:15px;color:var(--cl-paper);padding:0;text-decoration:none}
.cl-footer__link:hover{color:var(--cl-butter)}
.cl-footer__bar{margin-top:clamp(36px,5vh,56px);padding-top:24px;border-top:1px solid rgba(255,255,255,.12);display:flex;flex-wrap:wrap;gap:12px;justify-content:space-between;font-size:13px;opacity:.6}

/* ============================================================
   18. WORDPRESS CORE / GUTENBERG
   ============================================================ */
.cl-prose .wp-block-image{margin:1.2em 0}
.cl-prose figcaption{font-size:13px;opacity:.7;margin-top:6px;text-align:center}
.aligncenter{margin-left:auto;margin-right:auto}
.alignright{float:right;margin:0 0 1em 1.5em}
.alignleft{float:left;margin:0 1.5em 1em 0}
.screen-reader-text{position:absolute;width:1px;height:1px;overflow:hidden;clip:rect(1px,1px,1px,1px);clip-path:inset(50%);white-space:nowrap}
.admin-bar .cl-nav{top:32px}
@media screen and (max-width:782px){.admin-bar .cl-nav{top:46px}}

/* ============================================================
   19. RESPONSIVE
   ============================================================ */
@media (max-width:860px){
  .cl-split{grid-template-columns:1fr}
  .cl-contact-grid{grid-template-columns:1fr}
  .cl-footer__grid{grid-template-columns:1fr 1fr}
}
@media (max-width:680px){
  .cl-nav__links{position:fixed;inset:0 0 auto 0;top:0;flex-direction:column;justify-content:flex-start;align-items:stretch;gap:0;background:rgba(16,16,16,.97);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);padding:84px clamp(20px,7vw,90px) 32px;height:100vh;transform:translateY(-100%);transition:transform .32s var(--ease-out);overflow-y:auto;z-index:55}
  .cl-nav__links.is-open{transform:none}
  .cl-navlink{font-size:22px;padding:16px 0;border-bottom:1px solid rgba(255,255,255,.1)}
  .cl-navlink.is-active::after{display:none}
  .cl-navlink--cta{font-size:18px;text-align:center;margin-top:16px;padding:16px}
  .cl-nav__burger{display:block;position:relative;z-index:60}
  .cl-footer__grid{grid-template-columns:1fr}
}

/* ===== CL HOME FIXES ===== */
.cl-section[data-theme="butter"]{background:var(--surface);color:var(--accent)}
.cl-video__thumb{overflow:hidden}
.cl-video__thumb img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:center;display:block}
.cl-video__thumb .cl-video__play{position:relative;z-index:2;color:#fff;text-shadow:0 2px 14px rgba(0,0,0,.7)}
.cl-video:hover .cl-video__thumb img{opacity:.9;transition:opacity .2s var(--ease-out)}
/* ===== /CL HOME FIXES ===== */

/* ===== CL CF7 ===== */
.cl-site .wpcf7-form-control-wrap{display:block;width:100%}
.cl-site .cl-label .cl-input{width:100%}
.cl-site .wpcf7 .wpcf7-response-output{border:2px solid var(--accent);color:var(--accent);border-radius:2px;padding:12px 16px;margin:18px 0 0;font-weight:600;font-size:14px}
.cl-site .wpcf7-not-valid-tip{color:#ff8a8a;font-size:13px;font-weight:600;margin-top:6px}
.cl-site .wpcf7-spinner{margin:0 0 0 12px}
.cl-site .wpcf7 select.cl-input{appearance:auto}
/* ===== /CL CF7 ===== */

/* ===== CL TEAM CAROUSEL ===== */
.cl-site .cl-carousel{position:relative}
.cl-site .cl-carousel__track{display:flex;gap:clamp(16px,2vw,24px);overflow-x:auto;scroll-snap-type:x mandatory;scroll-behavior:smooth;-webkit-overflow-scrolling:touch;padding:4px 0 10px;scrollbar-width:none}
.cl-site .cl-carousel__track::-webkit-scrollbar{display:none}
.cl-site .cl-carousel__slide{flex:0 0 clamp(190px,22vw,235px);scroll-snap-align:start}
.cl-site .cl-carousel__nav{position:absolute;top:34%;transform:translateY(-50%);z-index:4;width:46px;height:46px;border:2px solid var(--accent);background:var(--surface);color:var(--accent);border-radius:999px;font-size:26px;line-height:1;cursor:pointer;display:flex;align-items:center;justify-content:center;padding:0 0 4px;transition:background .15s var(--ease-out),color .15s var(--ease-out)}
.cl-site .cl-carousel__nav:hover{background:var(--accent);color:var(--surface)}
.cl-site .cl-carousel__nav--prev{left:-10px}
.cl-site .cl-carousel__nav--next{right:-10px}
.cl-site .cl-member__photo img{width:100%;height:100%;object-fit:cover;display:block}
@media(max-width:680px){.cl-site .cl-carousel__nav{display:none}}
/* ===== /CL TEAM CAROUSEL ===== */