/* ============================================================
   Optivro Footwear Widgets — shared structural styles.
   Dynamic colours/typography come from Elementor Style controls
   ({{WRAPPER}} selectors). Everything here is ofl- prefixed so it
   can never affect other parts of the page.
   ============================================================ */
:root{
  --ofl-ink:#16151A; --ofl-ink2:#201E24; --ofl-base:#F2F0EB; --ofl-panel:#FBFAF6;
  --ofl-hair:#DED9D0; --ofl-steel:#6B6A66; --ofl-steel2:#97968F;
  --ofl-flo:#ED672B; --ofl-flo-deep:#D2551D; --ofl-ease:cubic-bezier(.19,1,.22,1);
  --ofl-sh:0 20px 44px -22px rgba(22,21,25,.28); --ofl-sh-lg:0 46px 90px -34px rgba(22,21,25,.42);
}
.ofl-wrap{max-width:1300px;margin:0 auto;padding-left:clamp(22px,5.5vw,88px);padding-right:clamp(22px,5.5vw,88px)}

/* schemes */
.ofl-sec{background:var(--ofl-base);color:var(--ofl-ink);position:relative}
.ofl-scheme--panel{background:var(--ofl-panel)}
.ofl-scheme--dark{background:var(--ofl-ink);color:#EBEAE5}
.ofl-scheme--dark .ofl-head{color:#fff}
.ofl-scheme--dark .ofl-lead{color:#F2F0EB}
.ofl-scheme--dark .ofl-body{color:#C7C6C0}
.ofl-scheme--dark .ofl-list li{color:#EBEAE5;border-top-color:rgba(255,255,255,.13)}
.ofl-scheme--dark .ofl-kicker__label,.ofl-scheme--dark .ofl-list-label{color:var(--ofl-steel2)}

/* grids */
.ofl-grid-7-5{display:grid;grid-template-columns:7fr 5fr;gap:clamp(36px,5vw,80px);align-items:start}
.ofl-grid-2{display:grid;grid-template-columns:1fr 1fr;gap:clamp(36px,5.5vw,90px);align-items:center}

/* kicker */
.ofl-kicker{display:flex;align-items:center;gap:18px;margin-bottom:clamp(22px,2.4vw,34px)}
.ofl-kicker__num{font-family:"Archivo Expanded",sans-serif;font-weight:700;font-size:clamp(20px,2vw,30px);color:var(--ofl-flo);line-height:.9;letter-spacing:-.02em}
.ofl-kicker__rule{width:72px;height:2px;background:var(--ofl-flo);flex:0 0 auto}
.ofl-kicker__label{font-family:"IBM Plex Mono",monospace;font-size:13px;font-weight:500;letter-spacing:.24em;text-transform:uppercase;color:var(--ofl-steel)}

/* typography blocks */
.ofl-head{margin:0;font-family:"Archivo Expanded","Archivo",sans-serif;font-weight:700;letter-spacing:-.025em;line-height:1.04;font-size:clamp(27px,3.4vw,47px);color:var(--ofl-ink)}
.ofl-head .ofl-k{color:var(--ofl-flo)}
.ofl-lead{font-family:"Archivo",sans-serif;font-weight:300;font-size:clamp(18px,1.9vw,25px);line-height:1.42;letter-spacing:-.01em;color:var(--ofl-ink);margin:0 0 18px}
.ofl-body{font-family:"IBM Plex Sans",sans-serif;font-size:16px;line-height:1.75;color:var(--ofl-steel);max-width:52ch;margin:18px 0 0}
.ofl-list{list-style:none;margin:16px 0 0;padding:0}
.ofl-list li{position:relative;padding:14px 0 14px 26px;font-size:15.5px;line-height:1.5;border-top:1px solid var(--ofl-hair);color:var(--ofl-ink);transition:padding .35s var(--ofl-ease)}
.ofl-list li:before{content:"";position:absolute;left:0;top:22px;width:8px;height:8px;background:var(--ofl-flo);transition:transform .35s var(--ofl-ease)}
.ofl-list li:hover{padding-left:34px}
.ofl-list li:hover:before{transform:scale(1.5)}
.ofl-list-label{font-family:"IBM Plex Mono",monospace;font-size:12px;letter-spacing:.14em;text-transform:uppercase;color:var(--ofl-steel);margin:0 0 4px}

/* figure + bracket */
.ofl-fig{position:relative;overflow:hidden;box-shadow:var(--ofl-sh)}
.ofl-fig img{width:100%;height:100%;object-fit:cover;aspect-ratio:4/5;transition:transform 1.1s var(--ofl-ease)}
.ofl-fig:hover img{transform:scale(1.06)}
.ofl-fig__cap{position:absolute;left:16px;bottom:16px;background:rgba(18,17,20,.55);backdrop-filter:blur(8px);border:1px solid rgba(255,255,255,.14);color:#fff;font-family:"IBM Plex Mono",monospace;font-size:10.5px;letter-spacing:.1em;text-transform:uppercase;padding:9px 14px}
.ofl-bracket{position:relative;padding:20px}
.ofl-bracket:before,.ofl-bracket:after{content:"";position:absolute;width:42%;height:42%;border:14px solid var(--ofl-flo);z-index:0;transition:all .5s var(--ofl-ease)}
.ofl-bracket:before{top:0;left:0;border-right:0;border-bottom:0}
.ofl-bracket:after{bottom:0;right:0;border-left:0;border-top:0}
.ofl-bracket:hover:before{top:-6px;left:-6px}
.ofl-bracket:hover:after{bottom:-6px;right:-6px}
.ofl-bracket .ofl-fig{position:relative;z-index:1}

/* buttons */
.ofl-btn{font-family:"IBM Plex Mono",monospace;font-size:13px;letter-spacing:.06em;text-transform:uppercase;padding:16px 28px;display:inline-flex;align-items:center;gap:10px;cursor:pointer;border:1px solid transparent;transition:transform .3s var(--ofl-ease),background .3s var(--ofl-ease),color .3s var(--ofl-ease);text-decoration:none}
.ofl-btn__arw{transition:transform .3s var(--ofl-ease)}
.ofl-btn:hover .ofl-btn__arw{transform:translateX(4px)}
.ofl-btn--primary{background:var(--ofl-flo);color:#fff}
.ofl-btn--primary:hover{background:var(--ofl-flo-deep)}
.ofl-btn--ghost{border-color:rgba(255,255,255,.5);color:#fff}
.ofl-btn--ghost:hover{background:rgba(255,255,255,.08)}

/* ============ HEADER ============ */
.ofl-hdr{position:fixed;top:0;left:0;right:0;z-index:60;padding:16px 0;background:rgba(242,240,235,.85);backdrop-filter:blur(14px) saturate(1.1);box-shadow:0 1px 0 var(--ofl-hair);transition:padding .4s var(--ofl-ease),box-shadow .4s}
.ofl-hdr.ofl-solid{padding:11px 0;box-shadow:0 6px 26px -14px rgba(22,21,25,.28),0 1px 0 var(--ofl-hair)}
.ofl-hdr__row{display:flex;align-items:center;justify-content:space-between;gap:24px}
.ofl-hdr__brand{display:flex;align-items:center;gap:13px}
.ofl-hdr__logo img{height:26px;width:auto;display:block}
.ofl-hdr__sub{font-family:"IBM Plex Mono",monospace;font-size:10px;letter-spacing:.17em;text-transform:uppercase;padding-left:13px;color:var(--ofl-steel);border-left:1px solid var(--ofl-hair)}
.ofl-hdr__nav{display:flex;gap:24px;align-items:center}
.ofl-hdr__nav a{font-family:"IBM Plex Sans",sans-serif;font-size:13px;font-weight:500;color:var(--ofl-ink);position:relative;padding:2px 0;text-decoration:none}
.ofl-hdr__nav a:after{content:"";position:absolute;left:0;right:100%;bottom:-2px;height:1.5px;background:var(--ofl-flo);transition:right .4s var(--ofl-ease)}
.ofl-hdr__nav a:hover:after{right:0}
.ofl-hdr__cta{font-family:"IBM Plex Mono",monospace;font-size:12px;letter-spacing:.08em;text-transform:uppercase;border:1px solid var(--ofl-ink);color:var(--ofl-ink);padding:10px 18px;transition:.35s var(--ofl-ease)}
.ofl-hdr__cta:after{display:none}
.ofl-hdr__cta:hover{background:var(--ofl-ink);color:#fff}
.ofl-hdr__burger{display:none;background:none;border:0;cursor:pointer;flex-direction:column;gap:5px;padding:6px}
.ofl-hdr__burger span{width:23px;height:2px;background:var(--ofl-ink);display:block}

/* ============ HERO ============ */
.ofl-hero{position:relative;min-height:100vh;display:flex;align-items:flex-end;overflow:hidden}
.ofl-hero__bg{position:absolute;inset:-8% 0;will-change:transform}
.ofl-hero__bg img{width:100%;height:100%;object-fit:cover;object-position:center;transform:scale(1.06);animation:ofl-hz 2s var(--ofl-ease) forwards}
@keyframes ofl-hz{to{transform:scale(1)}}
.ofl-hero__scrim{position:absolute;inset:0;background:linear-gradient(90deg,rgba(9,9,11,.9) 0%,rgba(9,9,11,.5) 46%,rgba(9,9,11,.08) 82%,rgba(9,9,11,.32) 100%)}
.ofl-hero__scrim-b{position:absolute;inset:0;background:linear-gradient(0deg,rgba(9,9,11,.82) 0%,rgba(9,9,11,0) 46%)}
.ofl-hero__inner{position:relative;width:100%;padding-bottom:clamp(44px,7vh,82px);padding-top:150px}
.ofl-hero__eyebrow{font-family:"IBM Plex Mono",monospace;font-size:clamp(11px,1.1vw,13px);font-weight:500;letter-spacing:.2em;text-transform:uppercase;color:#E9C9B6;display:flex;align-items:center;gap:14px}
.ofl-hero__eyebrow:before{content:"";width:34px;height:2px;background:var(--ofl-flo)}
.ofl-hero__title{color:#fff;font-family:"Archivo Expanded","Archivo",sans-serif;font-weight:700;margin:24px 0 0;font-size:clamp(40px,6.4vw,90px);letter-spacing:-.03em;line-height:.98;max-width:16ch}
.ofl-hero__u{position:relative;white-space:nowrap}
.ofl-hero__u:after{content:"";position:absolute;left:0;right:0;bottom:.04em;height:.07em;background:var(--ofl-flo);transform:scaleX(0);transform-origin:left;animation:ofl-uw 1s var(--ofl-ease) 1.1s forwards}
@keyframes ofl-uw{to{transform:scaleX(1)}}
.ofl-hero__lede{color:#D7D8DA;font-family:"IBM Plex Sans",sans-serif;font-size:clamp(16px,1.5vw,19px);max-width:56ch;margin:24px 0 34px;line-height:1.55;font-weight:300}
.ofl-hero__cta{display:flex;gap:14px;flex-wrap:wrap}
.ofl-hero__stats{position:relative;z-index:2;border-top:1px solid rgba(255,255,255,.18);display:grid;grid-template-columns:repeat(4,1fr);margin-top:44px}
.ofl-hero__stat{padding:22px 22px 4px 0;position:relative}
.ofl-hero__stat:not(:last-child):after{content:"";position:absolute;right:16px;top:24px;bottom:14px;width:1px;background:rgba(255,255,255,.1)}
.ofl-hero__stat-n{font-family:"Archivo Expanded",sans-serif;font-weight:700;color:#fff;font-size:clamp(23px,2.6vw,36px);letter-spacing:-.02em}
.ofl-hero__stat-l{font-family:"IBM Plex Mono",monospace;font-size:10.5px;letter-spacing:.11em;text-transform:uppercase;color:#A9ABAE;margin-top:5px}
.ofl-hero__accent{position:absolute;border:2px solid var(--ofl-flo);z-index:1;opacity:.5;will-change:transform}
.ofl-hero__accent--1{width:120px;height:120px;top:24%;right:10%;border-right:0;border-bottom:0}
.ofl-hero__accent--2{width:90px;height:90px;bottom:30%;right:22%;border-left:0;border-top:0}

/* ============ MOTION (progressive enhancement) ============
   Elements are VISIBLE by default. The hidden "from" state is applied only when
   JS has added .ofl-anim to <html> (see wp_head inline script). This guarantees
   content is never invisible if JS is slow/blocked. The editor always shows
   everything. A 3s JS failsafe reveals anything the observer missed. */
.ofl-st{opacity:1}
.ofl-reveal,.ofl-reveal-h,.ofl-reveal-m{opacity:1}
.ofl-d1{transition-delay:.12s}.ofl-d2{transition-delay:.24s}

html.ofl-anim .ofl-st{opacity:0;transform:translateY(24px);animation:ofl-rise 1s var(--ofl-ease) forwards}
html.ofl-anim .ofl-st.ofl-st1{animation-delay:.15s}
html.ofl-anim .ofl-st.ofl-st2{animation-delay:.34s}
html.ofl-anim .ofl-st.ofl-st3{animation-delay:.54s}
html.ofl-anim .ofl-st.ofl-st4{animation-delay:.72s}
html.ofl-anim .ofl-st.ofl-st5{animation-delay:.9s}
@keyframes ofl-rise{to{opacity:1;transform:none}}

html.ofl-anim .ofl-reveal{opacity:0;transform:translateY(28px);transition:opacity .9s var(--ofl-ease),transform .9s var(--ofl-ease)}
html.ofl-anim .ofl-reveal.ofl-in{opacity:1;transform:none}
html.ofl-anim .ofl-reveal-h{clip-path:inset(0 0 100% 0);transform:translateY(14px);transition:clip-path 1.05s var(--ofl-ease),transform 1.05s var(--ofl-ease)}
html.ofl-anim .ofl-reveal-h.ofl-in{clip-path:inset(0);transform:none}
html.ofl-anim .ofl-reveal-m{clip-path:inset(100% 0 0 0);transition:clip-path 1.15s var(--ofl-ease)}
html.ofl-anim .ofl-reveal-m.ofl-in{clip-path:inset(0 0 0 0)}
html.ofl-anim .ofl-reveal-m img{transform:scale(1.14);transition:transform 1.5s var(--ofl-ease)}
html.ofl-anim .ofl-reveal-m.ofl-in img{transform:scale(1)}

/* Never hide inside the Elementor editor. */
body.elementor-editor-active .ofl-st,
body.elementor-editor-active .ofl-reveal,
body.elementor-editor-active .ofl-reveal-h,
body.elementor-editor-active .ofl-reveal-m,
body.elementor-editor-active .ofl-reveal-m img{
  opacity:1 !important;transform:none !important;clip-path:none !important;animation:none !important;
}
@media (prefers-reduced-motion:reduce){
  html.ofl-anim .ofl-st,html.ofl-anim .ofl-reveal,html.ofl-anim .ofl-reveal-h,html.ofl-anim .ofl-reveal-m{opacity:1;transform:none;clip-path:none;transition:none;animation:none}
  html.ofl-anim .ofl-reveal-m img,.ofl-hero__bg img{transform:none;animation:none}
}

/* ============ RESPONSIVE ============ */
@media(max-width:1024px){
  .ofl-grid-7-5,.ofl-grid-2{grid-template-columns:1fr;gap:40px}
}
@media(max-width:900px){
  .ofl-hdr__nav{display:none}
  .ofl-hdr__burger{display:flex}
  .ofl-hero__accent{display:none}
  .ofl-hero__stats{grid-template-columns:1fr 1fr}
  .ofl-hero__stat:not(:last-child):after{display:none}
}
@media(max-width:600px){
  .ofl-hero__stats{grid-template-columns:1fr}
  .ofl-hero__cta{flex-direction:column}
  .ofl-hero__cta .ofl-btn{width:100%;justify-content:center}
  .ofl-hero__u{white-space:normal}
}
@media(max-width:480px){
  .ofl-fig img{aspect-ratio:1/1}
}
