 body.py-page{font-family:system-ui;margin:0;background:#0b1020;color:#e8ecff}.pyapp code,.pyapp pre{background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.08);border-radius:12px}.pyapp pre{padding:12px;overflow:auto}.pyapp a{color:#7aa2ff}.pyapp{max-width:1200px;margin:0 auto;padding:18px 16px;line-height:1.6 --panel:#111831;--panel2:#0f1630;--muted:#9aa7d6;--accent:#7aa2ff;--ok:#57f287;--danger:#ff5d7a;--stroke:rgba(255,255,255,.10);--shadow:0 10px 30px rgba(0,0,0,.35);--radius:16px;}.pyapp header{display:flex;gap:12px;flex-wrap:wrap;align-items:center;justify-content:space-between;margin-bottom:14px;}.pyapp .brand{display:flex;gap:10px;align-items:center}.pyapp .logo{width:38px;height:38px;border-radius:12px;background:linear-gradient(135deg,rgba(122,162,255,.25),rgba(87,242,135,.18));border:1px solid var(--stroke);display:grid;place-items:center;box-shadow:var(--shadow);}.pyapp .title{line-height:1.1}.pyapp .title h1{font-size:18px;margin:0}.pyapp .title .sub{font-size:12px;color:var(--muted)}.pyapp .toolbar{display:flex;gap:8px;flex-wrap:wrap;align-items:center}.pyapp button,.pyapp select{background:rgba(255,255,255,.06);color:var(--text,#e8ecff);border:1px solid var(--stroke);padding:10px 12px;border-radius:12px;cursor:pointer;transition:transform .12s ease,border-color .12s ease,background .12s ease;font-weight:600;}.pyapp button:hover,.pyapp select:hover{transform:translateY(-1px);border-color:rgba(122,162,255,.55)}.pyapp select option{color:#0b1020;background:#ffffff}.pyapp details.inline{margin-top:10px;border:1px solid rgba(255,255,255,.08);border-radius:12px;background:rgba(255,255,255,.04)}.pyapp details.inline>summary{cursor:pointer;list-style:none;padding:10px 12px;font-weight:800;color:#e8ecff}.pyapp details.inline>summary::-webkit-details-marker{display:none}.pyapp details.inline>summary::after{content:"▾";float:right;opacity:.75}.pyapp details.inline[open]>summary::after{content:"▴"}.pyapp details.inline .inner{padding:10px 12px;border-top:1px solid rgba(255,255,255,.08);color:var(--muted);font-size:12px}.pyapp .stdinArea{width:100%;height:96px;resize:vertical;flex:unset;padding:12px;border-radius:12px;border:1px solid rgba(255,255,255,.10);background:rgba(255,255,255,.03);color:#e8ecff;font-family:ui-monospace,Consolas,monospace;font-size:13px;line-height:1.45}.pyapp details.docsCard{margin-top:14px;min-height:auto}.pyapp details.docsCard>summary.cardhead{cursor:pointer;list-style:none}.pyapp details.docsCard>summary.cardhead::-webkit-details-marker{display:none}.pyapp .docsBody{padding:12px}.pyapp .docsBody h3{margin:10px 0 6px;font-size:14px}.pyapp .docsBody ul{margin:6px 0 10px 18px;color:#cfd6ff}.pyapp .docsBody p{margin:6px 0;color:#cfd6ff}.pyapp .docsBody code{padding:2px 6px}.pyapp button:active{transform:translateY(0px)}.pyapp button.primary{background:rgba(122,162,255,.16);border-color:rgba(122,162,255,.55)}.pyapp button.ghost{background:transparent}.pyapp button.danger{background:rgba(255,93,122,.14);border-color:rgba(255,93,122,.55)}.pyapp .chip{font-size:12px;color:var(--muted);padding:8px 10px;border-radius:999px;border:1px solid var(--stroke);background:rgba(255,255,255,.04)}.pyapp .grid{display:grid;grid-template-columns:1.05fr .95fr;gap:14px;align-items:stretch;}.pyapp .card{background:linear-gradient(180deg,rgba(255,255,255,.06),rgba(255,255,255,.03));border:1px solid var(--stroke);border-radius:var(--radius);box-shadow:var(--shadow);overflow:hidden;min-height:520px;display:flex;flex-direction:column;}.pyapp .cardhead{display:flex;align-items:center;justify-content:space-between;padding:10px 12px;background:rgba(17,24,49,.65);border-bottom:1px solid rgba(255,255,255,.08);}.pyapp .cardhead .label{font-weight:800;font-size:13px;letter-spacing:.2px}.pyapp .cardhead .hint{font-size:12px;color:var(--muted)}.pyapp .editorwrap{position:relative;flex:1;display:flex;flex-direction:column}.pyapp textarea{width:100%;flex:1;resize:none;padding:14px 14px 16px;border:0;outline:none;color:#e8ecff;background:transparent;font-family:ui-monospace,SFMono-Regular,Menlo,Consolas,"Liberation Mono",monospace;font-size:14px;line-height:1.5;tab-size:2;}.pyapp .footnote{padding:10px 12px;color:var(--muted);font-size:12px;border-top:1px solid rgba(255,255,255,.08);background:rgba(17,24,49,.35)}.pyapp .tabs{display:flex;gap:8px;flex-wrap:wrap;align-items:center}.pyapp .tab{padding:8px 10px;border-radius:999px;border:1px solid var(--stroke);background:rgba(255,255,255,.04);cursor:pointer;font-weight:700;font-size:12px;color:#e8ecff}.pyapp .tab[aria-selected="true"]{background:rgba(122,162,255,.16);border-color:rgba(122,162,255,.55)}.pyapp .pane{display:none;flex:1;min-height:0}.pyapp .pane.active{display:block}.pyapp #py-console{padding:12px;white-space:pre-wrap;word-break:break-word;overflow:auto;height:100%;margin:0;border:0;background:transparent;font-family:ui-monospace,SFMono-Regular,Menlo,Consolas,"Liberation Mono",monospace;font-size:13px;line-height:1.45;}.pyapp .msg{padding:12px;border-top:1px solid rgba(255,255,255,.08);background:rgba(17,24,49,.35);display:flex;gap:10px;align-items:flex-start;}.pyapp .dot{width:10px;height:10px;border-radius:999px;margin-top:4px;background:rgba(154,167,214,.8)}.pyapp .dot.ok{background:rgba(87,242,135,.9)}.pyapp .dot.bad{background:rgba(255,93,122,.95)}.pyapp .msg .text{font-size:12px;color:var(--muted)}.pyapp .msg .text b{color:#e8ecff}.pyapp #previewWrap{height:100%;padding:12px;overflow:auto}.pyapp #previewFrame{width:100%;height:380px;border:1px solid rgba(255,255,255,.10);border-radius:14px;background:#fff;}.pyapp #previewImage{width:100%;display:none;border:1px solid rgba(255,255,255,.10);border-radius:14px;background:rgba(255,255,255,.02);}.pyapp .err{color:#ffd2da}@media (max-width:960px){.pyapp .grid{grid-template-columns:1fr;}.pyapp .card{min-height:420px}.pyapp #previewFrame{height:320px}}