/* ============================================================
   BEACON — Component styles
   ============================================================ */

/* ---------- Buttons ---------- */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;
  font-family:var(--font-text);font-weight:600;font-size:14px;line-height:1;
  border:1px solid transparent;border-radius:var(--r-md);cursor:pointer;
  padding:0 16px;height:40px;white-space:nowrap;
  transition:background .15s var(--ease),border-color .15s var(--ease),color .15s var(--ease),box-shadow .15s var(--ease),transform .05s var(--ease);}
.btn:active{transform:translateY(1px);}
.btn svg{width:16px;height:16px;flex:none;}
.btn.sm{height:32px;font-size:13px;padding:0 12px;border-radius:var(--r-sm);}
.btn.lg{height:48px;font-size:15px;padding:0 22px;}
.btn.block{width:100%;}

.btn-primary{background:var(--primary);color:var(--on-primary);box-shadow:0 6px 16px -8px var(--primary);}
.btn-primary:hover{background:var(--primary-hover);}
.btn-primary:active{background:var(--primary-press);}

.btn-secondary{background:transparent;color:var(--text);border-color:var(--border-strong);}
.btn-secondary:hover{border-color:var(--text-secondary);background:var(--surface-raised);}

.btn-ghost{background:transparent;color:var(--link);}
.btn-ghost:hover{background:var(--primary-tint);}

.btn-highlight{background:var(--accent);color:var(--on-accent);box-shadow:0 6px 18px -8px var(--accent);}
.btn-highlight:hover{background:var(--accent-hover);}

.btn-danger{background:var(--danger);color:#fff;}
.btn-danger:hover{filter:brightness(.94);}

.btn:disabled,.btn.is-disabled{opacity:.42;pointer-events:none;box-shadow:none;}
.btn.icon{padding:0;width:40px;}
.btn.icon.sm{width:32px;}

.btn .spin{width:15px;height:15px;border-radius:50%;border:2px solid currentColor;border-top-color:transparent;animation:spin .7s linear infinite;}
@keyframes spin{to{transform:rotate(360deg);}}

.btn-row{display:flex;flex-wrap:wrap;gap:12px;align-items:center;}

/* ---------- Inputs / forms ---------- */
.field{display:flex;flex-direction:column;gap:6px;max-width:340px;}
.field .lab{font-size:13px;font-weight:500;color:var(--text-secondary);}
.field .hint{font-size:12.5px;color:var(--muted);}
.field .err{font-size:12.5px;color:var(--danger-ink);display:flex;align-items:center;gap:5px;}
.field .err svg{width:14px;height:14px;flex:none;}
.input,.select,.textarea{
  font-family:var(--font-text);font-size:14px;color:var(--text);
  background:var(--inset);border:1px solid var(--border);border-radius:var(--r-md);
  padding:0 13px;height:42px;width:100%;transition:border-color .15s var(--ease),box-shadow .15s var(--ease),background .15s var(--ease);}
.textarea{height:auto;padding:11px 13px;min-height:92px;resize:vertical;line-height:1.5;}
.input::placeholder,.textarea::placeholder{color:var(--muted);}
.input:hover,.select:hover,.textarea:hover{border-color:var(--border-strong);}
.input:focus,.select:focus,.textarea:focus{outline:none;border-color:var(--primary);box-shadow:var(--ring);background:var(--surface);}
.field.invalid .input{border-color:var(--danger);box-shadow:0 0 0 4px var(--danger-soft);}
.select{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%2364718A' stroke-width='2.2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center;padding-right:38px;cursor:pointer;}
.input-wrap{position:relative;}
.input-wrap .ic{position:absolute;left:12px;top:50%;transform:translateY(-50%);width:17px;height:17px;color:var(--muted);pointer-events:none;}
.input-wrap .input{padding-left:38px;}

/* checkbox / radio / switch */
.check{display:inline-flex;align-items:center;gap:10px;cursor:pointer;font-size:14px;color:var(--text);user-select:none;}
.check input{position:absolute;opacity:0;width:0;height:0;}
.check .box{width:20px;height:20px;border-radius:6px;border:1.5px solid var(--border-strong);background:var(--inset);display:grid;place-items:center;transition:.15s var(--ease);}
.check .box svg{width:13px;height:13px;color:#fff;opacity:0;transform:scale(.6);transition:.15s var(--ease);}
.check input:checked+.box{background:var(--primary);border-color:var(--primary);}
.check input:checked+.box svg{opacity:1;transform:scale(1);}
.check.radio .box{border-radius:50%;}
.check input:focus-visible+.box{box-shadow:var(--ring);}

.switch{position:relative;display:inline-flex;align-items:center;gap:10px;cursor:pointer;font-size:14px;color:var(--text);user-select:none;}
.switch input{position:absolute;opacity:0;width:0;height:0;}
.switch .track{width:42px;height:24px;border-radius:999px;background:var(--border-strong);position:relative;transition:.18s var(--ease);flex:none;}
.switch .track::after{content:"";position:absolute;top:2px;left:2px;width:20px;height:20px;border-radius:50%;background:#fff;box-shadow:0 1px 3px rgba(0,0,0,.3);transition:.18s var(--ease);}
.switch input:checked+.track{background:var(--primary);}
.switch input:checked+.track::after{transform:translateX(18px);}
.switch input:focus-visible+.track{box-shadow:var(--ring);}

/* ---------- Cards ---------- */
.card{background:var(--surface);border:1px solid var(--border-subtle);border-radius:var(--r-lg);box-shadow:var(--shadow-1);}
.card.pad{padding:22px;}
.card-head{padding:18px 22px;border-bottom:1px solid var(--border-subtle);display:flex;align-items:center;justify-content:space-between;gap:12px;}
.card-body{padding:22px;}
.card-foot{padding:14px 22px;border-top:1px solid var(--border-subtle);display:flex;gap:10px;justify-content:flex-end;}

/* stat tile */
.stat{background:var(--surface);border:1px solid var(--border-subtle);border-radius:var(--r-lg);padding:18px;box-shadow:var(--shadow-1);}
.stat .k{font-family:var(--font-display);font-weight:600;font-size:32px;letter-spacing:-.02em;line-height:1;}
.stat .l{font-size:12.5px;color:var(--muted);margin-top:8px;}
.stat .trend{display:inline-flex;align-items:center;gap:4px;white-space:nowrap;font-family:var(--font-mono);font-size:11.5px;font-weight:600;margin-top:10px;padding:3px 7px;border-radius:6px;}
.trend.up{background:var(--success-soft);color:var(--success-ink);}
.trend.down{background:var(--danger-soft);color:var(--danger-ink);}

/* ---------- Badges / tags / chips ---------- */
.badge{display:inline-flex;align-items:center;gap:5px;white-space:nowrap;font-size:12px;font-weight:600;padding:3px 9px;border-radius:var(--r-pill);background:var(--inset);color:var(--text-secondary);border:1px solid var(--border);}
.badge .dot{width:6px;height:6px;border-radius:50%;background:currentColor;}
.badge.solid{border:none;}
.badge.info{background:var(--info-soft);color:var(--info-ink);border-color:transparent;}
.badge.success{background:var(--success-soft);color:var(--success-ink);border-color:transparent;}
.badge.warning{background:var(--warning-soft);color:var(--warning-ink);border-color:transparent;}
.badge.danger{background:var(--danger-soft);color:var(--danger-ink);border-color:transparent;}
.badge.accent{background:var(--accent);color:var(--on-accent);border-color:transparent;}
.chip{display:inline-flex;align-items:center;gap:7px;font-size:13px;padding:6px 12px;border-radius:var(--r-pill);background:var(--surface-raised);border:1px solid var(--border);color:var(--text);}
.chip .x{width:14px;height:14px;color:var(--muted);cursor:pointer;}
.chip.on{background:var(--primary-tint);border-color:transparent;color:var(--link);font-weight:500;}

/* ---------- Alerts ---------- */
.alert{display:flex;gap:12px;padding:14px 16px;border-radius:var(--r-md);border:1px solid;align-items:flex-start;}
.alert .ai{width:20px;height:20px;flex:none;margin-top:1px;}
.alert .at{font-weight:600;font-size:14px;margin-bottom:2px;}
.alert .ad{font-size:13px;line-height:1.5;color:var(--text-secondary);}
.alert.info{background:var(--info-soft);border-color:transparent;color:var(--info-ink);}
.alert.success{background:var(--success-soft);border-color:transparent;color:var(--success-ink);}
.alert.warning{background:var(--warning-soft);border-color:transparent;color:var(--warning-ink);}
.alert.danger{background:var(--danger-soft);border-color:transparent;color:var(--danger-ink);}
.alert .at,.alert .ad{color:inherit;}
.alert .ad{opacity:.9;}

/* toast */
.toast{display:flex;align-items:center;gap:12px;background:var(--surface-raised);border:1px solid var(--border);border-left:3px solid var(--primary);border-radius:var(--r-md);padding:13px 16px;box-shadow:var(--shadow-2);max-width:360px;}
.toast.success{border-left-color:var(--success);}
.toast .tt{font-size:13.5px;font-weight:500;}
.toast .td{font-size:12.5px;color:var(--muted);}

/* ---------- Tabs ---------- */
.tabs{display:flex;gap:4px;border-bottom:1px solid var(--border);}
.tab{appearance:none;background:none;border:none;font-family:var(--font-text);font-size:14px;font-weight:500;color:var(--muted);padding:11px 14px;cursor:pointer;position:relative;transition:color .15s var(--ease);}
.tab:hover{color:var(--text);}
.tab.on{color:var(--link);}
.tab.on::after{content:"";position:absolute;left:10px;right:10px;bottom:-1px;height:2px;background:var(--primary);border-radius:2px;}

/* ---------- Table ---------- */
.tbl{width:100%;border-collapse:collapse;font-size:13.5px;}
.tbl thead th{font-family:var(--font-display);font-weight:600;font-size:10.5px;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);text-align:left;padding:11px 14px;background:var(--surface-raised);border-bottom:1px solid var(--border);}
.tbl tbody td{padding:13px 14px;border-bottom:1px solid var(--border-subtle);color:var(--text-secondary);}
.tbl tbody tr:hover{background:var(--surface-raised);}
.tbl .num{text-align:right;font-family:var(--font-mono);color:var(--text);}

/* ---------- Top nav (demo) ---------- */
.topnav{display:flex;align-items:center;justify-content:space-between;padding:12px 18px;background:var(--surface);border:1px solid var(--border-subtle);border-radius:var(--r-lg);box-shadow:var(--shadow-1);}
.topnav .nl{display:flex;align-items:center;gap:8px;font-family:var(--font-display);font-weight:600;font-size:16px;}
.topnav .nl img{height:24px;}
.topnav nav{display:flex;gap:4px;}
.topnav nav a{font-size:13.5px;font-weight:500;color:var(--muted);padding:8px 12px;border-radius:var(--r-md);}
.topnav nav a:hover{color:var(--text);background:var(--surface-raised);}
.topnav nav a.on{color:var(--link);background:var(--primary-tint);}

/* ---------- Progress / skeleton ---------- */
.progress{height:8px;border-radius:999px;background:var(--inset);overflow:hidden;}
.progress .bar{height:100%;border-radius:999px;background:var(--primary);}
.skeleton{background:linear-gradient(90deg,var(--inset) 25%,var(--surface-raised) 37%,var(--inset) 63%);background-size:400% 100%;animation:sk 1.4s ease infinite;border-radius:6px;}
@keyframes sk{0%{background-position:100% 0;}100%{background-position:-100% 0;}}

/* ---------- avatar / mono ---------- */
.avatar{width:38px;height:38px;border-radius:var(--r-md);display:grid;place-items:center;font-family:var(--font-display);font-weight:600;font-size:14px;background:var(--primary-tint);color:var(--link);}
.avatar.round{border-radius:50%;}
.avatar-group{display:flex;}
.avatar-group .avatar{border-radius:50%;width:36px;height:36px;border:2px solid var(--surface);margin-left:-10px;background:var(--surface-raised);color:var(--text-secondary);}
.avatar-group .avatar:first-child{margin-left:0;}
.avatar-group .avatar.more{background:var(--primary);color:#fff;}

/* ---------- Breadcrumbs ---------- */
.crumbs{display:flex;align-items:center;gap:7px;font-size:13.5px;flex-wrap:wrap;}
.crumbs a{color:var(--muted);display:inline-flex;align-items:center;gap:7px;}
.crumbs a:hover{color:var(--text);}
.crumbs .sep{color:var(--border-strong);width:15px;height:15px;}
.crumbs .cur{color:var(--text);font-weight:500;}

/* ---------- Dropdown menu ---------- */
.menu{position:relative;display:inline-block;}
.menu-pop{position:absolute;top:calc(100% + 8px);left:0;min-width:212px;background:var(--surface-raised);border:1px solid var(--border);border-radius:var(--r-lg);box-shadow:var(--shadow-3);padding:6px;z-index:20;
  opacity:0;transform:translateY(-6px) scale(.98);transform-origin:top left;pointer-events:none;transition:.16s var(--ease);}
.menu.open .menu-pop{opacity:1;transform:none;pointer-events:auto;}
.menu-pop.right{left:auto;right:0;transform-origin:top right;}
.menu-item{display:flex;align-items:center;gap:10px;width:100%;text-align:left;background:none;border:none;font-family:var(--font-text);font-size:13.5px;color:var(--text);padding:9px 10px;border-radius:var(--r-md);cursor:pointer;}
.menu-item:hover{background:var(--primary-tint);color:var(--link);}
.menu-item svg{width:16px;height:16px;color:var(--muted);flex:none;}
.menu-item:hover svg{color:var(--link);}
.menu-item .kbd{margin-left:auto;font-family:var(--font-mono);font-size:11px;color:var(--muted);}
.menu-item.danger{color:var(--danger-ink);}
.menu-item.danger:hover{background:var(--danger-soft);}
.menu-item.danger svg{color:var(--danger-ink);}
.menu-div{height:1px;background:var(--border-subtle);margin:6px 4px;}
.menu-label{font-family:var(--font-display);font-size:10px;letter-spacing:.12em;text-transform:uppercase;color:var(--muted);padding:8px 10px 4px;}

/* ---------- Modal ---------- */
.scrim{position:fixed;inset:0;background:rgba(8,9,12,.6);backdrop-filter:blur(2px);display:grid;place-items:center;z-index:80;padding:24px;
  opacity:0;pointer-events:none;transition:opacity .2s var(--ease);}
.scrim.open{opacity:1;pointer-events:auto;}
.modal{width:100%;max-width:460px;background:var(--surface);border:1px solid var(--border);border-radius:var(--r-xl);box-shadow:var(--shadow-3);overflow:hidden;
  transform:translateY(14px) scale(.97);transition:transform .22s var(--ease);}
.scrim.open .modal{transform:none;}
.modal-h{display:flex;align-items:flex-start;justify-content:space-between;gap:14px;padding:22px 22px 0;}
.modal-h h3{font-family:var(--font-display);font-weight:600;font-size:19px;letter-spacing:-.01em;}
.modal-h .x{width:30px;height:30px;border-radius:var(--r-md);border:none;background:var(--surface-raised);color:var(--muted);cursor:pointer;display:grid;place-items:center;flex:none;}
.modal-h .x:hover{background:var(--inset);color:var(--text);}
.modal-h .x svg{width:16px;height:16px;}
.modal-b{padding:12px 22px 0;font-size:14px;line-height:1.6;color:var(--text-secondary);}
.modal-f{display:flex;gap:10px;justify-content:flex-end;padding:22px;}

/* ---------- Tooltip ---------- */
.tip{position:relative;display:inline-flex;}
.tip .bubble{position:absolute;bottom:calc(100% + 9px);left:50%;transform:translateX(-50%) translateY(4px);
  background:var(--text);color:var(--canvas);font-size:12px;font-weight:500;padding:6px 10px;border-radius:var(--r-md);white-space:nowrap;
  opacity:0;pointer-events:none;transition:.15s var(--ease);box-shadow:var(--shadow-2);z-index:10;}
.tip .bubble::after{content:"";position:absolute;top:100%;left:50%;transform:translateX(-50%);border:5px solid transparent;border-top-color:var(--text);}
.tip:hover .bubble{opacity:1;transform:translateX(-50%);}

/* ---------- Pagination ---------- */
.pager{display:inline-flex;align-items:center;gap:4px;}
.pager button{min-width:36px;height:36px;padding:0 8px;border-radius:var(--r-md);border:1px solid transparent;background:none;font-family:var(--font-text);font-size:13.5px;color:var(--text-secondary);cursor:pointer;display:inline-flex;align-items:center;justify-content:center;gap:4px;transition:.13s var(--ease);}
.pager button:hover:not(:disabled){background:var(--surface-raised);color:var(--text);}
.pager button.on{background:var(--primary);color:#fff;}
.pager button:disabled{opacity:.4;cursor:default;}
.pager button svg{width:16px;height:16px;}
.pager .gap{color:var(--muted);padding:0 2px;}

/* ---------- Accordion ---------- */
.acc{border:1px solid var(--border-subtle);border-radius:var(--r-lg);overflow:hidden;background:var(--surface);}
.acc-item+.acc-item{border-top:1px solid var(--border-subtle);}
.acc-head{display:flex;align-items:center;justify-content:space-between;gap:12px;width:100%;text-align:left;background:none;border:none;font-family:var(--font-text);font-size:14.5px;font-weight:500;color:var(--text);padding:16px 18px;cursor:pointer;}
.acc-head:hover{background:var(--surface-raised);}
.acc-head .chevd{width:18px;height:18px;color:var(--muted);transition:transform .2s var(--ease);flex:none;}
.acc-item.open .acc-head .chevd{transform:rotate(180deg);color:var(--link);}
.acc-body{max-height:0;overflow:hidden;transition:max-height .26s var(--ease);}
.acc-body .inner{padding:0 18px 16px;font-size:13.5px;line-height:1.6;color:var(--text-secondary);}

/* ---------- Segmented control ---------- */
.segmented{display:inline-flex;background:var(--inset);border:1px solid var(--border);border-radius:var(--r-md);padding:3px;gap:2px;}
.segmented button{appearance:none;border:none;background:none;font-family:var(--font-text);font-size:13px;font-weight:500;color:var(--muted);padding:7px 15px;border-radius:6px;cursor:pointer;transition:.14s var(--ease);}
.segmented button:hover{color:var(--text);}
.segmented button.on{background:var(--surface);color:var(--text);box-shadow:var(--shadow-1);}

/* ---------- Slider ---------- */
.slider{appearance:none;width:100%;max-width:300px;height:6px;border-radius:999px;background:var(--inset);outline:none;cursor:pointer;}
.slider::-webkit-slider-runnable-track{height:6px;border-radius:999px;}
.slider::-webkit-slider-thumb{appearance:none;width:20px;height:20px;border-radius:50%;background:var(--primary);border:3px solid var(--surface);box-shadow:var(--shadow-1);margin-top:-7px;cursor:grab;}
.slider::-moz-range-thumb{width:18px;height:18px;border-radius:50%;background:var(--primary);border:3px solid var(--surface);cursor:grab;}
.slider:focus-visible::-webkit-slider-thumb{box-shadow:var(--ring);}

/* ---------- Empty state ---------- */
.empty{text-align:center;padding:38px 22px;border:1.5px dashed var(--border);border-radius:var(--r-lg);background:var(--surface);}
.empty .ei{width:48px;height:48px;border-radius:var(--r-lg);background:var(--primary-tint);color:var(--link);display:grid;place-items:center;margin:0 auto 14px;}
.empty .ei svg{width:24px;height:24px;}
.empty h4{font-family:var(--font-display);font-weight:600;font-size:16px;margin-bottom:6px;}
.empty p{font-size:13.5px;color:var(--muted);max-width:320px;margin:0 auto 16px;line-height:1.55;}
