/* OneJourney — Logokeuze hub chrome.  Light mode only. Warm / calm / editorial.
   Brand: green #1F4D3A · terracotta #C5683E · sand #E8D8C3 · off-white #F7F2EA · charcoal #2A2A28
   Display: Fraunces · Body/UI: Inter · Mono (IDs/hex): Space Mono
   Layout: slim sticky top bar + on-demand controls drawer (side panel desktop / sheet mobile). */

:root{
  --green:#1F4D3A; --green-d:#163A2B; --terra:#C5683E; --terra-d:#A8552F;
  --sand:#E8D8C3; --sand-d:#D8C4A9; --cream:#F7F2EA; --paper:#FBF8F2;
  --ink:#2A2A28; --ink-2:#5F594E; --ink-3:#6E675B; --line:#E4DCCD;
  --radius:16px; --radius-s:11px; --shadow:0 6px 28px rgba(31,77,58,.10);
  --shadow-lift:0 16px 40px rgba(31,77,58,.16);
  --mono:'Space Mono',ui-monospace,SFMono-Regular,Menlo,monospace;
  --topbar-h:60px;
  --ease:cubic-bezier(.16,1,.3,1);
  /* spacing scale (4pt) */
  --s1:4px; --s2:8px; --s3:12px; --s4:16px; --s5:24px; --s6:32px; --s7:48px; --s8:64px;
  /* z-scale */
  --z-topbar:700; --z-drawer:800; --z-scrim:790; --z-fab:760; --z-lightbox:1000; --z-toast:1200;
}
*{box-sizing:border-box}
html,body{margin:0}
body{
  background:
    radial-gradient(1200px 520px at 88% -8%, rgba(197,104,62,.10), transparent 60%),
    radial-gradient(1000px 600px at 6% 4%, rgba(31,77,58,.07), transparent 55%),
    var(--paper);
  color:var(--ink);
  font:400 16px/1.6 'Inter',system-ui,sans-serif;
  -webkit-font-smoothing:antialiased; text-rendering:optimizeLegibility;
}
.oj-hidden{display:none!important}
.oj-noscroll{overflow:hidden}
.oj-sr{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0 0 0 0);white-space:nowrap;border:0}
.oj-sr:focus{position:fixed;left:12px;top:12px;width:auto;height:auto;margin:0;padding:9px 15px;clip:auto;white-space:normal;background:var(--green);color:var(--cream);border-radius:8px;z-index:1300;font:600 13px 'Inter',sans-serif}
a{color:var(--green)}
::selection{background:rgba(197,104,62,.22)}
.oj-wrap{max-width:1340px;margin:0 auto;padding:0 clamp(18px,4vw,34px)}

/* shared icon strokes */
.oj-ic{flex:0 0 auto;stroke:currentColor;stroke-width:1.9;fill:none;stroke-linecap:round;stroke-linejoin:round}
.oj-ic .oj-ic-fill{fill:currentColor;stroke:none}

/* ============================ top bar ============================ */
.oj-topbar{position:sticky;top:0;z-index:var(--z-topbar);background:var(--paper);
  border-bottom:1px solid transparent;transition:border-color .25s ease, box-shadow .25s ease}
.oj-topbar.scrolled{border-bottom-color:var(--line);box-shadow:0 6px 24px rgba(31,77,58,.07)}
.oj-topbar-inner{max-width:1340px;margin:0 auto;min-height:var(--topbar-h);
  padding:10px clamp(14px,4vw,34px);display:flex;align-items:center;gap:14px}

.oj-brand{display:inline-flex;align-items:center;gap:10px;text-decoration:none;color:var(--ink);flex:0 0 auto}
.oj-mark{position:relative;width:22px;height:22px;overflow:hidden;display:inline-block;flex:0 0 auto}
.oj-mark .sun{position:absolute;left:50%;top:0;transform:translateX(-50%);width:19px;height:19px;border-radius:50%;background:radial-gradient(circle at 50% 38%,#f0a83f,var(--terra))}
.oj-mark .hz{position:absolute;left:-40%;right:-40%;bottom:-16px;height:22px;border-radius:50%;background:var(--paper);border-top:2px solid var(--green)}
.oj-brandname{font:700 18px 'Fraunces',serif;letter-spacing:-.01em}
.oj-brandsub{font:600 10.5px var(--mono);color:var(--ink-3);letter-spacing:.12em;text-transform:uppercase;padding-left:10px;border-left:1px solid var(--line)}

.oj-topbar-tools{margin-left:auto;display:flex;align-items:center;gap:9px;min-width:0}

.oj-search-field{position:relative;display:inline-flex;align-items:center}
.oj-search-field .oj-ic{position:absolute;left:11px;color:var(--ink-3);pointer-events:none}
#oj-search{font:500 13.5px 'Inter',sans-serif;border:1px solid var(--line);border-radius:11px;
  padding:9px 12px 9px 34px;width:230px;max-width:38vw;background:#fff;color:var(--ink);transition:border-color .15s ease}
#oj-search:focus-visible{outline:2px solid var(--green);outline-offset:1px;border-color:var(--green)}
#oj-search::placeholder{color:var(--ink-3)}

/* ============================ buttons (shared) ============================ */
.oj-ubtn{appearance:none;cursor:pointer;border:1px solid var(--line);background:#fff;color:var(--ink);
  border-radius:11px;padding:9px 13px;font:600 13px 'Inter',sans-serif;transition:.16s;
  display:inline-flex;align-items:center;gap:7px;white-space:nowrap}
.oj-ubtn:hover{border-color:var(--green);color:var(--green)}
.oj-ubtn.on{background:var(--terra);border-color:var(--terra);color:#fff}
.oj-ubtn.primary{background:var(--green);border-color:var(--green);color:var(--cream)}
.oj-ubtn.primary:hover{background:var(--green-d);color:var(--cream)}
.oj-ubtn.primary.on{background:var(--terra);border-color:var(--terra);color:#fff}
.oj-ubtn:focus-visible{outline:2px solid var(--green);outline-offset:2px}
.oj-ubtn.primary:focus-visible,.oj-ubtn.on:focus-visible{outline-color:var(--ink)}
.oj-short-count{font:700 12px var(--mono);opacity:.9}

.oj-drawer-toggle{position:relative}
.oj-filter-dot{position:absolute;top:-4px;right:-4px;width:10px;height:10px;border-radius:50%;
  background:var(--terra);border:2px solid var(--paper)}

/* ============================ FAB (mobile control trigger) ============================ */
.oj-fab{position:fixed;right:16px;bottom:calc(16px + env(safe-area-inset-bottom,0px));z-index:var(--z-fab);
  width:54px;height:54px;border-radius:17px;border:none;background:var(--green);color:var(--cream);
  box-shadow:var(--shadow-lift);cursor:pointer;display:none;align-items:center;justify-content:center;
  opacity:.95;transition:transform .25s var(--ease), opacity .2s}
.oj-fab:hover,.oj-fab:focus-visible{opacity:1;transform:translateY(-2px)}
.oj-fab:active{transform:translateY(0) scale(.96)}
.oj-fab:focus-visible{outline:2px solid var(--ink);outline-offset:3px}
.oj-fab svg{stroke:currentColor;stroke-width:2;fill:none;stroke-linecap:round}
.oj-fab svg .oj-ic-fill{fill:currentColor;stroke:none}
.oj-fab-dot{position:absolute;top:9px;right:9px;width:11px;height:11px;border-radius:50%;
  background:var(--terra);border:2px solid var(--green)}

/* ============================ scrim ============================ */
.oj-scrim{position:fixed;inset:0;z-index:var(--z-scrim);background:rgba(20,18,15,.42);
  opacity:0;pointer-events:none;transition:opacity .3s ease}
.oj-scrim.show{opacity:1;pointer-events:auto}

/* ============================ controls drawer ============================ */
.oj-drawer{position:fixed;top:0;right:0;height:100dvh;width:min(384px,92vw);z-index:var(--z-drawer);
  background:var(--paper);border-left:1px solid var(--line);box-shadow:-20px 0 60px rgba(31,77,58,.14);
  transform:translateX(104%);transition:transform .42s var(--ease);
  display:flex;flex-direction:column;overscroll-behavior:contain}
.oj-drawer.open{transform:none}
.oj-drawer[inert]{pointer-events:none}

.oj-drawer-head{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;
  padding:18px 20px 14px;border-bottom:1px solid var(--line)}
.oj-drawer-title{margin:0;font:600 19px 'Fraunces',serif;letter-spacing:-.01em}
.oj-drawer-live{display:block;margin-top:2px;font:600 11.5px var(--mono);color:var(--ink-3)}
.oj-drawer-close{appearance:none;cursor:pointer;border:1px solid var(--line);background:#fff;color:var(--ink-2);
  width:36px;height:36px;border-radius:10px;display:inline-flex;align-items:center;justify-content:center;flex:0 0 auto;transition:.15s}
.oj-drawer-close svg{stroke:currentColor;stroke-width:2;fill:none;stroke-linecap:round}
.oj-drawer-close:hover{border-color:var(--terra);color:var(--terra)}
.oj-drawer-close:focus-visible{outline:2px solid var(--green);outline-offset:2px}

.oj-drawer-body{flex:1 1 auto;overflow-y:auto;padding:6px 20px 28px;-webkit-overflow-scrolling:touch}
.oj-dsec{padding:16px 0;border-bottom:1px solid var(--line)}
.oj-dsec:last-of-type{border-bottom:none}
.oj-dsec-h{display:flex;align-items:baseline;justify-content:space-between;gap:10px;margin:0 0 12px}
.oj-dsec-h h3{margin:0;font:700 11px var(--mono);letter-spacing:.13em;text-transform:uppercase;color:var(--ink-3)}
.oj-palname{font:700 11.5px var(--mono);color:var(--green);letter-spacing:.02em}

/* palette as a scannable list (swatch + name) */
.oj-pal-list{display:flex;flex-direction:column;gap:6px}
.oj-pbtn{appearance:none;cursor:pointer;border:1px solid var(--line);background:#fff;color:var(--ink);
  border-radius:11px;padding:9px 12px;font:600 13.5px 'Inter',sans-serif;transition:.16s;
  display:inline-flex;align-items:center;gap:11px;text-align:left;width:100%}
.oj-pbtn:hover{border-color:var(--terra);color:var(--green)}
.oj-pbtn:focus-visible{outline:2px solid var(--green);outline-offset:2px}
.oj-pbtn[aria-pressed="true"]{background:var(--green);border-color:var(--green);color:var(--cream)}
.oj-pbtn .sw{width:24px;height:24px;border-radius:7px;border:1px solid rgba(0,0,0,.16);flex:0 0 auto}
.oj-pbtn[aria-pressed="true"] .sw{border-color:rgba(255,255,255,.5)}
.oj-sw-custom{background:conic-gradient(from 210deg,#C5683E,#1F4D3A,#E8D8C3,#C5683E)}

#oj-custom{display:flex;gap:10px;flex-wrap:wrap;align-items:flex-end;margin-top:12px}
#oj-custom[hidden]{display:none}
#oj-custom label{display:flex;flex-direction:column;gap:5px;font:600 10px var(--mono);letter-spacing:.05em;text-transform:uppercase;color:var(--ink-3)}
#oj-custom input[type=color]{width:84px;height:34px;padding:0;border:1px solid var(--line);border-radius:9px;background:#fff;cursor:pointer}

.oj-slider{display:flex;flex-direction:column;gap:9px;margin-top:6px}
.oj-flabel{font:600 12.5px 'Inter',sans-serif;color:var(--ink-2);display:flex;align-items:center;gap:8px}
.oj-flabel #oj-int-val{font:700 12px var(--mono);color:var(--green)}
input[type=range]{accent-color:var(--green);width:100%;cursor:pointer}
.oj-check{display:flex;align-items:center;gap:9px;font:600 13px 'Inter',sans-serif;color:var(--ink-2);cursor:pointer;margin-top:14px}
.oj-check input{accent-color:var(--green);width:16px;height:16px;flex:0 0 auto}

.oj-fam{display:flex;gap:7px;flex-wrap:wrap}
.oj-fchip{appearance:none;cursor:pointer;border:1px solid var(--line);background:#fff;color:var(--ink-2);
  border-radius:999px;padding:6px 12px;font:600 12px 'Inter',sans-serif;transition:.14s}
.oj-fchip:hover{border-color:var(--terra);color:var(--green)}
.oj-fchip[aria-pressed="true"]{background:rgba(31,77,58,.10);border-color:var(--green);color:var(--green)}
.oj-fchip:focus-visible{outline:2px solid var(--green);outline-offset:2px}

.oj-drawer-actions{display:flex;gap:8px;flex-wrap:wrap}
.oj-drawer-actions .oj-ubtn{flex:1 1 auto;justify-content:center}

/* "Voor ontwerpers" disclosure inside drawer */
.oj-adv{border-top:1px solid var(--line)}
.oj-adv>summary{cursor:pointer;list-style:none;font:700 11px var(--mono);letter-spacing:.13em;text-transform:uppercase;
  color:var(--ink-3);padding:16px 0 4px;display:inline-flex;align-items:center;gap:7px}
.oj-adv>summary::-webkit-details-marker{display:none}
.oj-adv>summary::before{content:"▸";color:var(--ink-3)}
.oj-adv[open]>summary{color:var(--green)}
.oj-adv[open]>summary::before{content:"▾"}
.oj-adv>summary:focus-visible{outline:2px solid var(--green);outline-offset:2px;border-radius:5px}
.oj-adv .oj-dsec{border-bottom:none;padding-top:6px}

.oj-contrast{display:flex;gap:6px;flex-wrap:wrap}
.oj-cgrade{font:600 11px var(--mono);padding:4px 9px;border-radius:7px;background:rgba(31,77,58,.06);color:var(--ink-2)}
.oj-cgrade[data-g="ok"]{background:rgba(31,77,58,.10);color:var(--green)}
.oj-cgrade[data-g="no"]{background:rgba(168,85,47,.12);color:var(--terra-d)}

/* ============================ sections + grids ============================ */
.oj-sec{margin:clamp(28px,4vw,46px) 0 10px}
.oj-sec:first-child{margin-top:clamp(22px,3vw,34px)}
.oj-sec-h{display:flex;align-items:baseline;gap:12px;margin:0 0 18px;flex-wrap:wrap}
.oj-sec-h h2{margin:0;font:600 clamp(22px,2.6vw,30px)/1.1 'Fraunces',serif;letter-spacing:-.01em}
.oj-sec-h .sub{font-size:14.5px;color:var(--ink-2)}
.oj-sec-h .count{font:600 11px var(--mono);color:var(--ink-3);background:rgba(31,77,58,.06);padding:3px 9px;border-radius:999px}
.oj-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(330px,1fr));gap:20px}

/* cards (base bg/border come from inline styles; we add interaction polish) */
.oj-card{transition:transform .18s ease, box-shadow .18s ease, outline-color .18s ease;outline:2px solid transparent;outline-offset:3px}
.oj-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lift)!important}
.oj-card.oj-picked{outline-color:var(--terra)}
.oj-stage{transition:background .25s ease}

/* footer meta */
.oj-foot{position:relative}
.oj-meta{margin-top:12px;border-top:1px dashed var(--line);padding-top:11px;display:flex;flex-direction:column;gap:9px}
.oj-metatop{display:flex;align-items:center;justify-content:space-between;gap:8px}
.oj-cardid{font:700 11px var(--mono);letter-spacing:.06em;color:var(--green);background:rgba(31,77,58,.07);
  border:1px solid rgba(31,77,58,.13);padding:3px 8px;border-radius:7px;cursor:pointer;user-select:all}
.oj-cardid:hover{background:rgba(31,77,58,.12)}
.oj-cardid:focus-visible{outline:2px solid var(--green);outline-offset:2px}
.oj-star{appearance:none;cursor:pointer;border:1px solid var(--line);background:#fff;color:var(--ink-3);
  width:30px;height:30px;border-radius:9px;display:inline-flex;align-items:center;justify-content:center;transition:.15s}
.oj-star svg{fill:none;stroke:currentColor;stroke-width:1.6}
.oj-star:hover{border-color:var(--terra);color:var(--terra)}
.oj-star.on{background:var(--terra);border-color:var(--terra);color:#fff}
.oj-star.on svg{fill:#fff;stroke:#fff}
.oj-star:focus-visible{outline:2px solid var(--green);outline-offset:2px}

.oj-chips{display:flex;gap:6px;flex-wrap:wrap}
.oj-chip{appearance:none;cursor:pointer;display:inline-flex;align-items:center;gap:6px;border:1px solid var(--line);
  background:#fff;border-radius:8px;padding:4px 8px 4px 5px;font:600 10.5px var(--mono);color:var(--ink-2);transition:.14s}
.oj-chip:hover{border-color:var(--green);color:var(--ink)}
.oj-chip .oj-sw{width:13px;height:13px;border-radius:4px;border:1px solid rgba(0,0,0,.16)}
.oj-actions{display:flex;gap:6px;flex-wrap:wrap}
.oj-actions button{appearance:none;cursor:pointer;border:1px solid var(--line);background:#fff;color:var(--ink-2);
  border-radius:8px;padding:5px 9px;font:600 11.5px 'Inter',sans-serif;white-space:nowrap;transition:.14s}
.oj-actions button:hover{border-color:var(--green);color:var(--green)}
.oj-actions button:focus-visible,.oj-chip:focus-visible{outline:2px solid var(--green);outline-offset:2px}

/* ============================ imports (plain full-width accordion) ============================ */
.oj-imports{margin:clamp(40px,6vw,72px) 0 10px;padding:clamp(22px,3vw,34px) 0 8px;border-top:1px solid var(--line)}
.oj-imports-inner{max-width:1340px;margin:0 auto;padding:0 clamp(18px,4vw,34px)}
.oj-imports .intro{max-width:64ch;color:var(--ink-2);margin:0 0 18px}
.oj-acc-list{border-top:1px solid var(--line)}
.oj-acc{border-bottom:1px solid var(--line)}
.oj-acc>summary{cursor:pointer;list-style:none;padding:18px 6px;display:flex;align-items:center;gap:13px;flex-wrap:wrap;
  font:600 19px 'Fraunces',serif;transition:color .15s;border-radius:10px}
.oj-acc>summary::-webkit-details-marker{display:none}
.oj-acc>summary:hover{color:var(--green)}
.oj-acc>summary:focus-visible{outline:2px solid var(--green);outline-offset:2px}
.oj-acc>summary .tag{font:600 11px var(--mono);color:var(--terra);background:rgba(197,104,62,.10);border:1px solid rgba(197,104,62,.2);padding:3px 9px;border-radius:999px}
.oj-acc>summary .desc{font:400 13.5px 'Inter',sans-serif;color:var(--ink-2);order:3;flex-basis:100%;margin:0}
.oj-acc-right{order:2;margin-left:auto;display:flex;align-items:center;gap:12px}
.oj-acc .chev{transition:transform .2s ease;color:var(--ink-3);font-size:22px;line-height:1}
.oj-acc.oj-nudge-on .chev{animation:oj-nudge 1.9s ease-in-out 2}        /* finite: nudges once on scroll-into-view */
.oj-acc:nth-child(2).oj-nudge-on .chev{animation-delay:.4s}
.oj-acc:nth-child(3).oj-nudge-on .chev{animation-delay:.8s}
.oj-acc:nth-child(4).oj-nudge-on .chev{animation-delay:1.2s}
.oj-acc>summary:hover .chev,.oj-acc[open] .chev{animation:none}
.oj-acc[open] .chev{transform:rotate(90deg)}
.oj-acc[open]>summary{color:var(--green)}
.oj-acc-picked>summary{background:rgba(197,104,62,.10);box-shadow:inset 0 0 0 1px rgba(197,104,62,.42)}
.oj-acc-body{padding:0 6px 24px}
.oj-acc[open]>.oj-acc-body{animation:oj-reveal .34s var(--ease) both}
.oj-acc-frame{width:100%;height:85vh;min-height:560px;border:1px solid var(--line);background:#fff;display:block}
.oj-acc-fallback{padding:16px 6px;color:var(--ink-2)}
@keyframes oj-nudge{0%,58%,100%{transform:translateX(0)}68%{transform:translateX(4px)}78%{transform:translateX(0)}88%{transform:translateX(4px)}}
@keyframes oj-reveal{from{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:none}}

/* ============================ lightbox ============================ */
#oj-lightbox{position:fixed;inset:0;z-index:var(--z-lightbox);display:flex;align-items:center;justify-content:center;padding:clamp(14px,3vw,34px)}
#oj-lightbox[hidden]{display:none}
.oj-lb-backdrop{position:absolute;inset:0;background:rgba(20,18,15,.55)}
.oj-lb-panel{position:relative;z-index:1;width:min(760px,100%);max-height:92vh;overflow:auto;background:var(--paper);
  border-radius:20px;box-shadow:0 30px 80px rgba(0,0,0,.4);padding:18px clamp(16px,3vw,28px) 22px}
.oj-lb-close{position:absolute;top:12px;right:14px;appearance:none;border:none;background:transparent;font-size:28px;line-height:1;color:var(--ink-3);cursor:pointer}
.oj-lb-close:hover{color:var(--ink)}
.oj-lb-stagewrap{border-radius:14px;overflow:hidden;display:flex;align-items:center;justify-content:center;min-height:330px;transition:background .25s}
.oj-lb-stagewrap[data-bg="dark"]{background:radial-gradient(circle at 50% 44%,#143036 0%,#0e2226 72%)}
.oj-lb-stagewrap[data-bg="light"]{background:#fff;border:1px solid var(--line)}
.oj-lb-stagewrap[data-bg="sand"]{background:var(--sand)}
.oj-lb-stage{transform:scale(2);transform-origin:center}
.oj-lb-stage>div{height:224px;display:flex;align-items:center;justify-content:center}
.oj-lb-bgrow{display:flex;gap:7px;margin:14px 0 4px}
.oj-lb-bgrow button{appearance:none;cursor:pointer;border:1px solid var(--line);background:#fff;color:var(--ink-2);border-radius:9px;padding:6px 12px;font:600 12.5px 'Inter',sans-serif}
.oj-lb-bgrow button[aria-pressed="true"]{background:var(--green);border-color:var(--green);color:var(--cream)}
.oj-lb-bgrow button:focus-visible,.oj-lb-actions button:focus-visible,.oj-lb-close:focus-visible{outline:2px solid var(--green);outline-offset:2px}
.oj-lb-info{margin-top:14px}
.oj-lb-id{font:700 12px var(--mono);color:var(--green);letter-spacing:.06em}
.oj-lb-name{font:600 22px 'Fraunces',serif;margin:2px 0 4px}
.oj-lb-desc{color:var(--ink-2);font-size:14.5px;margin-bottom:12px}
.oj-lb-chips{margin-bottom:4px}
.oj-lb-actions{display:flex;gap:8px;flex-wrap:wrap;margin-top:14px}
.oj-lb-actions button{appearance:none;cursor:pointer;border:1px solid var(--line);background:#fff;color:var(--ink);border-radius:10px;padding:8px 13px;font:600 13px 'Inter',sans-serif}
.oj-lb-actions button:hover{border-color:var(--green);color:var(--green)}

/* ============================ CTA + footer ============================ */
.oj-cta{margin:clamp(40px,5vw,58px) 0 22px;border-radius:22px;padding:clamp(26px,4vw,46px);
  background:linear-gradient(135deg,var(--green) 0%,var(--green-d) 100%);color:var(--cream);position:relative;overflow:hidden}
.oj-cta::after{content:"";position:absolute;right:-60px;top:-60px;width:280px;height:280px;border-radius:50%;
  background:radial-gradient(circle at 40% 40%,rgba(240,168,63,.5),transparent 65%);pointer-events:none}
.oj-cta h2{margin:0 0 10px;font:600 clamp(24px,3vw,34px)/1.1 'Fraunces',serif}
.oj-cta p{margin:0 0 20px;max-width:56ch;color:rgba(247,242,234,.86);font-size:16px}
.oj-cta .row{display:flex;gap:12px;flex-wrap:wrap;align-items:center}
.oj-cta-btn{background:var(--terra);color:#fff;border:none;border-radius:12px;padding:13px 22px;font:700 15px 'Inter',sans-serif;cursor:pointer;text-decoration:none;display:inline-flex;align-items:center;gap:9px;transition:.16s}
.oj-cta-btn:hover{background:#fff;color:var(--green)}
.oj-cta .ghost{background:rgba(255,255,255,.12);color:var(--cream);border:1px solid rgba(255,255,255,.32)}
.oj-cta .ghost:hover{background:rgba(255,255,255,.2);color:#fff;border-color:rgba(255,255,255,.5)}
.oj-cta .ghost:focus-visible{outline:2px solid #fff;outline-offset:2px}

.oj-footer{padding:30px 0 60px;color:var(--ink-3);font-size:13px;display:flex;justify-content:space-between;gap:16px;flex-wrap:wrap;border-top:1px solid var(--line);margin-top:30px}

/* ============================ toast ============================ */
#oj-toast{position:fixed;left:50%;bottom:26px;transform:translate(-50%,18px);z-index:var(--z-toast);
  background:var(--ink);color:var(--cream);padding:11px 18px;border-radius:12px;font:600 13.5px 'Inter',sans-serif;
  box-shadow:0 12px 30px rgba(0,0,0,.3);opacity:0;pointer-events:none;transition:.22s}
#oj-toast.show{opacity:1;transform:translate(-50%,0)}

/* ============================ responsive ============================ */
@media (max-width:900px){
  .oj-fab{display:inline-flex}
  .oj-drawer-toggle{display:none}
  /* drawer becomes a bottom sheet */
  .oj-drawer{top:auto;bottom:0;left:0;right:0;width:auto;height:auto;max-height:88dvh;
    border-left:none;border-top:1px solid var(--line);border-radius:22px 22px 0 0;
    transform:translateY(104%);box-shadow:0 -20px 60px rgba(0,0,0,.22)}
  .oj-drawer.open{transform:none}
  .oj-drawer-body{padding-bottom:calc(28px + env(safe-area-inset-bottom,0px))}
}
@media (max-width:620px){
  .oj-brandsub{display:none}
  #oj-search{width:100%;max-width:none}
  .oj-search-field{flex:1 1 auto;min-width:0}
  .oj-short-lbl{display:none}
  .oj-topbar-tools{gap:8px;flex:1 1 auto;justify-content:flex-end}
  .oj-grid{grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:14px}
}
@media (max-width:380px){
  .oj-brandname{display:none}
}
@media (prefers-reduced-motion:reduce){
  *{transition:none!important;animation:none!important}
}
