:root{--bg: #060a18;--bg-top: #0c1430;--bg-bot: #04060f;--glass: rgba(255, 255, 255, .045);--glass-strong: rgba(255, 255, 255, .08);--glass-border: rgba(255, 255, 255, .09);--glass-border-strong: rgba(255, 255, 255, .16);--surface: #131a2e;--surface-2: #1c2542;--border: rgba(255, 255, 255, .08);--border-strong: rgba(255, 255, 255, .18);--text: #f3f5fb;--muted: #a8b3cc;--muted-2: #7e8aa6;--accent: #6cc1ff;--accent-press: #3a9eea;--accent-soft: rgba(108, 193, 255, .18);--on-accent: #061226;--ring: 0 0 0 1px rgba(108, 193, 255, .55), 0 0 16px rgba(108, 193, 255, .35);--ring-strong: 0 0 0 1px rgba(108, 193, 255, .85), 0 0 22px rgba(108, 193, 255, .5);--danger: #ff7a7a;--ok: #5cd6a3;--warn: #ffc857;--radius-sm: 12px;--radius: 16px;--radius-lg: 22px;--tap: 44px;color-scheme:dark}*{box-sizing:border-box}html,body{margin:0;padding:0}body{background:radial-gradient(900px 600px at 50% -120px,rgba(108,193,255,.12),transparent 60%),radial-gradient(700px 500px at 100% 110%,rgba(94,75,255,.1),transparent 60%),linear-gradient(180deg,var(--bg-top) 0%,var(--bg-bot) 100%);background-color:var(--bg);background-attachment:fixed;color:var(--text);font-family:-apple-system,BlinkMacSystemFont,Hiragino Sans,Noto Sans JP,Inter,system-ui,sans-serif;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}#root{max-width:540px;margin:0 auto;height:100dvh;display:flex;flex-direction:column;overflow:hidden}.app-header{display:flex;align-items:center;justify-content:space-between;padding:max(env(safe-area-inset-top),10px) 16px 8px}.app-header h1{font-size:1.1rem;margin:0;letter-spacing:.01em;font-weight:700;color:var(--text)}.app-main{flex:1;min-height:0;display:flex;flex-direction:column;padding:4px 16px 0}.content{flex:1;min-height:0;overflow-y:auto;padding-bottom:156px;-webkit-overflow-scrolling:touch}.conn-bar{display:flex;gap:8px;overflow-x:auto;padding:2px 0 8px;scrollbar-width:none}.conn-bar::-webkit-scrollbar{display:none}.conn-chip{flex:0 0 auto;display:inline-flex;align-items:center;gap:7px;padding:6px 8px 6px 12px;background:var(--glass);border:1px solid var(--glass-border);border-radius:999px;font-size:.82rem;color:var(--text);backdrop-filter:blur(12px) saturate(140%);-webkit-backdrop-filter:blur(12px) saturate(140%)}.conn-dot{width:9px;height:9px;border-radius:50%;flex-shrink:0;box-shadow:0 0 7px #fff3;animation:conn-pulse 2.4s ease-in-out infinite}@keyframes conn-pulse{0%,to{opacity:1}50%{opacity:.55}}.conn-name{font-weight:700}.conn-state{font-size:.7rem;color:var(--ok);font-weight:600}.conn-off{width:20px;height:20px;display:grid;place-items:center;border:none;background:transparent;color:var(--muted-2);font-size:.72rem;cursor:pointer;border-radius:50%;padding:0}.conn-off:active{background:var(--glass-strong);color:var(--text)}.input-zone{position:fixed;bottom:0;left:50%;transform:translate(-50%);width:100%;max-width:540px;background:linear-gradient(to top,rgba(6,10,24,.92) 72%,rgba(6,10,24,.6) 92%,transparent);border-top:1px solid var(--glass-border);backdrop-filter:blur(20px) saturate(150%);-webkit-backdrop-filter:blur(20px) saturate(150%);padding-bottom:max(env(safe-area-inset-bottom),10px)}.quick-strip{display:flex;gap:8px;overflow-x:auto;padding:10px 12px 4px;scroll-snap-type:x proximity;-webkit-overflow-scrolling:touch;scrollbar-width:none}.quick-strip::-webkit-scrollbar{display:none}.quick-chip{flex:0 0 auto;scroll-snap-align:start;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1px;min-width:70px;min-height:48px;padding:6px 14px;background:var(--glass);border:1px solid var(--glass-border);border-radius:14px;color:var(--text);cursor:pointer;backdrop-filter:blur(14px) saturate(140%);-webkit-backdrop-filter:blur(14px) saturate(140%);box-shadow:inset 0 1px #ffffff0d,0 4px 14px #0000002e;transition:background .12s ease,border-color .12s ease,transform .08s ease}.quick-chip:active{background:var(--glass-strong);border-color:var(--glass-border-strong);transform:scale(.96)}.quick-chip-label{font-size:.92rem;font-weight:700;line-height:1.15;white-space:nowrap}.quick-chip-sub{font-size:.68rem;color:var(--muted)}.input-dock{display:flex;gap:8px;padding:6px 12px 8px}.dock-btn{flex:1;min-height:var(--tap);border:1px solid var(--glass-border);background:var(--glass);border-radius:var(--radius);padding:8px 6px;font-size:.85rem;font-weight:600;color:var(--text);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;cursor:pointer;backdrop-filter:blur(14px) saturate(140%);-webkit-backdrop-filter:blur(14px) saturate(140%);box-shadow:inset 0 1px #ffffff0f,0 4px 14px #00000040;transition:background .12s ease,transform .08s ease,border-color .12s ease}.dock-btn:active{background:var(--glass-strong);transform:scale(.97)}.dock-btn.primary{background:linear-gradient(135deg,#6cc1fff2,#3a9eeaf2);border-color:#ffffff40;color:var(--on-accent);box-shadow:inset 0 1px #ffffff59,0 6px 18px #6cc1ff59}.dock-btn.primary:active{filter:brightness(.92)}.dock-btn .ico{font-size:1.25rem;line-height:1}.dock-btn:disabled{opacity:.4}.card{background:var(--glass);border:1px solid var(--glass-border);border-radius:var(--radius);padding:14px;margin-bottom:8px;backdrop-filter:blur(14px) saturate(140%);-webkit-backdrop-filter:blur(14px) saturate(140%);box-shadow:inset 0 1px #ffffff0d,0 4px 16px #0003;transition:background .12s ease,border-color .12s ease}.card[role=button]{cursor:pointer}.card[role=button]:active{background:var(--glass-strong);border-color:var(--glass-border-strong)}.card .title{font-weight:700;font-size:1rem;line-height:1.3;color:var(--text)}.card .meta{color:var(--muted);font-size:.85rem;margin-top:4px;line-height:1.35}.section-label{color:var(--muted);font-size:.78rem;font-weight:600;margin:12px 2px 6px;letter-spacing:.01em}.field{margin-bottom:12px}.field label{display:block;font-size:.8rem;color:var(--muted);margin-bottom:6px;font-weight:500}.field input,.field textarea,.field select{width:100%;background:var(--bg);border:1px solid var(--border);border-radius:var(--radius-sm);padding:12px;color:var(--text);font-size:1rem;font-family:inherit;min-height:var(--tap);transition:border-color .12s ease}.field input:focus,.field textarea:focus,.field select:focus{outline:none;border-color:var(--accent)}.field textarea{min-height:84px;line-height:1.4;resize:vertical}.row{display:flex;gap:10px}.row>.field{flex:1}.btn{border:1px solid var(--glass-border);border-radius:var(--radius-sm);padding:12px 16px;font-size:.95rem;font-weight:600;cursor:pointer;background:var(--glass);color:var(--text);min-height:var(--tap);backdrop-filter:blur(12px) saturate(140%);-webkit-backdrop-filter:blur(12px) saturate(140%);box-shadow:inset 0 1px #ffffff0d,0 2px 10px #0003;transition:background .12s ease,transform .08s ease}.btn:active{background:var(--glass-strong);transform:scale(.98)}.btn.primary{background:linear-gradient(135deg,#6cc1fff2,#3a9eeaf2);border-color:#ffffff40;color:var(--on-accent);box-shadow:inset 0 1px #ffffff59,0 6px 18px #6cc1ff59}.btn.primary:active{filter:brightness(.92)}.btn.ghost{background:transparent;border-color:var(--glass-border);color:var(--muted);-webkit-backdrop-filter:none;backdrop-filter:none;box-shadow:none}.btn:disabled{opacity:.45;cursor:not-allowed}.btn-row{display:flex;gap:10px;margin-top:8px}.btn-row .btn{flex:1}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0408168c;backdrop-filter:blur(8px) saturate(120%);-webkit-backdrop-filter:blur(8px) saturate(120%);display:flex;align-items:flex-end;z-index:50;animation:fade-in .18s ease}@keyframes fade-in{0%{opacity:0}to{opacity:1}}.modal{background:radial-gradient(700px 200px at 50% -60px,rgba(108,193,255,.08),transparent),linear-gradient(180deg,#1a2342,#131a31);width:100%;max-width:540px;margin:0 auto;border-radius:var(--radius-lg) var(--radius-lg) 0 0;border-top:1px solid var(--glass-border-strong);padding:16px;padding-bottom:max(env(safe-area-inset-bottom),16px);max-height:92dvh;overflow-y:auto;display:flex;flex-direction:column;box-shadow:0 -10px 36px #00000080}.modal.modal-fixed{height:82dvh;overflow:hidden}.modal-body{flex:1;min-height:0;overflow-y:auto;margin:0 -4px;padding:0 4px}.modal h2{font-size:1.1rem;margin:0 0 8px;font-weight:700}.badge{display:inline-block;font-size:.72rem;padding:3px 9px;border-radius:999px;font-weight:600}.badge.low{background:#ffc85724;color:var(--warn)}.badge.ok{background:#5cd6a324;color:var(--ok)}.banner{border-radius:var(--radius-sm);padding:10px 12px;font-size:.88rem;margin-bottom:10px;line-height:1.4}.banner.warn{background:#ffc8571a;color:var(--warn);border:1px solid rgba(255,200,87,.3)}.banner.error{background:#ff7a7a1a;color:var(--danger);border:1px solid rgba(255,122,122,.3)}.banner.info{background:var(--accent-soft);color:var(--accent);border:1px solid rgba(77,171,255,.3)}.empty{text-align:center;color:var(--muted);padding:32px 16px;font-size:.9rem}.spinner{display:inline-block;width:16px;height:16px;border:2px solid var(--border);border-top-color:var(--accent);border-radius:50%;animation:spin .7s linear infinite;vertical-align:-2px;margin-right:6px}@keyframes spin{to{transform:rotate(360deg)}}.link-btn{background:none;border:none;color:var(--accent);font-size:.88rem;font-weight:600;cursor:pointer;padding:6px 8px;border-radius:6px;min-height:32px}.view-toggle{display:flex;gap:0;background:var(--glass);border:1px solid var(--glass-border);border-radius:var(--radius-sm);padding:3px;margin:4px 0 10px;backdrop-filter:blur(12px) saturate(140%);-webkit-backdrop-filter:blur(12px) saturate(140%)}.view-toggle button{flex:1;border:none;background:transparent;color:var(--muted);padding:8px 10px;border-radius:9px;font-size:.88rem;font-weight:600;cursor:pointer;min-height:36px;transition:background .12s ease,color .12s ease,box-shadow .15s ease}.view-toggle button.active{background:linear-gradient(135deg,#6cc1fff2,#3a9eeaf2);color:var(--on-accent);box-shadow:inset 0 1px #ffffff59,0 4px 14px #6cc1ff52}.month-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px}.month-nav{background:var(--glass);border:1px solid var(--glass-border);color:var(--text);border-radius:var(--radius-sm);width:var(--tap);height:38px;font-size:1.2rem;cursor:pointer;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);box-shadow:inset 0 1px #ffffff0a;transition:background .12s ease,transform .08s ease}.month-nav:active{background:var(--glass-strong);transform:scale(.94)}.month-title{background:none;border:none;color:var(--text);font-size:1.05rem;font-weight:700;cursor:pointer;padding:6px 12px;border-radius:8px}.month-title:active{background:var(--surface)}.month-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:4px}.month-weekdays{margin-bottom:4px}.wd{text-align:center;font-size:.74rem;color:var(--muted);padding:4px 0;font-weight:600}.wd.sun{color:#ff8a8a}.wd.sat{color:#7eb4ff}.day-cell{min-height:50px;background:var(--glass);border:1px solid var(--glass-border);border-radius:var(--radius-sm);display:flex;flex-direction:column;align-items:center;justify-content:flex-start;gap:3px;padding:5px 0 3px;color:var(--text);cursor:pointer;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);transition:background .15s ease,border-color .15s ease,box-shadow .2s ease}.day-cell:active{background:var(--glass-strong)}.day-cell.dim{opacity:.28;background:transparent;border-color:transparent}.day-cell.today{border-color:#6cc1ff80;box-shadow:var(--ring)}.day-cell.today .day-num{color:var(--accent);font-weight:700}.day-cell.selected{background:#6cc1ff2e;border-color:#6cc1ffd9;box-shadow:var(--ring-strong)}.day-cell.selected .day-num{color:var(--text);font-weight:700}.day-cell.selected .dot{background:var(--text)}.day-num{font-size:.88rem;font-weight:600;line-height:1}.day-dots{display:flex;flex-wrap:wrap;gap:2px;justify-content:center;min-height:6px}.dot{width:5px;height:5px;border-radius:50%}.dot.google{background:var(--accent)}.dot.ics{background:var(--warn)}.month-day-list{margin-top:10px}.chip-row{display:flex;flex-wrap:wrap;gap:8px;padding:2px 0 6px}.chip{flex:0 0 auto;display:flex;flex-direction:column;align-items:flex-start;gap:2px;background:var(--surface);border:1px solid var(--border);border-radius:999px;padding:6px 12px;color:var(--text);font-size:.85rem}.chip .chip-sub{font-size:.7rem;color:var(--muted)}.calendar-checklist{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius-sm);padding:4px;max-height:220px;overflow-y:auto}.check-row{display:flex;align-items:center;gap:10px;padding:10px 8px;border-radius:8px;cursor:pointer;min-height:40px;color:var(--text);transition:background .12s ease}.check-row+.check-row{border-top:1px solid var(--border)}.check-row:active{background:var(--surface-2)}.check-row input[type=checkbox]{width:20px;height:20px;accent-color:var(--accent);cursor:pointer;margin:0}.check-row span{flex:1;font-size:.95rem}:root[data-theme=light]{--bg: #eef1f8;--bg-top: #f8fafe;--bg-bot: #e6ebf5;--glass: rgba(17, 26, 48, .035);--glass-strong: rgba(17, 26, 48, .07);--glass-border: rgba(17, 26, 48, .1);--glass-border-strong: rgba(17, 26, 48, .2);--surface: #ffffff;--surface-2: #eef1f7;--border: rgba(17, 26, 48, .1);--border-strong: rgba(17, 26, 48, .22);--text: #0f1626;--muted: #51607c;--muted-2: #74809a;--accent: #1f8be3;--accent-press: #1773c4;--accent-soft: rgba(31, 139, 227, .12);--on-accent: #ffffff;--ring: 0 0 0 1px rgba(31, 139, 227, .5), 0 0 14px rgba(31, 139, 227, .25);--ring-strong: 0 0 0 1px rgba(31, 139, 227, .85), 0 0 18px rgba(31, 139, 227, .4);--danger: #d63838;--ok: #1ea974;--warn: #b1700a;color-scheme:light}:root[data-theme=light] body{background:radial-gradient(900px 600px at 50% -140px,rgba(31,139,227,.1),transparent 60%),linear-gradient(180deg,var(--bg-top) 0%,var(--bg-bot) 100%);background-color:var(--bg)}:root[data-theme=light] .input-zone{background:linear-gradient(to top,rgba(238,241,248,.92) 72%,rgba(238,241,248,.55) 92%,transparent)}:root[data-theme=light] .modal{background:radial-gradient(700px 200px at 50% -60px,rgba(31,139,227,.07),transparent),#fff}:root[data-theme=light] .modal-backdrop{background:#0f162659}:root[data-theme=light] .day-cell.selected{background:#1f8be324}:root[data-theme=light] .wd.sun{color:#d63838}:root[data-theme=light] .wd.sat{color:#1773c4}
