@import url('https://fonts.googleapis.com/css2?family=Bricolage+Grotesque:opsz,wght@12..96,400;12..96,600;12..96,700;12..96,800&family=DM+Sans:opsz,wght@9..40,300;9..40,400;9..40,500&display=swap');

/* ════════════════ TOKENS ════════════════ */
:root {
  --ink:       #0b1728;
  --ink-70:    rgba(11,23,40,.70);
  --ink-40:    rgba(11,23,40,.40);
  --ink-12:    rgba(11,23,40,.12);
  --ink-06:    rgba(11,23,40,.06);
  --teal:      #00897b;
  --teal-d:    #005f56;
  --teal-glow: rgba(0,137,123,.10);
  --teal-glow2:rgba(0,137,123,.18);
  --amber:     #f59e0b;
  --green:     #10b981;
  --red:       #ef4444;
  --blue:      #3b82f6;
  --purple:    #8b5cf6;
  --surf:      #ffffff;
  --surf2:     #f6f9fb;
  --surf3:     #edf1f5;
  --border:    rgba(0,0,0,.08);
  --border-m:  rgba(0,0,0,.14);
  --r-sm:      8px;
  --r-md:      13px;
  --r-lg:      20px;
  --r-xl:      28px;
  --sh-card:   0 2px 10px rgba(0,0,0,.055),0 1px 3px rgba(0,0,0,.04);
  --sh-elev:   0 12px 40px rgba(0,0,0,.11),0 2px 8px rgba(0,0,0,.06);
  --fh:        'Bricolage Grotesque',sans-serif;
  --fb:        'DM Sans',sans-serif;
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
body{font-family:var(--fb);color:var(--ink);background:var(--surf2)}

/* ════════════════ HERO ════════════════ */
.ls-hero{
  background:var(--ink);padding:44px 0 82px;
  position:relative;overflow:hidden;
}
.ls-hero-grid{
  position:absolute;inset:0;pointer-events:none;
  background-image:linear-gradient(rgba(255,255,255,.025) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.025) 1px,transparent 1px);
  background-size:52px 52px
}
.ls-hero-glow{
  position:absolute;inset:0;pointer-events:none;
  background:radial-gradient(ellipse 55% 90% at 5% 50%,rgba(0,137,123,.17) 0%,transparent 60%),
             radial-gradient(ellipse 35% 55% at 88% 15%,rgba(0,137,123,.09) 0%,transparent 55%)
}
.ls-eyebrow{
  display:inline-flex;align-items:center;gap:8px;
  background:rgba(0,137,123,.18);border:1px solid rgba(0,137,123,.32);
  color:#4dd0c4;padding:5px 14px;border-radius:40px;
  font-size:.7rem;font-weight:600;letter-spacing:1.3px;text-transform:uppercase;margin-bottom:18px
}
.ls-eyebrow-dot{width:6px;height:6px;background:#4dd0c4;border-radius:50%;animation:pulseD 2s ease-in-out infinite}
@keyframes pulseD{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(1.5)}}
.ls-hero-title{
  font-family:var(--fh);font-size:clamp(1.9rem,3.5vw,3rem);
  font-weight:800;color:#fff;line-height:1.15;letter-spacing:-.4px;margin-bottom:12px
}
.ls-hero-title em{font-style:normal;color:#4dd0c4}
.ls-hero-sub{color:rgba(255,255,255,.48);font-size:.97rem;max-width:500px;line-height:1.65}
.ls-stats{display:flex;gap:32px;margin-top:26px;padding-top:26px;border-top:1px solid rgba(255,255,255,.08)}
.ls-stat-n{font-family:var(--fh);font-size:1.45rem;font-weight:800;color:#fff}
.ls-stat-l{font-size:.68rem;color:rgba(255,255,255,.38);text-transform:uppercase;letter-spacing:.9px;margin-top:2px}

/* PAGE SWITCHER TABS */
.ls-page-tabs{
  display:inline-flex;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.12);
  border-radius:40px;padding:4px;gap:4px;margin-bottom:24px
}
.ls-page-tab{
  padding:7px 20px;border-radius:40px;font-size:.82rem;font-weight:600;
  cursor:pointer;transition:all .2s;border:none;background:transparent;
  color:rgba(255,255,255,.55);display:flex;align-items:center;gap:7px
}
.ls-page-tab.active{background:var(--teal);color:#fff}
.ls-page-tab:hover:not(.active){color:#fff}

/* SEARCHBOX */
.ls-sbox{
  background:#fff;border-radius:var(--r-xl);
  display:flex;align-items:center;
  box-shadow:0 24px 64px rgba(0,0,0,.32),0 0 0 1px rgba(255,255,255,.07);
  margin-top:28px;position:relative;z-index:3;padding:5px 5px 5px 20px
}
.ls-sbox-ico{color:var(--teal);font-size:1rem;flex-shrink:0;margin-right:4px}
.ls-sbox input{border:none;outline:none;flex:1;font-family:var(--fb);font-size:.97rem;color:var(--ink);background:transparent;padding:11px 6px}
.ls-sbox input::placeholder{color:var(--ink-40)}
.ls-sdiv{width:1px;background:var(--border-m);height:34px;flex-shrink:0;margin:0 2px}
.ls-sbox select{border:none;outline:none;background:transparent;font-family:var(--fb);font-size:.85rem;color:var(--ink-70);padding:11px 14px;cursor:pointer;min-width:145px}
.ls-sbox-btn{background:var(--teal);color:#fff;border:none;border-radius:20px;padding:12px 26px;font-family:var(--fh);font-size:.88rem;font-weight:700;cursor:pointer;display:flex;align-items:center;gap:7px;white-space:nowrap;transition:background .2s,transform .15s;flex-shrink:0}
.ls-sbox-btn:hover{background:var(--teal-d);transform:translateY(-1px)}

.ls-pills{display:flex;flex-wrap:wrap;gap:7px;margin-top:15px;position:relative;z-index:2}
.ls-pill{background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.12);color:rgba(255,255,255,.72);padding:5px 15px;border-radius:40px;font-size:.76rem;font-weight:500;cursor:pointer;transition:all .18s;display:flex;align-items:center;gap:5px}
.ls-pill:hover,.ls-pill.active{background:var(--teal);border-color:var(--teal);color:#fff}

/* ════════════════ LAYOUT ════════════════ */
.ls-layout{display:grid;grid-template-columns:292px 1fr;gap:22px;margin-top:-44px;align-items:start}

/* ════════════════ SIDEBAR ════════════════ */
.ls-sidebar{background:var(--surf);border-radius:var(--r-lg);border:1px solid var(--border);box-shadow:var(--sh-card);position:sticky;top:14px;overflow:hidden}
.ls-sb-head{display:flex;align-items:center;justify-content:space-between;padding:15px 20px;border-bottom:1px solid var(--border);background:var(--surf2)}
.ls-sb-head h6{font-family:var(--fh);font-size:.86rem;font-weight:700;display:flex;align-items:center;gap:8px}
.ls-sb-head h6 i{color:var(--teal)}
.ls-clear-all{font-size:.73rem;color:var(--ink-40);background:none;border:none;cursor:pointer;padding:4px 9px;border-radius:var(--r-sm);transition:all .2s}
.ls-clear-all:hover{color:var(--red);background:rgba(239,68,68,.08)}
.ls-sb-body{max-height:calc(100vh - 110px);overflow-y:auto;scroll-behavior:smooth}
.ls-sb-body::-webkit-scrollbar{width:3px}
.ls-sb-body::-webkit-scrollbar-thumb{background:var(--border-m);border-radius:4px}
.ls-section{border-bottom:1px solid var(--border)}
.ls-sec-toggle{width:100%;display:flex;align-items:center;justify-content:space-between;padding:13px 20px;background:none;border:none;cursor:pointer;font-family:var(--fb);transition:background .15s;text-align:left}
.ls-sec-toggle:hover{background:var(--surf2)}
.ls-sec-label{display:flex;align-items:center;gap:9px;font-size:.78rem;font-weight:600;color:var(--ink);text-transform:uppercase;letter-spacing:.7px}
.ls-sec-label i{color:var(--teal);font-size:.84rem;width:14px;text-align:center}
.ls-caret{color:var(--ink-40);font-size:.7rem;transition:transform .22s}
.ls-sec-toggle.open .ls-caret{transform:rotate(180deg)}
.ls-sec-body{display:none;padding:4px 20px 15px}
.ls-sec-body.open{display:block}
.ls-fi-search{width:100%;padding:7px 11px;border:1px solid var(--border-m);border-radius:var(--r-sm);font-family:var(--fb);font-size:.8rem;outline:none;color:var(--ink);background:var(--surf2);margin-bottom:9px;transition:border-color .2s}
.ls-fi-search:focus{border-color:var(--teal);background:#fff}
.ls-checklist{display:flex;flex-direction:column;gap:2px;max-height:190px;overflow-y:auto}
.ls-checklist::-webkit-scrollbar{width:2px}
.ls-checklist::-webkit-scrollbar-thumb{background:var(--border-m)}
.ls-cw{display:flex;align-items:center;gap:9px;padding:5px 8px;border-radius:var(--r-sm);cursor:pointer;transition:background .14s}
.ls-cw:hover{background:var(--teal-glow)}
.ls-cw input[type=checkbox]{width:14px;height:14px;accent-color:var(--teal);cursor:pointer;flex-shrink:0}
.ls-cw-label{font-size:.83rem;color:var(--ink);flex:1;cursor:pointer}
.ls-pair{display:grid;grid-template-columns:1fr 1fr;gap:7px}
.ls-ni{width:100%;padding:7px 9px;border:1px solid var(--border-m);border-radius:var(--r-sm);font-family:var(--fb);font-size:.8rem;outline:none;color:var(--ink);transition:border-color .2s}
.ls-ni:focus{border-color:var(--teal)}
.ls-range{width:100%;accent-color:var(--teal);cursor:pointer}
.ls-range-row{display:flex;justify-content:space-between;font-size:.72rem;color:var(--ink-40);margin-top:5px}
.ls-range-val{font-weight:700;color:var(--teal)}
.ls-toggle-row{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px;cursor:pointer}
.ls-toggle-txt{font-size:.83rem;color:var(--ink)}
.ls-sw{position:relative;width:34px;height:18px;flex-shrink:0}
.ls-sw input{opacity:0;width:0;height:0}
.ls-sw-track{position:absolute;inset:0;background:var(--surf3);border-radius:10px;cursor:pointer;transition:background .2s}
.ls-sw input:checked+.ls-sw-track{background:var(--teal)}
.ls-sw-track::after{content:'';position:absolute;left:2px;top:2px;width:14px;height:14px;background:#fff;border-radius:50%;transition:transform .2s;box-shadow:0 1px 3px rgba(0,0,0,.22)}
.ls-sw input:checked+.ls-sw-track::after{transform:translateX(16px)}
.ls-apply{width:100%;background:var(--teal);color:#fff;border:none;padding:14px;font-family:var(--fh);font-size:.87rem;font-weight:700;cursor:pointer;letter-spacing:.3px;display:flex;align-items:center;justify-content:center;gap:8px;transition:background .2s}
.ls-apply:hover{background:var(--teal-d)}

/* ════════════════ TOOLBAR ════════════════ */
.ls-results{min-width:0}
.ls-toolbar{background:var(--surf);border-radius:var(--r-md);padding:12px 18px;margin-bottom:18px;display:flex;align-items:center;gap:12px;flex-wrap:wrap;border:1px solid var(--border);box-shadow:var(--sh-card);position: sticky;}
.ls-count{font-family:var(--fh);font-weight:700;font-size:.88rem;color:var(--ink);white-space:nowrap}
.ls-count strong{color:var(--teal)}
.ls-tb-right{display:flex;align-items:center;gap:9px;margin-left:auto}
.ls-sort{padding:7px 11px;border:1px solid var(--border-m);border-radius:var(--r-sm);font-family:var(--fb);font-size:.8rem;color:var(--ink);outline:none;cursor:pointer;background:#fff}
.ls-views{display:flex;background:var(--surf3);border-radius:var(--r-sm);overflow:hidden}
.ls-vbtn{padding:7px 11px;border:none;background:transparent;color:var(--ink-40);cursor:pointer;font-size:.85rem;transition:all .14s}
.ls-vbtn.active{background:var(--teal);color:#fff}
.ls-exp{background:#fff;border:1px solid var(--border-m);border-radius:var(--r-sm);padding:7px 14px;font-size:.78rem;font-weight:600;cursor:pointer;display:flex;align-items:center;gap:6px;color:var(--ink-70);transition:all .2s}
.ls-exp:hover{border-color:var(--teal);color:var(--teal)}
.ls-tag-row{display:flex;flex-wrap:wrap;gap:6px;flex:1}
.ls-tag{display:inline-flex;align-items:center;gap:5px;background:var(--teal-glow);border:1px solid rgba(0,137,123,.18);color:var(--teal-d);padding:4px 11px;border-radius:40px;font-size:.73rem;font-weight:600}
.ls-tag-x{cursor:pointer;opacity:.55}
.ls-tag-x:hover{opacity:1}

/* ════════════════ CARDS ════════════════ */
.ls-grid{display:grid;gap:16px}
.ls-grid.gv{grid-template-columns:repeat(auto-fill,minmax(310px,1fr))}
.ls-grid.lv{grid-template-columns:1fr}
.ls-card{background:var(--surf);border-radius:var(--r-lg);border:1px solid var(--border);box-shadow:var(--sh-card);position:relative;overflow:hidden;transition:transform .24s,box-shadow .24s,border-color .24s;animation:cardIn .35s ease both}
.ls-card::before{content:'';position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,var(--teal),#4dd0c4);transform:scaleX(0);transform-origin:left;transition:transform .28s}
.ls-card:hover{transform:translateY(-4px);box-shadow:var(--sh-elev);border-color:rgba(0,137,123,.18)}
.ls-card:hover::before{transform:scaleX(1)}
@keyframes cardIn{from{opacity:0;transform:translateY(14px)}to{opacity:1;transform:translateY(0)}}
.ls-cb{padding:20px 22px}

/* card header */
.ls-ch{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:13px}
.ls-co-row{display:flex;align-items:center;gap:11px}
.ls-logo{width:46px;height:46px;border-radius:12px;background:var(--surf2);border:1px solid var(--border);display:flex;align-items:center;justify-content:center;font-family:var(--fh);font-size:.82rem;font-weight:800;color:var(--teal-d);flex-shrink:0;overflow:hidden}
.ls-logo img{width:100%;height:100%;object-fit:cover}
.ls-co-name{font-family:var(--fh);font-weight:700;font-size:.92rem;color:var(--ink);line-height:1.3}
.ls-co-ind{font-size:.73rem;color:var(--ink-40);margin-top:2px}

/* intent badge */
.ls-intent{display:inline-flex;align-items:center;gap:5px;padding:4px 10px;border-radius:40px;font-size:.68rem;font-weight:700;white-space:nowrap;flex-shrink:0}
.ls-intent.hi{background:rgba(16,185,129,.1);color:#047857}
.ls-intent.md{background:rgba(245,158,11,.1);color:#b45309}
.ls-intent.lo{background:rgba(107,114,128,.1);color:#4b5563}
.ls-idot{width:6px;height:6px;border-radius:50%;flex-shrink:0}
.hi .ls-idot{background:var(--green)}
.md .ls-idot{background:var(--amber)}
.lo .ls-idot{background:#9ca3af}

/* score bar */
.ls-sbar{margin:9px 0 13px}
.ls-sbar-lbl{display:flex;justify-content:space-between;font-size:.7rem;color:var(--ink-40);margin-bottom:5px}
.ls-sbar-track{height:4px;background:var(--surf3);border-radius:4px;overflow:hidden}
.ls-sbar-fill{height:100%;border-radius:4px;transition:width .6s}

/* meta grid */
.ls-meta{display:grid;grid-template-columns:1fr 1fr;gap:7px;margin-bottom:14px}
.ls-mi{display:flex;align-items:center;gap:7px;font-size:.78rem;color:var(--ink-70)}
.ls-mi i{color:var(--teal);font-size:.77rem;width:13px;text-align:center;flex-shrink:0}
.ls-mi a{color:var(--teal);text-decoration:none}

/* ── CHANNEL AVAILABILITY INDICATORS ── */
.ls-channels{
  display:flex;flex-wrap:wrap;gap:5px;margin:10px 0 14px;
  padding:10px 0;border-top:1px solid var(--border);border-bottom:1px solid var(--border)
}
.ls-ch-pill{
  display:inline-flex;align-items:center;gap:5px;
  padding:4px 9px;border-radius:20px;font-size:.7rem;font-weight:600;
  transition:all .15s
}
/* Available */
.ls-ch-pill.avail{background:rgba(16,185,129,.08);border:1px solid rgba(16,185,129,.2);color:#047857}
/* Not available */
.ls-ch-pill.missing{background:var(--surf3);border:1px solid var(--border);color:var(--ink-40)}
.ls-ch-pill i{font-size:.72rem}

/* contact row */
.ls-cr{display:flex;align-items:center;gap:10px;padding:11px 0;border-top:1px solid var(--border);border-bottom:1px solid var(--border);margin-bottom:13px}
.ls-av{width:34px;height:34px;border-radius:10px;background:var(--surf3);display:flex;align-items:center;justify-content:center;font-family:var(--fh);font-size:.73rem;font-weight:800;color:var(--teal-d);flex-shrink:0}
.ls-cr-name{font-weight:600;font-size:.83rem;color:var(--ink)}
.ls-cr-title{font-size:.73rem;color:var(--ink-40)}
.ls-verified{margin-left:auto;display:flex;align-items:center;gap:3px;font-size:.66rem;font-weight:700;color:var(--teal);background:var(--teal-glow);padding:3px 8px;border-radius:20px}

/* actions */
.ls-acts{display:flex;align-items:center;gap:7px}
.ls-ib{width:34px;height:34px;border-radius:var(--r-sm);border:1px solid var(--border);background:var(--surf2);display:flex;align-items:center;justify-content:center;cursor:pointer;color:var(--ink-40);font-size:.82rem;transition:all .18s}
.ls-ib:hover{border-color:var(--teal);color:var(--teal);background:var(--teal-glow)}
.ls-ib:disabled{opacity:.3;cursor:not-allowed}
.ls-cta{flex:1;background:var(--teal);color:#fff;border:none;border-radius:var(--r-sm);padding:9px;font-family:var(--fh);font-size:.78rem;font-weight:700;cursor:pointer;letter-spacing:.2px;transition:all .18s}
.ls-cta:hover{background:var(--teal-d);transform:translateY(-1px)}

/* LIST VIEW */
.ls-grid.lv .ls-cb{padding:14px 18px;display:grid;grid-template-columns:auto 1fr auto auto;gap:0 20px;align-items:center}
.ls-grid.lv .ls-ch{margin:0;grid-column:1}
.ls-grid.lv .ls-ch .ls-intent{display:none}
.ls-grid.lv .ls-channels{grid-column:1/-1;border:none;padding:6px 0;margin:4px 0}
.ls-grid.lv .ls-meta{grid-template-columns:repeat(4,auto);gap:0 18px;margin:0;grid-column:2}
.ls-grid.lv .ls-sbar,.ls-grid.lv .ls-cr{display:none}
.ls-grid.lv .ls-acts{grid-column:3}
.ls-grid.lv .ls-cta{white-space:nowrap;padding:9px 14px;flex:none}
.ls-grid.lv .ls-li-intent{display:flex!important;grid-column:4}
.ls-li-intent{display:none}

/* ════════════════ PAGINATION ════════════════ */
.ls-pag{display:flex;align-items:center;justify-content:center;gap:5px;margin-top:30px}
.ls-pg{width:35px;height:35px;border-radius:var(--r-sm);border:1px solid var(--border);background:var(--surf);display:flex;align-items:center;justify-content:center;font-size:.82rem;font-weight:600;cursor:pointer;color:var(--ink-70);transition:all .18s}
.ls-pg:hover,.ls-pg.active{background:var(--teal);color:#fff;border-color:var(--teal)}
.ls-pg:disabled{opacity:.35;cursor:default;pointer-events:none}

/* empty */
.ls-empty{background:var(--surf);border-radius:var(--r-lg);border:1px dashed var(--border-m);padding:68px 28px;text-align:center}
.ls-empty-ico{font-size:2.4rem;color:var(--ink-12);margin-bottom:14px}
.ls-empty h5{font-family:var(--fh);font-size:1.05rem;font-weight:700;margin-bottom:6px}
.ls-empty p{color:var(--ink-40);font-size:.88rem}

/* skeleton */
.ls-sk{background:linear-gradient(90deg,var(--surf3) 25%,var(--surf2) 50%,var(--surf3) 75%);background-size:200% 100%;animation:shimmer 1.5s infinite;border-radius:var(--r-sm)}
@keyframes shimmer{0%{background-position:200% 0}100%{background-position:-200% 0}}

/* mobile filter btn */
.ls-mob-btn{display:none;align-items:center;gap:8px;background:var(--teal);color:#fff;border:none;border-radius:var(--r-sm);padding:10px 18px;font-family:var(--fh);font-size:.83rem;font-weight:700;cursor:pointer;margin-bottom:14px}

/* toast */
.ls-toast{position:fixed;bottom:22px;right:22px;z-index:10000;background:var(--ink);color:#fff;padding:11px 18px;border-radius:var(--r-md);font-size:.83rem;font-weight:500;display:flex;align-items:center;gap:9px;transform:translateY(60px);opacity:0;transition:all .32s cubic-bezier(.34,1.56,.64,1);box-shadow:0 8px 28px rgba(0,0,0,.28)}
.ls-toast.show{transform:translateY(0);opacity:1}
.ls-toast i{color:var(--green)}

/* ════════════════ MODAL ════════════════ */
.ls-overlay{position:fixed;inset:0;z-index:9000;background:rgba(11,23,40,.6);backdrop-filter:blur(6px);display:flex;align-items:center;justify-content:center;padding:20px;opacity:0;pointer-events:none;transition:opacity .28s}
.ls-overlay.open{opacity:1;pointer-events:all}
.ls-modal{background:var(--surf);border-radius:var(--r-xl);width:100%;max-width:860px;max-height:92vh;overflow-y:auto;box-shadow:0 32px 80px rgba(0,0,0,.25),0 0 0 1px var(--border);transform:translateY(24px) scale(.97);transition:transform .28s,opacity .28s;opacity:0;position:relative}
.ls-overlay.open .ls-modal{transform:translateY(0) scale(1);opacity:1}
.ls-modal::-webkit-scrollbar{width:4px}
.ls-modal::-webkit-scrollbar-thumb{background:var(--border-m);border-radius:4px}

/* modal banner */
.ls-m-banner{background:var(--ink);padding:28px 32px 24px;border-radius:var(--r-xl) var(--r-xl) 0 0;position:relative;overflow:hidden}
.ls-m-banner::after{content:'';position:absolute;inset:0;pointer-events:none;background:radial-gradient(ellipse 60% 100% at 0% 50%,rgba(0,137,123,.2) 0%,transparent 60%)}
.ls-m-close{position:absolute;top:18px;right:18px;width:32px;height:32px;background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.15);border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;color:#fff;font-size:.85rem;transition:all .18s;z-index:2}
.ls-m-close:hover{background:rgba(255,255,255,.2)}
.ls-m-banner-inner{display:flex;align-items:flex-start;gap:18px;position:relative;z-index:1}
.ls-m-logo{width:64px;height:64px;border-radius:16px;background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.15);display:flex;align-items:center;justify-content:center;font-family:var(--fh);font-size:1.2rem;font-weight:800;color:#fff;flex-shrink:0;overflow:hidden}
.ls-m-logo img{width:100%;height:100%;object-fit:cover}
.ls-m-coname{font-family:var(--fh);font-size:1.4rem;font-weight:800;color:#fff;line-height:1.2}
.ls-m-coind{font-size:.82rem;color:rgba(255,255,255,.5);margin-top:4px}
.ls-m-badges{display:flex;flex-wrap:wrap;gap:7px;margin-top:10px}
.ls-m-badge{display:inline-flex;align-items:center;gap:5px;background:rgba(0,137,123,.25);border:1px solid rgba(0,137,123,.4);color:#4dd0c4;padding:4px 12px;border-radius:40px;font-size:.7rem;font-weight:700}
.ls-m-badge.warn{background:rgba(245,158,11,.15);border-color:rgba(245,158,11,.3);color:var(--amber)}

/* modal body */
.ls-m-body{padding:28px 32px}
.ls-m-2col{display:grid;grid-template-columns:1fr 1fr;gap:24px}
.ls-m-sec{font-family:var(--fh);font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:1px;color:var(--teal);margin-bottom:14px;display:flex;align-items:center;gap:8px}
.ls-m-sec::after{content:'';flex:1;height:1px;background:var(--border)}
.ls-m-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:24px}
.ls-m-item{display:flex;flex-direction:column;gap:3px}
.ls-m-lbl{font-size:.68rem;text-transform:uppercase;letter-spacing:.7px;color:var(--ink-40);font-weight:600}
.ls-m-val{font-size:.88rem;color:var(--ink);font-weight:500;word-break:break-word}
.ls-m-val a{color:var(--teal);text-decoration:none}
.ls-m-val a:hover{text-decoration:underline}

/* modal channel indicators */
.ls-m-channels{display:flex;flex-wrap:wrap;gap:7px;margin-bottom:22px}
.ls-m-ch{display:inline-flex;align-items:center;gap:7px;padding:8px 14px;border-radius:var(--r-md);font-size:.8rem;font-weight:600;border:1px solid;transition:all .15s}
.ls-m-ch.avail{background:rgba(16,185,129,.06);border-color:rgba(16,185,129,.2);color:#047857;cursor:pointer}
.ls-m-ch.avail:hover{background:rgba(16,185,129,.12)}
.ls-m-ch.missing{background:var(--surf2);border-color:var(--border);color:var(--ink-40)}
.ls-m-ch .ch-label{font-size:.72rem}
.ls-m-ch .ch-val{font-size:.78rem;font-weight:700;max-width:200px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}

/* person card in modal */
.ls-m-person{display:flex;align-items:center;gap:14px;background:var(--surf2);border-radius:var(--r-md);border:1px solid var(--border);padding:16px 18px;margin-bottom:16px}
.ls-m-av{width:52px;height:52px;border-radius:14px;background:var(--teal-glow2);display:flex;align-items:center;justify-content:center;font-family:var(--fh);font-size:1rem;font-weight:800;color:var(--teal-d);flex-shrink:0;overflow:hidden}
.ls-m-av img{width:100%;height:100%;object-fit:cover}
.ls-m-pname{font-family:var(--fh);font-size:1rem;font-weight:700;color:var(--ink)}
.ls-m-ptitle{font-size:.8rem;color:var(--ink-70);margin-top:2px}
.ls-m-ptags{display:flex;gap:6px;margin-top:7px;flex-wrap:wrap}
.ls-m-ptag{background:var(--teal-glow);border:1px solid rgba(0,137,123,.15);color:var(--teal-d);padding:3px 10px;border-radius:20px;font-size:.68rem;font-weight:600}
.ls-m-plinks{display:flex;gap:7px;margin-left:auto;flex-shrink:0}
.ls-m-plink{width:34px;height:34px;border-radius:var(--r-sm);background:#fff;border:1px solid var(--border);display:flex;align-items:center;justify-content:center;text-decoration:none;color:var(--ink-70);font-size:.85rem;transition:all .18s}
.ls-m-plink:hover{border-color:var(--teal);color:var(--teal)}
.ls-m-plink.disabled-link{opacity:.3;pointer-events:none}

/* technologies */
.ls-tech-pills{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:22px}
.ls-tech-pill{background:var(--surf3);border:1px solid var(--border);color:var(--ink-70);padding:3px 10px;border-radius:20px;font-size:.7rem;font-weight:500}

/* contact form */
.ls-m-form{background:var(--surf2);border-radius:var(--r-md);border:1px solid var(--border);padding:22px}
.ls-m-form-title{font-family:var(--fh);font-size:.95rem;font-weight:700;margin-bottom:10px;display:flex;align-items:center;gap:8px}
.ls-m-form-title i{color:var(--teal)}
.ls-credit-notice{background:rgba(16,185,129,.07);border:1px solid rgba(16,185,129,.2);border-radius:var(--r-md);padding:10px 14px;margin-bottom:16px;font-size:.8rem;display:flex;align-items:center;gap:9px;color:#047857}
.ls-frow{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:12px}
.ls-frow.full{grid-template-columns:1fr}
.ls-fg{display:flex;flex-direction:column;gap:5px}
.ls-fg label{font-size:.72rem;font-weight:600;color:var(--ink-70);text-transform:uppercase;letter-spacing:.6px}
.ls-fg input,.ls-fg select,.ls-fg textarea{padding:9px 12px;border:1px solid var(--border-m);border-radius:var(--r-sm);font-family:var(--fb);font-size:.85rem;color:var(--ink);outline:none;background:#fff;transition:border-color .2s;width:100%}
.ls-fg input:focus,.ls-fg select:focus,.ls-fg textarea:focus{border-color:var(--teal)}
.ls-fg textarea{resize:vertical;min-height:90px}
.ls-m-actions{display:flex;gap:10px;margin-top:16px}
.ls-m-send{flex:1;background:var(--teal);color:#fff;border:none;border-radius:var(--r-sm);padding:12px;font-family:var(--fh);font-size:.88rem;font-weight:700;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:8px;transition:background .2s}
.ls-m-send:hover{background:var(--teal-d)}
.ls-m-send:disabled{opacity:.6;cursor:not-allowed}
.ls-m-cancel{padding:12px 20px;background:#fff;border:1px solid var(--border-m);border-radius:var(--r-sm);font-family:var(--fb);font-size:.85rem;cursor:pointer;color:var(--ink-70);transition:all .18s}
.ls-m-cancel:hover{border-color:var(--ink-40)}
.ls-m-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:64px 32px;gap:14px}
.ls-spinner{width:36px;height:36px;border:3px solid var(--surf3);border-top-color:var(--teal);border-radius:50%;animation:spin .7s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}

/* credits bar */
.ls-credits-bar-wrap{background:var(--surf2);border:1px solid var(--border);border-radius:var(--r-md);padding:12px 16px;display:flex;align-items:center;gap:14px;font-size:.82rem}
.ls-credits-num{font-family:var(--fh);font-weight:800;font-size:1.1rem;color:var(--teal)}

/* ════════════════ RESPONSIVE ════════════════ */
@media(max-width:1050px){.ls-layout{grid-template-columns:260px 1fr}}
@media(max-width:860px){
  .ls-layout{grid-template-columns:1fr}
  .ls-sidebar{position:static;display:none}
  .ls-sidebar.mob-open{display:block}
  .ls-mob-btn{display:flex}
}
@media(max-width:600px){
  .ls-sbox select,.ls-sdiv{display:none}
  .ls-grid.gv{grid-template-columns:1fr}
  .ls-grid.lv .ls-cb{grid-template-columns:auto 1fr}
  .ls-grid.lv .ls-meta{display:none}
  .ls-grid.lv .ls-acts{grid-column:1/-1}
  .ls-m-2col{grid-template-columns:1fr}
  .ls-m-body{padding:20px}
  .ls-m-banner{padding:20px}
  .ls-frow{grid-template-columns:1fr}
}