#tissu-root{
  --bg:#0b0f14; --text:#eaf0ff; --muted:#9fb0c8; --muted2:#6d7f98;
  --line:rgba(255,255,255,.08); --accent:rgba(92,157,255,.95);
  --good:rgba(108,255,178,.9); --warn:rgba(255,205,92,.95); --bad:rgba(255,92,124,.95);
  --radius:16px; --radius2:12px; --shadow:0 12px 34px rgba(0,0,0,.4); --shadow2:0 8px 20px rgba(0,0,0,.3);
  --mono:ui-monospace,SFMono-Regular,Menlo,Consolas,monospace;
  --sans:ui-sans-serif,system-ui,-apple-system,Segoe UI,Roboto,Helvetica,Arial,sans-serif;
  display:block; background:var(--bg); color:var(--text); font-family:var(--sans);
  min-height:100vh; padding-bottom:calc(96px + env(safe-area-inset-bottom));
}
#tissu-root *{box-sizing:border-box}
#tissu-root .wrap{max-width:1100px; margin:0 auto; padding:14px 14px 30px}
#tissu-root .wrap.calc{max-width:820px}

/* Top bar */
#tissu-root .topbar{position:sticky; top:0; z-index:20; display:flex; align-items:center; justify-content:space-between;
  gap:10px; padding:12px 14px; background:rgba(11,15,20,.94); backdrop-filter:blur(8px); border-bottom:1px solid var(--line); flex-wrap:wrap}
#tissu-root .brand{font-weight:750; letter-spacing:.1em; font-size:14px}
#tissu-root .nav{display:flex; gap:8px}
#tissu-root .nav .btn.active{border-color:rgba(92,157,255,.55); background:linear-gradient(180deg,rgba(92,157,255,.20),rgba(92,157,255,.08))}
#tissu-root .lock{font-size:12px; color:var(--muted2)}

#tissu-root h1,#tissu-root h2{margin:0}

/* Panels */
#tissu-root .panel{border:1px solid var(--line); border-radius:var(--radius);
  background:linear-gradient(180deg,rgba(255,255,255,.045),rgba(255,255,255,.02)); box-shadow:var(--shadow); overflow:hidden; margin-bottom:14px}
#tissu-root .panel .hd{display:flex; align-items:center; justify-content:space-between; padding:13px 14px 11px; border-bottom:1px solid var(--line); background:rgba(255,255,255,.015)}
#tissu-root .panel .hd .h .t{font-size:16px; font-weight:750; letter-spacing:.1em}
#tissu-root .panel .bd{padding:14px}
#tissu-root details.panel{padding:0}
#tissu-root details.panel>summary{list-style:none; cursor:pointer}
#tissu-root details.panel>summary::-webkit-details-marker{display:none}
#tissu-root details.proj .bd{border-top:1px solid var(--line)}

#tissu-root .row{display:grid; grid-template-columns:1fr; gap:10px; margin-bottom:12px}
@media (min-width:560px){#tissu-root .row.cols2{grid-template-columns:1fr 1fr}}

#tissu-root label{display:flex; flex-direction:column; gap:6px; font-size:12px; color:var(--muted)}
#tissu-root input[type=text],#tissu-root input[type=number],#tissu-root input[type=password],#tissu-root select,#tissu-root textarea{
  width:100%; border:1px solid var(--line); border-radius:12px; padding:13px 12px; background:rgba(0,0,0,.2); color:var(--text);
  outline:none; font-size:16px; font-family:var(--sans)}
#tissu-root textarea{min-height:84px; resize:vertical}
#tissu-root input::placeholder,#tissu-root textarea::placeholder{color:rgba(159,176,200,.5)}
#tissu-root input:focus,#tissu-root select:focus,#tissu-root textarea:focus{border-color:rgba(92,157,255,.55); box-shadow:0 0 0 3px rgba(92,157,255,.12)}
#tissu-root .help{font-size:11px; color:var(--muted2); line-height:1.35}
#tissu-root .small{font-size:12px; color:var(--muted); line-height:1.4}

/* Buttons */
#tissu-root .btns{display:flex; gap:10px; flex-wrap:wrap}
#tissu-root .btn{border:1px solid var(--line); background:rgba(255,255,255,.03); color:var(--text); border-radius:12px; padding:11px 13px;
  font-size:13px; font-weight:650; cursor:pointer; box-shadow:var(--shadow2); display:inline-flex; align-items:center; gap:8px; user-select:none; text-decoration:none; font-family:var(--sans)}
#tissu-root .btn:active{transform:translateY(1px)}
#tissu-root .btn.primary{border-color:rgba(92,157,255,.45); background:linear-gradient(180deg,rgba(92,157,255,.22),rgba(92,157,255,.08))}
#tissu-root .btn.danger{border-color:rgba(255,92,124,.38); background:linear-gradient(180deg,rgba(255,92,124,.16),rgba(255,92,124,.05))}
#tissu-root .btn.ghost{background:transparent; box-shadow:none}
#tissu-root .btn[disabled]{opacity:.4; cursor:not-allowed}

/* Segmented product control */
#tissu-root .seg{display:flex; gap:8px; margin-bottom:14px}
#tissu-root .segbtn{flex:1; padding:15px 12px; border:1px solid var(--line); border-radius:14px; background:rgba(255,255,255,.03);
  color:var(--muted); font-size:15px; font-weight:700; letter-spacing:.02em; cursor:pointer; font-family:var(--sans)}
#tissu-root .segbtn.active{color:var(--text); border-color:rgba(92,157,255,.6); background:linear-gradient(180deg,rgba(92,157,255,.24),rgba(92,157,255,.09)); box-shadow:0 0 0 1px rgba(92,157,255,.16) inset}

/* KPI */
#tissu-root .kpi{display:grid; grid-template-columns:1fr 1fr 1fr; gap:10px}
#tissu-root .k{border:1px solid var(--line); background:rgba(255,255,255,.02); border-radius:var(--radius2); padding:11px; display:flex; flex-direction:column; gap:3px}
#tissu-root .k .l{font-size:11px; color:var(--muted)}
#tissu-root .k .v{font-size:18px; font-weight:720}
@media (max-width:420px){#tissu-root .k .v{font-size:15px}}

/* Badges / dots */
#tissu-root .badge{display:inline-flex; align-items:center; gap:6px; border:1px solid var(--line); background:rgba(255,255,255,.03); border-radius:999px; padding:5px 9px; font-size:11px; color:var(--muted); white-space:nowrap}
#tissu-root .dot{width:8px; height:8px; border-radius:999px; background:rgba(255,255,255,.35)}
#tissu-root .dot.good{background:var(--good)} #tissu-root .dot.warn{background:var(--warn)} #tissu-root .dot.bad{background:var(--bad)}

/* Window sets */
#tissu-root .set{border:1px solid var(--line); background:rgba(0,0,0,.14); border-radius:var(--radius); overflow:hidden; margin-bottom:12px}
#tissu-root .set .top{display:flex; align-items:flex-start; justify-content:space-between; gap:10px; padding:12px; border-bottom:1px solid var(--line); background:rgba(255,255,255,.02); flex-wrap:wrap}
#tissu-root .set .top .left{display:flex; flex-direction:column; gap:5px}
#tissu-root .set .top .left .name{font-size:13px; font-weight:700}
#tissu-root .set .top .left .meta{display:flex; flex-wrap:wrap; gap:8px}
#tissu-root .set .top .right{display:flex; gap:8px; align-items:center; flex-wrap:wrap; justify-content:flex-end}
#tissu-root .set .mid{padding:12px}
#tissu-root .price{font-size:17px; font-weight:800}

#tissu-root .inline{display:flex; align-items:center; gap:10px; flex-wrap:wrap}
#tissu-root .chk{display:inline-flex; align-items:center; gap:9px; padding:11px 12px; border:1px solid var(--line); border-radius:12px; background:rgba(0,0,0,.16)}
#tissu-root .chk input{transform:scale(1.2)}
#tissu-root .chk span{font-size:13px; font-weight:600}

#tissu-root .switch{position:relative; display:inline-block; width:46px; height:26px}
#tissu-root .switch input{opacity:0; width:0; height:0}
#tissu-root .slider{position:absolute; cursor:pointer; inset:0; background:rgba(255,255,255,.06); border:1px solid var(--line); transition:.2s; border-radius:999px}
#tissu-root .slider:before{position:absolute; content:""; height:20px; width:20px; left:3px; top:3px; background:rgba(234,240,255,.92); transition:.2s; border-radius:999px}
#tissu-root .switch input:checked + .slider{background:rgba(92,157,255,.25); border-color:rgba(92,157,255,.45)}
#tissu-root .switch input:checked + .slider:before{transform:translateX(20px)}

#tissu-root details:not(.panel){border:1px solid var(--line); border-radius:var(--radius2); background:rgba(255,255,255,.02); padding:10px 12px}
#tissu-root details:not(.panel) summary{cursor:pointer; list-style:none; display:flex; align-items:center; justify-content:space-between; gap:10px; font-size:13px; font-weight:650}
#tissu-root details summary::-webkit-details-marker{display:none}
#tissu-root details .inside{padding-top:10px}
#tissu-root details.detailsHero{border:none; background:transparent; padding:0}
#tissu-root details.detailsHero summary{border:1px solid var(--line); border-radius:var(--radius2); background:rgba(255,255,255,.02); padding:10px 12px}
#tissu-root details.detailsHero .inside{padding:12px 4px 0}

#tissu-root .hr{height:1px; background:var(--line); margin:12px 0}
#tissu-root .mono{font-family:var(--mono); font-size:12px; color:rgba(234,240,255,.92); white-space:pre-wrap; word-break:break-word}
#tissu-root .mono b{font-weight:800} #tissu-root .mono .line{margin:0 0 6px} #tissu-root .mono .item{margin:0 0 10px} #tissu-root .mono .indent{margin-left:16px}

#tissu-root .quoteGroup{border:1px solid var(--line); border-radius:var(--radius); background:rgba(0,0,0,.14); overflow:hidden; margin-bottom:12px}
#tissu-root .quoteGroup .gh{padding:12px; border-bottom:1px solid var(--line); display:flex; align-items:center; justify-content:space-between; gap:10px; background:rgba(255,255,255,.02)}
#tissu-root .quoteGroup .gh .t{font-size:13px; font-weight:700}
#tissu-root .quoteGroup .gh .m{color:var(--muted); font-size:12px}
#tissu-root .qItem{padding:12px; border-top:1px solid var(--line)}
#tissu-root .qItem:first-child{border-top:none}
#tissu-root .qTop{display:flex; align-items:flex-start; justify-content:space-between; gap:10px; flex-wrap:wrap}
#tissu-root .qTop .a{display:flex; flex-direction:column; gap:6px; min-width:220px; flex:1}
#tissu-root .qTop .a .p{font-weight:700; font-size:13px}
#tissu-root .qTop .a .c{color:var(--muted); font-size:12px; line-height:1.35}
#tissu-root .qTop .b{display:flex; align-items:center; gap:10px; flex-wrap:wrap; justify-content:flex-end}

/* Sticky total bar */
#tissu-root .bar{position:fixed; left:0; right:0; bottom:0; z-index:30; display:flex; align-items:center; justify-content:space-between; gap:12px;
  padding:12px 16px calc(12px + env(safe-area-inset-bottom)); background:rgba(12,17,24,.97); backdrop-filter:blur(10px); border-top:1px solid var(--line)}
#tissu-root .bartotal{display:flex; flex-direction:column; line-height:1.1}
#tissu-root .bartotal .l{font-size:11px; color:var(--muted)}
#tissu-root .bartotal .v{font-size:22px; font-weight:800}
#tissu-root .baract{display:flex; gap:10px}
#tissu-root .baract .btn{padding:13px 16px; font-size:14px}

/* Projects list */
#tissu-root .filters{display:flex; gap:10px; flex-wrap:wrap; margin-bottom:14px}
#tissu-root .filters label{flex:1; min-width:150px}
#tissu-root .tbl{width:100%; border-collapse:collapse; font-size:13px}
#tissu-root .tbl th{text-align:left; font-size:11px; text-transform:uppercase; letter-spacing:.06em; color:var(--muted2); padding:10px; border-bottom:1px solid var(--line); cursor:pointer; white-space:nowrap}
#tissu-root .tbl td{padding:12px 10px; border-bottom:1px solid var(--line); vertical-align:middle}
#tissu-root .tbl tbody tr{cursor:pointer}
#tissu-root .tbl tbody tr:hover td{background:rgba(255,255,255,.02)}
#tissu-root .tbl .name{font-weight:700; color:var(--text)}
#tissu-root .rowact{text-align:right}
#tissu-root .pill-st{display:inline-flex; align-items:center; padding:5px 10px; border-radius:999px; font-size:11px; border:1px solid var(--line); background:rgba(255,255,255,.03); cursor:pointer; white-space:nowrap}
#tissu-root .st-nepradeta{color:var(--muted)}
#tissu-root .st-gaminama{color:var(--warn); border-color:rgba(255,205,92,.3)}
#tissu-root .st-baigta{color:var(--good); border-color:rgba(108,255,178,.3)}
#tissu-root .st-neapmoketa{color:var(--bad); border-color:rgba(255,92,124,.3)}
#tissu-root .st-apmoketa{color:var(--good); border-color:rgba(108,255,178,.3)}

/* Mobile: table -> stacked cards */
@media (max-width:720px){
  #tissu-root .tbl thead{position:absolute; width:1px; height:1px; overflow:hidden; clip:rect(0 0 0 0)}
  #tissu-root .tbl,#tissu-root .tbl tbody,#tissu-root .tbl tr,#tissu-root .tbl td{display:block; width:100%}
  #tissu-root .tbl tr{border:1px solid var(--line); border-radius:var(--radius2); background:rgba(0,0,0,.14); margin-bottom:10px; padding:6px 4px; position:relative}
  #tissu-root .tbl td{border:none; padding:8px 12px; display:flex; justify-content:space-between; align-items:center; gap:12px}
  #tissu-root .tbl td:before{content:attr(data-label); color:var(--muted2); font-size:11px; text-transform:uppercase; letter-spacing:.06em}
  #tissu-root .tbl td.name{font-size:15px; padding-top:10px}
  #tissu-root .tbl td.name:before{content:""}
  #tissu-root .rowact{position:absolute; top:8px; right:8px; padding:0}
  #tissu-root .rowact:before{content:""}
}

/* Lock page */
#tissu-root .toast{position:fixed; left:50%; transform:translateX(-50%); bottom:96px; background:rgba(10,14,20,.95); border:1px solid var(--line); border-radius:999px; padding:10px 16px; color:var(--text); font-size:13px; display:none; z-index:99999}
.lockpage{min-height:100vh; display:flex; align-items:center; justify-content:center; padding:20px;
  background:#0b0f14; color:#eaf0ff; font-family:ui-sans-serif,system-ui,-apple-system,Segoe UI,Roboto,sans-serif}
.lockbox{width:100%; max-width:340px; text-align:center}
.lockbrand{font-weight:750; letter-spacing:.12em; font-size:15px; margin-bottom:20px; color:#9fb0c8}
.lockform{display:flex; flex-direction:column; gap:12px}
.lockform input{border:1px solid rgba(255,255,255,.1); border-radius:12px; padding:14px; background:rgba(0,0,0,.25); color:#eaf0ff; font-size:16px; outline:none}
.lockform input:focus{border-color:rgba(92,157,255,.55); box-shadow:0 0 0 3px rgba(92,157,255,.12)}
.lockform button{border:1px solid rgba(92,157,255,.45); border-radius:12px; padding:14px; background:linear-gradient(180deg,rgba(92,157,255,.24),rgba(92,157,255,.09)); color:#eaf0ff; font-size:15px; font-weight:700; cursor:pointer}
.lockerr{color:#ff5c7c; font-size:13px}
