@import"https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700&display=swap";:root{--ds-primary: #1D9ED5;--ds-primary-soft: rgba(29, 158, 213, .12);--ds-primary-hover: rgba(29, 158, 213, .22);--ds-accent: #20E39A;--ds-accent-soft: rgba(32, 227, 154, .12);--ds-accent-hover: rgba(32, 227, 154, .2);--ds-bg: #C2DFF0;--ds-input-bg: #DAEDF5;--ds-surface: rgba(255, 255, 255, .9);--ds-surface-strong: rgba(255, 255, 255, .96);--ds-text: #2C3E50;--ds-text-light: #FFFFFF;--ds-muted: #7A8BA0;--ds-border: rgba(29, 158, 213, .2);--ds-border-strong: rgba(29, 158, 213, .35);--ds-success: #059669;--ds-success-soft: rgba(5, 150, 105, .1);--ds-success-border: rgba(5, 150, 105, .25);--ds-warning: #F59E0B;--ds-warning-soft: rgba(245, 158, 11, .1);--ds-warning-border: rgba(245, 158, 11, .25);--ds-warning-text: #B45309;--ds-error: #EF4444;--ds-error-soft: rgba(239, 68, 68, .1);--ds-error-border: rgba(239, 68, 68, .25);--ds-error-text: #DC2626;--ds-info: #1D9ED5;--ds-info-soft: rgba(29, 158, 213, .1);--ds-info-border: rgba(29, 158, 213, .25);--sp-1: 4px;--sp-2: 8px;--sp-3: 12px;--sp-4: 16px;--sp-5: 20px;--sp-6: 24px;--sp-8: 32px;--sp-10: 40px;--sp-12: 48px;--fs-2xs: 10px;--fs-xs: 11px;--fs-sm: 13px;--fs-base: 15px;--fs-md: 17px;--fs-lg: 22px;--fs-xl: 28px;--fw-normal: 400;--fw-medium: 500;--fw-semi: 600;--fw-bold: 700;--r-sm: 8px;--r-md: 14px;--r-lg: 18px;--r-full: 999px;--sh-soft: 0 1px 3px rgba(26, 31, 46, .05);--sh-card: 0 2px 8px rgba(26, 31, 46, .08);--sh-elevated: 0 4px 16px rgba(26, 31, 46, .12);--z-base: 1;--z-sticky: 100;--z-dropdown: 200;--z-modal: 1000;--z-toast: 2000;--z-nav: 9999;--ease-default: .15s ease;--ease-smooth: .25s ease;--ease-spring: .2s cubic-bezier(.34, 1.56, .64, 1)}:root{--color-primary: #1D9ED5;--color-accent: #20E39A;--color-highlight: #A7F3FD;--color-bg: #C2DFF0;--color-primary-light: rgba(29, 158, 213, .22);--color-primary-lighter: rgba(29, 158, 213, .12);--color-accent-light: rgba(32, 227, 154, .2);--color-accent-lighter: rgba(32, 227, 154, .12);--color-highlight-light: rgba(167, 243, 253, .15);--color-text-dark: #1A1F2E;--color-text-light: #FFFFFF;--text: #2C3E50;--muted: #7A8BA0;--light: #B0D4E8;--surface: rgba(29, 158, 213, .12);--card: rgba(255, 255, 255, .95);--card-strong: rgba(255, 255, 255, 1);--border: rgba(29, 158, 213, .35);--shadow: 0 2px 8px rgba(26, 31, 46, .1);--shadow-soft: 0 1px 3px rgba(26, 31, 46, .05);--glow: 0 0 0 3px rgba(32, 227, 154, .15);--gradient: rgba(29, 158, 213, .12);--gradient-strong: linear-gradient(135deg, #1D9ED5, #20E39A);--outline: 1px solid rgba(29, 158, 213, .3);--blue: #1D9ED5;--green: #20E39A;--bg: #C2DFF0;--safe-area-top: env(safe-area-inset-top, 0px);--safe-area-right: env(safe-area-inset-right, 0px);--safe-area-bottom: env(safe-area-inset-bottom, 0px);--safe-area-left: env(safe-area-inset-left, 0px)}*{box-sizing:border-box}body{margin:0;padding:0;font-family:Inter,system-ui,-apple-system,SF Pro Display,Segoe UI,sans-serif;background:var(--color-bg);color:var(--text);min-height:100vh;min-height:100dvh;padding-bottom:var(--safe-area-bottom)}#app{max-width:1120px;margin:0 auto;padding:calc(8px + var(--safe-area-top)) 18px calc(120px + var(--safe-area-bottom))}h1{font-size:30px;margin:8px 0;letter-spacing:-.02em;font-weight:600}h2{font-size:18px;margin:12px 0 8px;letter-spacing:-.01em;font-weight:600}p{line-height:1.6}.screen{display:none}.screen.active{display:block;animation:fadeIn .26s ease;padding-bottom:calc(80px + var(--safe-area-bottom))}button{background:var(--gradient-strong);color:var(--color-text-dark);border:none;padding:12px 18px;border-radius:999px;cursor:pointer;font-weight:600;letter-spacing:-.01em;box-shadow:var(--glow);transition:transform .12s ease,box-shadow .16s ease,opacity .16s ease}button.small{padding:10px 14px;font-size:13px}button.secondary{background:transparent;color:var(--color-primary);border:1.5px solid rgba(29,158,213,.6);box-shadow:none}button.ghost{background:transparent;color:var(--text);border:1px solid rgba(122,139,160,.24);box-shadow:none}button.link{background:transparent;color:var(--color-primary);border:1px solid rgba(29,158,213,.25);box-shadow:none}button:hover{transform:translateY(-1px) scale(1.01);box-shadow:0 8px 20px #1d9ed533}button:active{transform:translateY(0);box-shadow:inset 0 1px 3px #1a1f2e26}input,select,textarea{width:100%;padding:12px 14px;border-radius:14px;border:1px solid rgba(122,139,160,.28);background:#1d9ed508;color:var(--text);margin:8px 0;outline:none;transition:border-color .12s ease,box-shadow .16s ease,background .16s ease}input[type=checkbox],input[type=radio]{width:auto;margin:0;padding:0;border-radius:0;border:revert;background:revert;flex-shrink:0}input:focus,select:focus,textarea:focus{border-color:#1d9ed5cc;background:#1d9ed514;box-shadow:0 0 0 3px #1d9ed526}label{display:block;font-size:13px;color:var(--muted);margin-top:4px;margin-bottom:4px;letter-spacing:-.01em}#notif-toggles{display:flex;flex-direction:column;gap:10px;margin-left:28px}#notif-toggles label{display:flex;align-items:center;gap:10px;cursor:pointer;margin:0;font-size:14px;color:var(--text)}#notif-toggles label span{white-space:nowrap}.card{background:#ffffffd9;border:var(--outline);border-radius:18px;padding:18px;margin:12px 0;box-shadow:var(--shadow);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.card.strong{background:#ffffffeb;box-shadow:var(--shadow-soft)}.row{display:flex;gap:10px;align-items:center;flex-wrap:wrap}.muted{color:var(--muted);font-size:14px}.pill{display:inline-flex;align-items:center;gap:6px;padding:7px 12px;border-radius:999px;background:#1d9ed524;color:var(--color-primary);font-size:13px;border:1px solid rgba(29,158,213,.3)}.pill.green{background:#20e39a1f;border-color:#20e39a59;color:#0d8f5e}.pill.blue{background:#1d9ed51f;border-color:#1d9ed559;color:#0f6fa0}.pill.ghost{background:#1d9ed50d;border-color:#1d9ed526;color:var(--text)}.msg{background:#ffffff0a;border:1px solid rgba(148,163,184,.2);border-radius:14px;padding:12px;margin:8px 0}.thumb{max-width:140px;border-radius:12px;margin-top:6px}#map{height:500px;border-radius:18px;border:1.5px solid rgba(29,158,213,.35);background:#1d9ed51f,radial-gradient(circle at 25% 25%,rgba(255,255,255,.1),transparent 40%),var(--color-bg);position:relative;overflow:hidden;box-shadow:inset 0 1px #1d9ed51f,var(--shadow)}#map canvas{display:block;width:100%;height:100%;border-radius:18px}#map .leaflet-container{border-radius:18px;background:var(--color-bg)}.leaflet-boat-marker{background:transparent!important;border:none!important;pointer-events:auto!important}.leaflet-popup-content-wrapper{background:#daedf5fa!important;border-radius:8px!important;border:1px solid rgba(29,158,213,.25)!important;color:var(--text)!important}.leaflet-popup-content{color:var(--text)!important;font-size:12px!important}.leaflet-popup-tip{background:#daedf5fa!important;border:1px solid rgba(29,158,213,.25)!important}.map-controls{position:absolute;top:12px;right:12px;display:flex;gap:6px;z-index:10}.map-controls button{padding:8px 12px;font-size:12px;background:#1d9ed526;border:1px solid rgba(29,158,213,.35);color:var(--color-primary);border-radius:8px;cursor:pointer;transition:background .2s,border-color .2s}.map-controls button:hover{background:#1d9ed540;border-color:#1d9ed580}.map-status{position:absolute;bottom:12px;left:12px;font-size:11px;color:var(--text);background:#daedf5d9;padding:6px 10px;border-radius:6px;z-index:10}.map-legend{display:flex;gap:8px;margin-top:10px;flex-wrap:wrap}.map-legend .pill{background:#1d9ed514;border-color:#1d9ed540}.boat{position:absolute;width:56px;height:56px;border-radius:18px;display:flex;align-items:center;justify-content:center;color:var(--color-text-dark);font-weight:700;box-shadow:var(--shadow);border:1.5px solid rgba(29,158,213,.65);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);cursor:pointer;transition:transform .14s ease,box-shadow .16s ease,border-color .16s ease}.boat.ok{background:#1d9ed5d9}.boat.busy{background:linear-gradient(145deg,#ff6b6bf2,#ffa366e6);color:var(--color-text-dark)}.boat:hover{transform:translateY(-3px) scale(1.02);box-shadow:0 12px 24px #1d9ed540;border-color:#1d9ed5d9}.hero{background:#ffffffbf;border:1px solid rgba(29,158,213,.35);border-radius:18px;padding:22px;box-shadow:var(--shadow)}@media (min-width: 768px){.hero-logo{width:280px!important}}@media (min-width: 1200px){.hero-logo{width:320px!important}}.section-title{display:flex;align-items:center;gap:8px;font-size:16px;color:var(--color-primary);margin-top:20px}.badge-set{display:flex;gap:8px;flex-wrap:wrap}.badge-set .pill{background:#20e39a24;border-color:#20e39a59}.bottom-nav{position:fixed;top:calc(56px + var(--safe-area-top));right:calc(14px + var(--safe-area-right));z-index:9000;background:#daedf5f7;border:1px solid rgba(29,158,213,.4);border-radius:16px;padding:8px;display:flex;flex-direction:column;gap:4px;-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);box-shadow:0 8px 32px #1a1f2e2e;min-width:180px;animation:menuPopIn .15s ease}@keyframes menuPopIn{0%{opacity:0;transform:translateY(-8px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}.bottom-nav.hidden{display:none}.bottom-nav button{width:100%;background:transparent;color:var(--text);border:1px solid rgba(29,158,213,.2);box-shadow:none;padding:12px 16px;text-align:left;border-radius:12px;font-size:.95em}.bottom-nav button:hover{background:#1d9ed51a}.bottom-nav button.active{background:#1d9ed526;box-shadow:0 0 8px #1d9ed540;border-color:#1d9ed566}.nav-toggle{position:fixed;top:calc(14px + var(--safe-area-top));right:calc(14px + var(--safe-area-right));z-index:9999;background:#1d9ed5eb;color:#fff;border:1px solid rgba(29,158,213,.65);border-radius:999px;padding:10px 14px;box-shadow:var(--shadow);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);cursor:pointer;font-weight:700;letter-spacing:-.01em}.nav-toggle:hover{transform:translateY(-1px);box-shadow:0 10px 24px #1d9ed559}.layout-split{display:grid;grid-template-columns:1fr;gap:16px}@media (min-width: 900px){.layout-split{grid-template-columns:1.2fr .9fr}}.fade-card{position:relative;overflow:hidden}.fade-card:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:transparent;pointer-events:none}.list-stack{display:flex;flex-direction:column;gap:10px}.list-row{display:flex;justify-content:space-between;gap:12px;align-items:flex-start;padding:12px 0;border-bottom:1px solid rgba(122,139,160,.12)}.list-row:last-child{border-bottom:none}.stat-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:12px;margin-top:10px}.stat{padding:14px;border-radius:14px;border:1px solid rgba(29,158,213,.25);background:#ffffffb3;box-shadow:inset 0 1px #ffffff80}.stat .label{font-size:12px;color:var(--muted);letter-spacing:-.01em}.stat .value{font-size:22px;font-weight:700;letter-spacing:-.02em}.divider{height:1px;background:#7a8ba02e;margin:10px 0}.chip-row{display:flex;flex-wrap:wrap;gap:8px}.ghost-tile{padding:12px 14px;border-radius:14px;border:1px dashed rgba(29,158,213,.25);color:var(--text);background:#ffffff80}.ghost-tile.warning{border-color:#f9731680;background:#f973161a;color:#ea580c}.warning{color:#ea580c}.pill.warning{background:#f973161f;border-color:#f9731659;color:#ea580c}.trip-stepper{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;background:#ffffffb3;border-radius:16px;border:1px solid var(--border)}.trip-step{display:flex;flex-direction:column;align-items:center;gap:4px}.trip-step__dot{width:36px;height:36px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:16px;border:2px solid rgba(122,139,160,.25);background:#7a8ba00f;color:var(--muted);transition:all .3s ease}.trip-step--done .trip-step__dot{border-color:#20e39a;background:#20e39a1f;color:#059669}.trip-step--active .trip-step__dot{border-color:var(--color-primary);background:#1d9ed51f;color:var(--color-primary);box-shadow:0 0 0 4px #1d9ed526;animation:stepPulse 2s infinite}.trip-step__label{font-size:10px;font-weight:600;color:var(--muted);white-space:nowrap;transition:color .3s ease}.trip-step--done .trip-step__label{color:#059669}.trip-step--active .trip-step__label{color:var(--color-primary)}.trip-step__line{width:24px;height:2px;background:#7a8ba033;flex-shrink:0;margin:0 2px 18px}.trip-step__line--done{background:#20e39a}@keyframes stepPulse{0%,to{box-shadow:0 0 0 4px #1d9ed526}50%{box-shadow:0 0 0 8px #1d9ed514}}.boat-map-overlay{position:absolute;bottom:12px;left:12px;max-width:220px;background:#0f172ae6;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);border-radius:12px;padding:10px 12px;color:#fff;font-size:12px;z-index:1000;pointer-events:auto;cursor:pointer;animation:overlayFadeIn .2s ease}.boat-map-overlay__title{font-size:14px;font-weight:700;margin-bottom:4px}.boat-map-overlay__row{display:flex;align-items:center;gap:5px;margin-top:3px;font-size:12px;line-height:1.3}.boat-map-overlay__row--ok{color:#34d399}.boat-map-overlay__row--warn{color:#fbbf24}.boat-map-overlay__row--error{color:#f87171}@keyframes overlayFadeIn{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}.btn-trip-start{margin-top:12px;width:100%;padding:16px 24px;background:linear-gradient(135deg,#20e39a,#1d9ed5);color:#fff;border:none;border-radius:16px;font-weight:800;font-size:17px;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:10px;box-shadow:0 6px 24px #20e39a59,0 2px 8px #1d9ed533;text-transform:uppercase;letter-spacing:.5px;transition:all .2s ease}.btn-trip-start:hover{transform:translateY(-1px);box-shadow:0 8px 28px #20e39a73,0 4px 12px #1d9ed540}.btn-trip-start:active{transform:scale(.98)}.btn-trip-start:disabled{opacity:.4;cursor:not-allowed;transform:none;box-shadow:0 2px 8px #0000001a}.trip-checklist{padding:16px}.trip-checklist__header{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:12px}.trip-checklist__title{font-size:16px;font-weight:700;margin:0 0 2px}.trip-checklist__subtitle{font-size:12px;color:var(--muted);margin:0}.trip-checklist__badge--ok{background:#20e39a26;color:#059669}.trip-checklist__badge--warn{background:#f973161f;color:#ea580c}.trip-checklist__badge--error{background:#dc35451f;color:#dc3545}.trip-check{display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:12px;border:1px solid var(--border);margin-bottom:6px;background:#ffffff80;transition:all .2s ease}.trip-check--ok{border-color:#20e39a4d;background:#20e39a0a}.trip-check--warn{border-color:#f973164d;background:#f973160a}.trip-check--error{border-color:#dc35454d;background:#dc35450a}.trip-check--loading{border-color:#1d9ed533;background:#1d9ed50a}.trip-check__icon{font-size:18px;flex-shrink:0}.trip-check__body{flex:1;min-width:0}.trip-check__label{font-size:13px;font-weight:600}.trip-check__detail{font-size:11px;color:var(--muted)}.trip-check__status{font-size:16px;flex-shrink:0}.trip-cmd-btn{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;padding:14px 8px;border-radius:14px;border:1.5px solid rgba(122,139,160,.15);background:#fff9;color:var(--text);font-weight:600;font-size:12px;cursor:pointer;transition:all .15s ease}.trip-cmd-btn:active{transform:scale(.95)}.trip-cmd-btn__icon{font-size:22px}.trip-cmd-btn__label{font-size:11px}.trip-cmd-btn--yellow{border-color:#ffc10740;background:#ffc1070f}.trip-cmd-btn--blue{border-color:#1d9ed533;background:#1d9ed50f}.trip-cmd-btn--grey{border-color:#7a8ba033;background:#7a8ba00f}.trip-emergency-btn{margin-top:10px;width:100%;display:flex;align-items:center;justify-content:center;gap:10px;padding:14px;border-radius:14px;border:2px solid rgba(220,53,69,.3);background:linear-gradient(135deg,#dc354514,#dc35450a);color:#dc3545;font-weight:700;font-size:14px;cursor:pointer;transition:all .15s ease}.trip-emergency-btn:active{transform:scale(.97)}.form-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:12px;margin-top:10px}.form-grid textarea{min-height:72px}.social-feed{display:flex;flex-direction:column;gap:14px;margin-top:10px}.social-card{border:1px solid var(--border);border-radius:18px;overflow:hidden;background:#ffffff0d;box-shadow:var(--shadow)}.social-media{position:relative;height:320px;overflow:hidden}.social-media img{width:100%;height:100%;object-fit:cover;filter:saturate(1.05)}.social-overlay{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;flex-direction:column;justify-content:space-between;padding:14px;background:linear-gradient(180deg,rgba(0,0,0,.28),transparent 40%,rgba(0,0,0,.35))}.social-meta{display:flex;flex-direction:column;gap:4px;color:var(--light)}.social-body{padding:14px;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);background:#ffffffd9;border-top:1px solid rgba(29,158,213,.15)}button.copied,[data-copy].copied,[data-copy-open].copied{background:#20e39a40!important;color:var(--color-accent)!important;border-color:var(--color-accent)!important;transition:all .2s ease}.captain-slot{background:#1d9ed51f;border:1px solid rgba(29,158,213,.35);color:var(--muted);padding:8px 12px;border-radius:6px;font-size:12px;font-weight:500;cursor:pointer;transition:all .2s ease;min-height:36px;display:flex;align-items:center;justify-content:center}.captain-slot:hover{background:#1d9ed526;border-color:#1d9ed580;transform:translateY(-2px)}.captain-slot-active{background:var(--gradient-strong);color:var(--color-text-dark);border:1px solid rgba(32,227,154,.8);padding:8px 12px;border-radius:6px;font-size:12px;font-weight:600;cursor:pointer;transition:all .2s ease;min-height:36px;display:flex;align-items:center;justify-content:center;box-shadow:0 0 12px #20e39a4d}.captain-slot-active:hover{background:linear-gradient(135deg,#1d9ed5,#20e39a);transform:translateY(-2px);box-shadow:0 0 20px #20e39a80}.captain-slot-available{background:#20e39a2e;border:1px solid rgba(32,227,154,.5);color:var(--color-text-dark);padding:8px 12px;border-radius:6px;font-size:12px;font-weight:500;cursor:pointer;transition:all .2s ease;min-height:36px;display:flex;align-items:center;justify-content:center}.captain-slot-available:hover{background:#20e39a4d;border-color:#20e39ab3;transform:translateY(-2px)}.captain-slot-selected{background:var(--gradient-strong);color:var(--color-text-dark);border:1px solid rgba(32,227,154,.8);font-weight:600;box-shadow:0 0 12px #20e39a4d}@keyframes fadeIn{0%{opacity:0;translate:0 4px}to{opacity:1;translate:0 0}}@keyframes pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(1.3)}}@keyframes iot-pulse{0%{transform:scale(1);opacity:.7}50%{transform:scale(1.6);opacity:0}to{transform:scale(1);opacity:0}}@keyframes slideIn{0%{opacity:0;transform:translate(400px)}to{opacity:1;transform:translate(0)}}@keyframes slideOut{0%{opacity:1;transform:translate(0)}to{opacity:0;transform:translate(400px)}}@keyframes spin{to{transform:rotate(360deg)}}@keyframes slideDown{0%{transform:translateY(-100%);opacity:0}to{transform:translateY(0);opacity:1}}#iot-live-map .leaflet-popup-content-wrapper{background:#1a1a2e;color:#eee;border-radius:10px;box-shadow:0 4px 20px #0006}#iot-live-map .leaflet-popup-tip{background:#1a1a2e}div[style*="overflow-x:auto"]{scrollbar-width:thin;scrollbar-color:rgba(29,158,213,.4) rgba(29,158,213,.08)}div[style*="overflow-x:auto"]::-webkit-scrollbar{height:6px}div[style*="overflow-x:auto"]::-webkit-scrollbar-track{background:#1d9ed514;border-radius:3px}div[style*="overflow-x:auto"]::-webkit-scrollbar-thumb{background:#1d9ed566;border-radius:3px}div[style*="overflow-x:auto"]::-webkit-scrollbar-thumb:hover{background:#1d9ed599}@media (min-width:960px){body{padding:0}}.chat-tab{transition:background .15s ease,color .15s ease;font-weight:500}.chat-tab:hover{opacity:.85}.chat-item.card{transition:transform .12s ease,box-shadow .12s ease}.chat-item.card:hover{transform:translateY(-1px);box-shadow:0 4px 14px #1d9ed526}.chat-messages{scrollbar-width:thin;scrollbar-color:rgba(29,158,213,.3) transparent}.chat-messages::-webkit-scrollbar{width:5px}.chat-messages::-webkit-scrollbar-thumb{background:#1d9ed54d;border-radius:3px}.btn-accent{background:var(--color-accent);color:#fff;border:none;border-radius:999px;font-weight:600;cursor:pointer}.btn-accent:hover{filter:brightness(1.06)}.btn-accent.sm{padding:6px 12px;font-size:.85em}.btn-accent.md{padding:8px 18px;font-size:.92em}.btn-accent.lg{padding:14px 20px;font-size:15px;letter-spacing:-.01em;box-shadow:0 2px 8px #20e39a40;transition:transform .12s ease,box-shadow .16s ease}.btn-primary{background:var(--color-primary);color:#fff;border:none;border-radius:999px;font-weight:600;cursor:pointer}.btn-danger{background:#ef444426;color:#ef4444;border:none;border-radius:999px;font-weight:600;cursor:pointer}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#0000008c;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);display:flex;align-items:center;justify-content:center;z-index:1000;padding:16px}.row-between{display:flex;justify-content:space-between;align-items:center}.row-between.wrap{flex-wrap:wrap;gap:12px}.row-start{display:flex;justify-content:space-between;align-items:flex-start}.row-start.wrap{flex-wrap:wrap;gap:12px}.col{display:flex;flex-direction:column}.gap-4{gap:4px}.gap-6{gap:6px}.gap-8{gap:8px}.gap-10{gap:10px}.gap-12{gap:12px}.text-xs{font-size:.75em}.text-sm{font-size:.85em}.text-base{font-size:.92em}.text-center{text-align:center}.text-left{text-align:left}.font-bold{font-weight:700}.font-semi{font-weight:600}.mt-4{margin-top:4px}.mt-6{margin-top:6px}.mt-8{margin-top:8px}.mt-10{margin-top:10px}.mt-12{margin-top:12px}.mt-16{margin-top:16px}.mb-8{margin-bottom:8px}.mb-12{margin-bottom:12px}.mb-16{margin-bottom:16px}.p-8{padding:8px}.p-12{padding:12px}.p-16{padding:16px}.stat-card{flex:1;min-width:200px}.stat-card .label{font-size:.8em;color:var(--muted)}.stat-card .value{font-weight:700;font-size:.95em}.form-field{flex:1;min-width:200px}.form-field.narrow{flex:.5;min-width:160px}.sub-info{margin:4px 0 0;font-size:13px;color:var(--muted)}.empty-state{text-align:center;padding:20px;color:var(--muted)}.status-dot{display:inline-block;width:12px;height:12px;border-radius:50%}.status-dot.online{background:#20e39a}.status-dot.offline{background:#ef4444}.status-dot.idle{background:#888}.grid-auto{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:12px}.list-row{border:1px solid rgba(29,158,213,.2);border-radius:10px;padding:14px;margin-bottom:8px;background:#ffffff05}.scroll-x{overflow-x:auto;padding-bottom:8px;scrollbar-width:thin;scrollbar-color:rgba(29,158,213,.3) rgba(255,255,255,.5)}.code-block{background:#0003;border-radius:8px;padding:12px;font-family:monospace;font-size:.88em}.hidden{display:none}.chat-panel-messages{overflow-y:auto;display:flex;flex-direction:column;gap:6px;padding:14px;background:#1d9ed508;border-radius:14px;min-height:120px}.chat-panel-input-row{display:flex;gap:8px;margin-top:10px}.chat-panel-input{flex:1;padding:10px 14px;border:1.5px solid rgba(29,158,213,.3);border-radius:999px;background:#ffffff0d;color:var(--text);font-size:.92em;margin:0}.chat-bubble{padding:8px 14px;border-radius:16px;max-width:80%;font-size:.92em;line-height:1.5;word-break:break-word}.chat-bubble--mine{align-self:flex-end;background:var(--color-primary);color:#fff}.chat-bubble--other{align-self:flex-start;background:#1d9ed51f;color:var(--text)}.chat-bubble__sender{font-size:.78em;font-weight:600;margin-bottom:2px;opacity:.7}.chat-bubble__time{font-size:.72em;opacity:.6;margin-top:2px}.chat-bubble__time--mine{text-align:right}.chat-bubble__time--other{text-align:left}.chat-flat{padding:8px 12px;border-bottom:1px solid rgba(148,163,184,.15);font-size:.92em}.chat-flat__sender{font-weight:600;font-size:.85em;color:var(--color-primary)}.chat-flat__time{font-size:.75em;color:var(--muted)}.chat-flat__text{font-size:.9em;line-height:1.5}.chat-panel-empty{text-align:center;color:var(--muted);padding:24px;font-size:.92em}.chat-delete-btn{background:none;border:none;cursor:pointer;font-size:.8em;opacity:.5;margin-left:4px;padding:2px}.chat-delete-btn:hover{opacity:1}.ds-page{max-width:1120px;margin:0 auto;padding:var(--sp-8) var(--sp-4) 120px}.ds-section{margin-bottom:var(--sp-6)}.ds-stack{display:flex;flex-direction:column;gap:var(--sp-3)}.ds-stack--tight{gap:var(--sp-2)}.ds-stack--loose{gap:var(--sp-5)}.ds-row{display:flex;align-items:center;gap:var(--sp-3);flex-wrap:wrap}.ds-row--between{justify-content:space-between}.ds-card{background:var(--ds-surface);border:1px solid var(--ds-border);border-radius:var(--r-lg);padding:var(--sp-4);box-shadow:var(--sh-card)}.ds-card--strong{background:var(--ds-surface-strong)}.ds-btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--sp-2);padding:var(--sp-3) var(--sp-4);border-radius:var(--r-full);font-weight:var(--fw-semi);font-size:var(--fs-sm);cursor:pointer;border:1.5px solid transparent;transition:transform var(--ease-default),box-shadow var(--ease-default),opacity var(--ease-default);line-height:1}.ds-btn:hover{transform:translateY(-1px)}.ds-btn:active{transform:translateY(0)}.ds-btn--primary{background:var(--ds-primary);color:var(--ds-text-light);border-color:var(--ds-primary)}.ds-btn--primary:hover{box-shadow:0 4px 12px #1d9ed540}.ds-btn--secondary{background:transparent;color:var(--ds-primary);border-color:var(--ds-border-strong)}.ds-btn--ghost{background:transparent;color:var(--ds-text);border-color:var(--ds-border)}.ds-btn--danger{background:var(--ds-error-soft);color:var(--ds-error-text);border-color:var(--ds-error-border)}.ds-btn--danger:hover{background:#ef444426}.ds-btn--sm{padding:var(--sp-1) var(--sp-3);font-size:var(--fs-xs)}.ds-btn--lg{padding:var(--sp-4) var(--sp-5);font-size:var(--fs-base)}.ds-input,.ds-select{width:100%;padding:var(--sp-3) var(--sp-3);border-radius:var(--r-md);border:1px solid var(--ds-border);background:#1d9ed508;color:var(--ds-text);font-size:var(--fs-sm);outline:none;transition:border-color var(--ease-default),box-shadow var(--ease-default),background var(--ease-default)}.ds-input:focus,.ds-select:focus{border-color:var(--ds-primary);background:#1d9ed50f;box-shadow:0 0 0 3px var(--ds-primary-soft)}.ds-select{-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%237A8BA0' stroke-width='1.5' fill='none'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center;padding-right:32px}.ds-pill{display:inline-flex;align-items:center;gap:var(--sp-1);padding:5px var(--sp-3);border-radius:var(--r-full);font-size:var(--fs-xs);font-weight:var(--fw-medium);border:1px solid transparent;line-height:1.3}.ds-pill--success{background:var(--ds-success-soft);color:var(--ds-success);border-color:var(--ds-success-border)}.ds-pill--warning{background:var(--ds-warning-soft);color:var(--ds-warning-text);border-color:var(--ds-warning-border)}.ds-pill--error{background:var(--ds-error-soft);color:var(--ds-error-text);border-color:var(--ds-error-border)}.ds-pill--info{background:var(--ds-info-soft);color:var(--ds-primary);border-color:var(--ds-info-border)}.ds-pill--muted{background:#7a8ba014;color:var(--ds-muted);border-color:#7a8ba026}.ds-infobox{padding:var(--sp-3) var(--sp-4);border-radius:var(--r-md);border-left:3px solid var(--ds-border-strong);background:var(--ds-surface);font-size:var(--fs-sm);line-height:1.5}.ds-infobox--blue{border-left-color:var(--ds-primary);background:var(--ds-info-soft);color:var(--ds-text)}.ds-infobox--green{border-left-color:var(--ds-success);background:var(--ds-success-soft);color:var(--ds-text)}.ds-infobox--red{border-left-color:var(--ds-error);background:var(--ds-error-soft);color:var(--ds-text)}.ds-infobox--orange{border-left-color:var(--ds-warning);background:var(--ds-warning-soft);color:var(--ds-text)}.ds-tabs{display:flex;gap:var(--sp-2);border-bottom:1px solid var(--ds-border);padding-bottom:var(--sp-2);overflow-x:auto;scrollbar-width:none}.ds-tabs::-webkit-scrollbar{display:none}.ds-tab{padding:var(--sp-2) var(--sp-4);border-radius:var(--r-full);font-size:var(--fs-sm);font-weight:var(--fw-medium);color:var(--ds-muted);background:transparent;border:1px solid transparent;cursor:pointer;white-space:nowrap;transition:color var(--ease-default),background var(--ease-default),border-color var(--ease-default);box-shadow:none}.ds-tab:hover{color:var(--ds-text);background:var(--ds-primary-soft);transform:none;box-shadow:none}.ds-tab--active{color:var(--ds-primary);background:var(--ds-primary-soft);border-color:var(--ds-border-strong);font-weight:var(--fw-semi)}.ds-divider{height:1px;background:var(--ds-border);margin:var(--sp-3) 0;border:none}.ds-empty{text-align:center;padding:var(--sp-6);color:var(--ds-muted);font-size:var(--fs-sm)}.ds-label{font-size:var(--fs-xs);font-weight:var(--fw-medium);color:var(--ds-muted);letter-spacing:-.01em}
