/* Kodachi Domain-Info v2, theme + single-page states.
   SPDX-License-Identifier: LicenseRef-Kodachi-SAN-1.0
   Tokens verbatim from /downloads/ + /wiki/bina/ (the approved mockup). */
:root{
  --bg:#000000; --bg-soft:#050505;
  --bg-card:rgba(159,239,0,0.025); --bg-card-hover:rgba(159,239,0,0.055);
  --neon:#9FEF00; --neon-bright:#b6ff1a; --neon-dim:#6fa800; --neon-glow:rgba(159,239,0,0.28);
  --text:#f0f0f0; --text-muted:#9a9a9a; --text-dim:#8a8a8a;
  --border:rgba(159,239,0,0.18); --border-strong:rgba(159,239,0,0.42);
  --danger:#ff3b3b; --warn:#ffcc00; --teal:#35e6d4; --violet:#c9a3ff; --info:#7fd3ff;
  --mono:'JetBrains Mono','SFMono-Regular',Consolas,Menlo,monospace;
  --disp:'Orbitron',sans-serif; --sans:'Inter',system-ui,-apple-system,sans-serif;
}
*{box-sizing:border-box}
/* scrollbar-gutter:stable reserves the scrollbar space so a tooltip that
   momentarily extends the page can't toggle the scrollbar and shift the
   layout sideways ("shake"). overflow-x:hidden kills any sideways scroll. */
html{scrollbar-gutter:stable;overflow-x:hidden}
html,body{margin:0;padding:0;background:var(--bg);color:var(--text);
  font-family:var(--sans);font-size:15px;line-height:1.6;-webkit-font-smoothing:antialiased;overflow-x:hidden}
::selection{background:var(--neon);color:#000}
a{color:var(--neon);text-decoration:none} a:hover{color:var(--neon-bright)}

.appcol{max-width:1180px;margin:0 auto;min-width:0;padding:0 22px}
@media(max-width:760px){.appcol{padding:0 14px}}

.hero{position:relative;padding:26px 0 8px;overflow:visible;z-index:5}  /* z-index so search-box tooltips paint above the history panel below */
.hero::before{content:'';position:absolute;top:-70%;left:50%;transform:translateX(-50%);width:820px;height:820px;background:radial-gradient(circle,var(--neon-glow) 0%,transparent 55%);opacity:.20;pointer-events:none;z-index:0}
.hero::after{content:'';position:absolute;inset:0;background-image:linear-gradient(rgba(159,239,0,.04) 1px,transparent 1px),linear-gradient(90deg,rgba(159,239,0,.04) 1px,transparent 1px);background-size:50px 50px;mask-image:radial-gradient(ellipse at center,#000 30%,transparent 75%);-webkit-mask-image:radial-gradient(ellipse at center,#000 30%,transparent 75%);pointer-events:none;z-index:0}
.hero>*{position:relative;z-index:1}
.eyebrow{display:inline-flex;align-items:center;gap:8px;font-family:var(--mono);font-size:11.5px;color:var(--neon);text-transform:uppercase;letter-spacing:.16em;border:1px solid var(--border-strong);background:rgba(159,239,0,.06);padding:6px 13px;border-radius:999px;margin-bottom:14px}
.eyebrow .dot{width:8px;height:8px;border-radius:50%;background:var(--neon);box-shadow:0 0 10px var(--neon);animation:pulse 1.8s ease-in-out infinite;flex:0 0 auto}
h1.title{font-family:var(--disp);font-weight:900;font-size:clamp(26px,4.4vw,42px);line-height:1.05;margin:0 0 10px;letter-spacing:-.02em;background:linear-gradient(180deg,#fff 0%,var(--neon) 135%);-webkit-background-clip:text;background-clip:text;color:transparent}
.sub{color:var(--text-muted);font-size:15px;max-width:640px}
.toolbar{display:flex;gap:10px;flex-wrap:wrap;margin-top:16px}
.tbtn{font-family:var(--mono);font-size:12.5px;cursor:pointer;border:1px solid var(--border);border-radius:8px;background:rgba(159,239,0,.03);color:var(--text-muted);padding:8px 14px;display:inline-flex;gap:7px;align-items:center}
.tbtn:hover{border-color:var(--border-strong);color:var(--neon)}

.search{display:flex;gap:10px;background:var(--bg-card);border:1px solid var(--border);border-radius:14px;padding:12px;align-items:center;margin-top:14px;flex-wrap:wrap;box-shadow:0 24px 60px -34px var(--neon-glow)}
.search:focus-within{border-color:var(--border-strong)}
.search .glass{color:var(--neon);font-size:18px;padding-left:6px}
.search input{flex:1;min-width:160px;background:transparent;border:0;outline:0;color:#fff;font-family:var(--mono);font-size:16px}
.opts{display:flex;gap:6px;flex-wrap:wrap}
.chip{font-family:var(--mono);font-size:11px;border:1px solid var(--border);border-radius:999px;padding:5px 11px;color:var(--text-muted);cursor:pointer;letter-spacing:.04em;user-select:none}
.chip.on{color:#000;background:rgba(159,239,0,.85);border-color:var(--neon);font-weight:600}

/* terms gate + cache hint */
.terms-row{display:flex;align-items:center;gap:12px;flex-wrap:wrap;margin-top:11px;font-family:var(--mono);font-size:12.5px;color:var(--text-muted)}
.terms-check{display:flex;align-items:center;gap:7px;cursor:pointer;user-select:none}
.terms-check input{accent-color:var(--neon);width:15px;height:15px;cursor:pointer}
.terms-check a{color:var(--neon)} .terms-check a:hover{color:var(--neon-bright)}
.terms-warn{color:var(--danger);font-size:12px}
.terms-row.shake{animation:tshake .4s}
@keyframes tshake{0%,100%{transform:translateX(0)}25%{transform:translateX(-5px)}75%{transform:translateX(5px)}}
.cache-hint{margin-top:11px;border-radius:10px;padding:9px 13px;font-family:var(--mono);font-size:12.5px;background:#101a0a;border:1px solid #2c4413;color:#cdf3a0;display:flex;gap:8px;align-items:center;flex-wrap:wrap}
.cache-hint b{color:var(--neon)} .cache-hint .stale{color:var(--warn)}
.dom-suggest{margin-top:9px;font-family:var(--mono);font-size:12.5px;color:var(--warn)}
.dom-suggest a{color:var(--neon);cursor:pointer;text-decoration:underline}
.dom-suggest a:hover{color:var(--neon-bright)}
.terms-body{font-family:var(--sans);font-size:13px;color:var(--text-muted);line-height:1.65;max-height:46vh;overflow:auto;margin:10px 0}
.terms-body li{margin-bottom:7px} .terms-body strong{color:#e8f4d8}
.btn{display:inline-flex;align-items:center;gap:8px;font-family:var(--sans);font-weight:800;font-size:14px;letter-spacing:.02em;cursor:pointer;border:0;border-radius:8px;padding:12px 20px;background:var(--neon);color:#000;box-shadow:0 0 0 1px var(--neon),0 8px 24px rgba(159,239,0,.22);transition:transform .15s,box-shadow .2s,background .2s;text-decoration:none}
.btn:hover{background:var(--neon-bright);transform:translateY(-2px);box-shadow:0 0 0 1px var(--neon-bright),0 10px 30px rgba(159,239,0,.35);color:#000}
.btn.ghost{background:transparent;color:var(--neon);border:1px solid var(--border-strong);box-shadow:none}
.btn.ghost:hover{background:rgba(159,239,0,.07);transform:none;box-shadow:none;color:var(--neon)}
.btn.warn{background:var(--warn);color:#241c00;box-shadow:0 0 0 1px var(--warn),0 8px 24px rgba(255,204,0,.2)}
.btn.sm{padding:8px 13px;font-size:12px}

.panel{background:var(--bg-card);border:1px solid var(--border);border-radius:14px;padding:20px;margin-top:18px}
.panel h2{font-family:var(--disp);font-weight:700;font-size:16px;margin:0 0 14px;color:var(--text);display:flex;align-items:center;gap:10px}
.badge{font-family:var(--mono);font-size:11px;text-transform:uppercase;letter-spacing:.08em;padding:4px 10px;border-radius:999px;border:1px solid var(--border-strong);color:var(--neon);background:rgba(159,239,0,.07);font-weight:600}
.muted{color:var(--text-muted)} .hidden{display:none!important}

.fring{--p:80;--c:var(--neon);width:44px;height:44px;border-radius:50%;flex:0 0 auto;position:relative;display:grid;place-items:center;
  background:conic-gradient(var(--c) calc(var(--p)*1%),#161b0f 0)}
.fring::after{content:"";position:absolute;inset:5px;border-radius:50%;background:#070905;border:1px solid var(--border)}
.fring span{position:relative;z-index:1;font-family:var(--mono);font-size:10px;color:#fff}

.histbar{display:flex;gap:10px;align-items:center;margin-bottom:12px;flex-wrap:wrap}
.histbar input{background:rgba(0,0,0,.4);border:1px solid var(--border);border-radius:9px;color:#fff;padding:9px 12px;font-family:var(--mono);font-size:13px;flex:1;min-width:170px}
.sortpills{display:flex;gap:6px}
.table-wrap{overflow-x:auto}   /* mobile: history table scrolls horizontally instead of hiding columns */
table{width:100%;border-collapse:collapse;font-size:13.5px;min-width:520px}
/* keyboard focus visibility (a11y) */
.chip:focus-visible,th[data-sort]:focus-visible,tr.row:focus-visible,.tbtn:focus-visible,.btn:focus-visible,.pbtn:focus-visible{outline:2px solid var(--neon);outline-offset:2px}
tr.row:focus-visible td{background:var(--bg-card-hover)}
.hint{display:inline-grid;place-items:center;width:16px;height:16px;border-radius:50%;border:1px solid var(--border-strong);color:var(--neon);font-family:var(--mono);font-size:10px;cursor:help;flex:0 0 auto;user-select:none}
th{text-align:left;color:var(--text-muted);font-weight:600;font-size:11px;text-transform:uppercase;letter-spacing:.08em;padding:9px 10px;border-bottom:1px solid var(--border);cursor:pointer;font-family:var(--mono)}
th .ar{color:var(--neon);font-size:10px;margin-left:3px}
.chip .ar{font-size:10px;margin-left:2px}
td{padding:11px 10px;border-bottom:1px solid rgba(159,239,0,.07);font-family:var(--mono)}
tr.row{cursor:pointer;transition:.12s} tr.row:hover td{background:var(--bg-card-hover)}
.dom{color:#fff;font-weight:600} .when{color:var(--text-muted);font-size:12px}
.grade{font-family:var(--disp);font-weight:900;font-size:13px;width:30px;height:26px;border-radius:7px;display:inline-grid;place-items:center}
.g-A{background:rgba(159,239,0,.12);color:var(--neon);border:1px solid var(--neon-dim)}
.g-B{background:rgba(159,239,0,.1);color:var(--neon);border:1px solid var(--neon-dim)}
.g-C{background:rgba(255,204,0,.12);color:var(--warn);border:1px solid #8a6a00}
.g-D{background:rgba(255,204,0,.12);color:var(--warn);border:1px solid #8a6a00}
.g-E{background:rgba(255,59,59,.12);color:var(--danger);border:1px solid #7a1f1f}
.g-F{background:rgba(255,59,59,.12);color:var(--danger);border:1px solid #7a1f1f}
.recommend{color:var(--warn);font-size:11px;margin-left:6px}
.row-acts{white-space:nowrap;display:flex;gap:5px}
.row-act{cursor:pointer;border:1px solid var(--border);background:rgba(159,239,0,.03);color:var(--text-muted);border-radius:6px;width:24px;height:24px;display:inline-grid;place-items:center;font-size:12px;line-height:1;transition:.12s}
.row-act:hover{border-color:var(--border-strong);color:var(--neon)}
.row-act[data-act="fresh"]:hover{color:var(--warn);border-color:#8a6a00}
.row-act:focus-visible{outline:2px solid var(--neon);outline-offset:1px}
.cache-hint a{color:var(--neon)} .cache-hint a:hover{color:var(--neon-bright)}
.pager{display:flex;align-items:center;gap:10px;margin-top:14px;flex-wrap:wrap;font-family:var(--mono);font-size:12px;color:var(--text-muted)}
.pager .pbtn{border:1px solid var(--border);background:rgba(159,239,0,.03);color:var(--text);border-radius:8px;padding:6px 12px;cursor:pointer;font-family:var(--mono);font-size:12px}
.pager .pbtn:hover:not(:disabled){border-color:var(--border-strong);color:var(--neon)}
.pager .pbtn:disabled{opacity:.35;cursor:not-allowed}
.pager .pinfo{color:var(--text)} .pager .pinfo b{color:var(--neon)}
.pager .pgrow{display:flex;gap:6px;margin-left:auto;align-items:center}
.pager select{background:rgba(0,0,0,.4);border:1px solid var(--border);color:#fff;border-radius:7px;padding:5px 8px;font-family:var(--mono);font-size:12px}
/* site inspector */
.inspector{margin-top:18px;border:1px solid var(--border);border-radius:13px;padding:16px;background:rgba(0,0,0,.22)}
.insp-h{font-family:var(--disp);font-weight:700;font-size:13px;margin:0 0 12px;color:var(--text);display:flex;align-items:center;gap:10px}
.insp-bar{display:flex;gap:8px;flex-wrap:wrap;align-items:center}
.insp-bar input{flex:1;min-width:200px;background:rgba(0,0,0,.4);border:1px solid var(--border);border-radius:9px;color:#fff;padding:10px 12px;font-family:var(--mono);font-size:13px}
.insp-bar input:focus{outline:0;border-color:var(--border-strong)}
.insp-meta{margin-top:12px;font-family:var(--mono);font-size:12px;color:var(--text-muted)}
.insp-meta .ok{color:var(--neon)} .insp-meta .bad{color:var(--danger)}
.insp-scan{display:flex;gap:8px;flex-wrap:wrap;margin-top:10px}
.insp-scan .det{font-family:var(--mono);font-size:11px;border:1px solid var(--border);border-radius:8px;padding:6px 10px;display:flex;gap:7px;align-items:center;cursor:help}
.insp-scan .det b{color:#fff} .insp-scan .det.hit{border-color:#7a4a1f;background:rgba(255,138,61,.08);color:#ffb98a}
.insp-scan .det.clean{color:var(--neon)}
.insp-out{margin-top:12px;max-height:380px;overflow:auto;background:#06090a;border:1px solid var(--border);border-radius:9px;padding:12px;font-family:var(--mono);font-size:12px;color:#cfe8b0;white-space:pre-wrap;word-break:break-word}
.insp-tbl{width:100%;border-collapse:collapse;font-family:var(--mono);font-size:12px;margin-top:10px}
.insp-tbl td{padding:5px 8px;border-bottom:1px solid rgba(159,239,0,.08);vertical-align:top}
.insp-tbl td.k{color:var(--neon);white-space:nowrap;width:1%}
.eng{font-family:var(--mono);font-size:9.5px;font-weight:700;letter-spacing:.06em;padding:2px 7px;border-radius:6px;cursor:help}
.eng-new{background:rgba(159,239,0,.14);color:var(--neon);border:1px solid var(--neon-dim)}
.eng-old{background:rgba(255,204,0,.12);color:var(--warn);border:1px solid #8a6a00}

.cache-card{display:flex;gap:18px;align-items:center;flex-wrap:wrap}
.cache-card .big{font-family:var(--disp);font-weight:700;font-size:18px;color:#fff}
.cache-actions{display:flex;gap:10px;margin-left:auto;flex-wrap:wrap}
.reco{margin-top:14px;border-radius:10px;padding:10px 12px;font-family:var(--mono);font-size:12px;line-height:1.6}
.reco.warn{background:#1a0e0e;border:1px solid #4a1d1d;color:#ffb3b3}
.reco .rescan-link{color:var(--neon);text-decoration:underline;cursor:pointer;font-weight:600}
.reco .rescan-link:hover{color:var(--neon-bright)}
.reco.ok{background:#101a0a;border:1px solid #2c4413;color:#cdf3a0}

.scan-grid{display:grid;grid-template-columns:240px 1fr;gap:24px;align-items:start}
@media(max-width:680px){.scan-grid{grid-template-columns:1fr}}
.radial{position:relative;width:210px;height:210px;margin:0 auto}
.radial svg{transform:rotate(-90deg)}
.radial .pct{position:absolute;inset:0;display:grid;place-items:center;text-align:center}
.radial .pct .n{font-family:var(--disp);font-size:42px;font-weight:900;color:#fff}
.radial .pct .s{font-family:var(--mono);font-size:11px;color:var(--text-muted);letter-spacing:1px}
.stage{font-family:var(--disp);color:var(--neon);font-size:13px;margin-bottom:12px}
.checks{display:grid;grid-template-columns:1fr 1fr;gap:7px 18px}
@media(max-width:520px){.checks{grid-template-columns:1fr}}
.ck{display:flex;align-items:center;gap:9px;font-family:var(--mono);font-size:12.5px;padding:5px 2px;color:var(--text-dim)}
.dot{width:9px;height:9px;border-radius:50%;flex:0 0 auto;background:#2a352a}
.ck.run .dot{background:var(--neon);box-shadow:0 0 8px var(--neon);animation:pulse 1s infinite}
.ck.run{color:var(--neon)} .ck.done .dot{background:var(--neon)} .ck.done{color:var(--text)}
.ck.fail .dot{background:var(--danger)} .ck.fail{color:#e8a6a6}
.ck .t{margin-left:auto;font-size:11px;color:#56624f} .ck.run .t{color:var(--neon)}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.35}}
.log{margin-top:16px;border:1px solid var(--border);border-radius:10px;padding:10px 12px;font-family:var(--mono);font-size:12.5px;height:140px;overflow:auto;background:rgba(0,0,0,.35)}
.log div{padding:2px 0;color:var(--text-muted)} .log .ok{color:var(--neon)} .log .info{color:var(--info)} .log .bad{color:#ffb3b3}
.legend{display:flex;gap:14px;flex-wrap:wrap;font-family:var(--mono);font-size:11px;color:var(--text-muted);margin-top:12px}
.legend span{display:flex;align-items:center;gap:6px}

.scorewrap{display:flex;gap:26px;align-items:center;flex-wrap:wrap;margin-bottom:14px}
.dims{display:flex;gap:14px;flex-wrap:wrap}
.ring{width:74px;height:74px;position:relative;margin:0 auto}
.ring .v{position:absolute;inset:0;display:grid;place-items:center;font-family:var(--disp);font-weight:700;font-size:16px;color:#fff}
.dim .lbl{font-family:var(--mono);font-size:11px;color:var(--text-muted);margin-top:6px;letter-spacing:.06em;text-align:center}
.exports{display:flex;gap:8px;flex-wrap:wrap}
.kpis{display:grid;grid-template-columns:repeat(5,1fr);gap:10px;margin:4px 0 14px}
@media(max-width:760px){.kpis{grid-template-columns:repeat(2,1fr)}}
.kpi{background:rgba(0,0,0,.3);border:1px solid var(--border);border-radius:11px;padding:12px}
.kpi .n{font-family:var(--disp);font-weight:800;font-size:20px;color:#fff}
.kpi .n.green{color:var(--neon)}.kpi .n.amber{color:var(--warn)}.kpi .n.red{color:var(--danger)}
.kpi .l{font-family:var(--mono);font-size:10.5px;color:var(--text-muted);text-transform:uppercase;letter-spacing:.07em;margin-top:3px}
.cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(252px,1fr));gap:13px;margin-top:6px;align-items:start}
.card{background:var(--bg-card);border:1px solid var(--border);border-radius:13px;padding:14px;transition:.2s}
.card:hover{border-color:var(--border-strong);background:var(--bg-card-hover)}
.card h3{font-family:var(--disp);font-weight:700;font-size:12.5px;margin:0 0 10px;color:var(--text);display:flex;align-items:center;gap:8px}
.card-tools{margin-left:auto;display:flex;gap:4px;align-items:center}
.card-tool{cursor:pointer;border:1px solid var(--border);background:rgba(159,239,0,.03);color:var(--text-muted);border-radius:6px;width:22px;height:22px;display:inline-grid;place-items:center;font-size:12px;font-family:var(--mono);line-height:1;user-select:none;transition:.12s}
.card-tool:hover{border-color:var(--border-strong);color:var(--neon)}
.card-tool:focus-visible{outline:2px solid var(--neon);outline-offset:1px}
.card.collapsed{padding-bottom:14px}
.card.collapsed > *:not(h3){display:none!important}
.st{width:8px;height:8px;border-radius:50%}
.st.ok{background:var(--neon)} .st.wn{background:var(--warn)} .st.er{background:var(--danger)} .st.nf{background:var(--teal)}
.kv{display:flex;justify-content:space-between;gap:10px;padding:4px 8px;margin:0 -8px;border-radius:6px;font-family:var(--mono);font-size:12.5px;border-bottom:1px dashed rgba(159,239,0,.08);transition:background .12s}
.kv:last-child{border:0}
.kv:hover{background:rgba(159,239,0,.07)}   /* highlight the FULL record row */
.kv .k{color:var(--text-muted)} .kv .v{color:#e8f4d8;text-align:right;word-break:break-word}
.new-badge{font-family:var(--mono);font-size:9px;background:var(--neon);color:#000;border-radius:5px;padding:1px 5px;font-weight:600;letter-spacing:.04em;cursor:help}
.legacy-pre{margin:0;white-space:pre-wrap;word-break:break-word;font-family:var(--mono);font-size:12px;line-height:1.55;color:#cfe0c0;max-height:none}

.modal{position:fixed;inset:0;display:grid;place-items:center;z-index:300}
.scrim{position:absolute;inset:0;background:#000b;backdrop-filter:blur(3px)}
.box{position:relative;width:min(780px,94vw);max-height:88vh;overflow:auto;background:linear-gradient(180deg,#0c100a,#070905);border:1px solid var(--border-strong);border-radius:16px;padding:22px;box-shadow:0 40px 120px -40px var(--neon-glow)}
.box h3{font-family:var(--disp);margin:0 0 4px;font-size:18px}
.gate{display:flex;align-items:center;gap:10px;background:#101a0a;border:1px solid #2c4413;color:#cdf3a0;border-radius:10px;padding:10px 12px;font-family:var(--mono);font-size:12.5px;margin:12px 0}
.gate.bad{background:#1a0e0e;border-color:#4a1d1d;color:#ffb3b3}
.gate b{color:var(--neon)}
.tabs{display:flex;gap:6px;flex-wrap:wrap;margin:6px 0 12px}
.tab{font-family:var(--mono);padding:6px 12px;border:1px solid var(--border);border-radius:9px;background:rgba(0,0,0,.3);color:var(--text-muted);cursor:pointer;font-size:12px}
.tab.on{background:#15240a;border-color:#2c4413;color:var(--neon)}
.cmp{width:100%;border-collapse:collapse;font-family:var(--mono);font-size:12.5px}
.cmp th,.cmp td{padding:8px 9px;border-bottom:1px solid var(--border);text-align:left;vertical-align:top}
.cmp th{color:var(--text-muted);font-size:11px;text-transform:uppercase;letter-spacing:.05em}
.v-keep{color:var(--text-muted)} .v-imp{color:var(--info)} .v-add{color:var(--neon)} .v-miss{color:var(--danger)}
.foot{display:flex;justify-content:flex-end;gap:10px;margin-top:16px}
.spinner{display:inline-block;width:14px;height:14px;border:2px solid var(--border-strong);border-top-color:var(--neon);border-radius:50%;animation:spin .7s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}

/* Tooltips render BELOW by default so controls near the top of the page never
   clip against the viewport edge. Opt into above with .tip-up (rare). */
[data-tip]{position:relative}
[data-tip]:hover::after{content:attr(data-tip);position:absolute;left:50%;top:calc(100% + 9px);transform:translateX(-50%);width:max-content;max-width:260px;white-space:normal;text-align:left;background:#06090a;color:var(--text);border:1px solid var(--border-strong);border-radius:9px;padding:9px 11px;font-family:var(--mono);font-size:11.5px;line-height:1.5;font-weight:400;letter-spacing:0;box-shadow:0 10px 30px rgba(0,0,0,.7);z-index:400;pointer-events:none}
[data-tip]:hover::before{content:'';position:absolute;left:50%;top:calc(100% + 3px);transform:translateX(-50%);border:6px solid transparent;border-bottom-color:var(--border-strong);z-index:400;pointer-events:none}
[data-tip].tip-up:hover::after{top:auto;bottom:calc(100% + 9px)}
[data-tip].tip-up:hover::before{top:auto;bottom:calc(100% + 3px);border-bottom-color:transparent;border-top-color:var(--border-strong)}
/* keep tooltips inside the viewport horizontally for edge controls */
[data-tip].tip-left:hover::after{left:auto;right:0;transform:none}
[data-tip].tip-left:hover::before{left:auto;right:14px;transform:none}
