:root{color-scheme:light;font-family:Segoe UI,Hiragino Sans,Meiryo,sans-serif;background:radial-gradient(circle at top left,rgba(22,163,74,.12),transparent 28%),radial-gradient(circle at top right,rgba(37,99,235,.12),transparent 26%),linear-gradient(180deg,#f4f8fb,#eef3f7);color:#123}*{box-sizing:border-box}html,body,#root{margin:0;min-height:100%}body{min-height:100vh}button,textarea{font:inherit}button{cursor:pointer}.app-shell{min-height:100vh;padding:20px}.login-shell{min-height:100vh;display:grid;place-items:center;padding:24px}.login-card{width:min(560px,100%);padding:32px;border-radius:28px;background:#ffffffe6;border:1px solid rgba(18,51,68,.12);box-shadow:0 28px 60px #1233441f;-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px)}.login-card h1{margin:8px 0 14px;font-size:clamp(30px,5vw,42px)}.login-copy{margin:0 0 24px;color:#4f6577;line-height:1.7}.login-button-slot{min-height:44px;display:flex;align-items:center}.login-status,.login-error{margin:18px 0 0}.login-error{color:#b91c1c}.login-note{margin-top:24px;padding:16px 18px;border-radius:18px;background:#eff6ff;color:#234}.login-note p{margin:8px 0 0;line-height:1.6}.topbar{display:flex;justify-content:space-between;gap:24px;align-items:flex-start;padding:20px 24px;border:1px solid rgba(18,51,68,.12);border-radius:20px;background:#ffffffd6;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);box-shadow:0 18px 40px #12334414}.topbar h1{margin:6px 0 8px;font-size:clamp(28px,4vw,40px)}.eyebrow{margin:0;color:#527189;font-size:12px;font-weight:700;letter-spacing:.08em;text-transform:uppercase}.subtle{margin:0;color:#567}.topbar__actions{display:flex;align-items:center;gap:12px;flex-wrap:wrap;justify-content:flex-end}.viewer-chip{display:flex;flex-direction:column;gap:2px;min-width:220px;padding:10px 14px;border-radius:14px;background:#eff6ff;color:#28415a}.viewer-chip span{font-size:12px;opacity:.7}.board-chip{display:flex;flex-direction:column;gap:2px;min-width:96px;padding:10px 14px;border-radius:14px;background:#ecfccb;color:#365314}.board-chip span{font-size:12px;opacity:.72}.primary-button,.ghost-button{border:none;border-radius:12px;padding:12px 16px;font-weight:700}.primary-button{background:#0f766e;color:#fff;box-shadow:0 12px 24px #0f766e38}.ghost-button{background:#fff;color:#234;border:1px solid rgba(18,51,68,.12)}.board-nav{display:flex;gap:10px;align-items:center;flex-wrap:wrap;margin:16px 0 12px;padding:0 6px;color:#537}.board-nav a{color:#0f766e;text-decoration:none;font-weight:700}.board-nav__hint{margin-left:8px;font-size:12px;color:#567}.board-stage{position:relative;min-height:calc(100vh - 220px);overflow:hidden;border:1px solid rgba(18,51,68,.12);border-radius:24px;background:linear-gradient(#ffffffd1,#ffffffd1);box-shadow:inset 0 1px #ffffff80;touch-action:none;cursor:default}.board-stage.is-pan-ready{cursor:grab}.board-stage.is-panning{cursor:grabbing}.board-stage.is-selecting{cursor:crosshair}.board-canvas{position:absolute;left:0;top:0;transform-origin:0 0;background:linear-gradient(#ffffffd1,#ffffffd1),linear-gradient(90deg,rgba(15,118,110,.06) 1px,transparent 1px),linear-gradient(rgba(15,118,110,.06) 1px,transparent 1px);background-size:auto,28px 28px,28px 28px;border-radius:24px;box-shadow:0 30px 60px #12334414,inset 0 0 0 1px #1233440f}.selection-rect{position:absolute;border:2px solid rgba(15,118,110,.8);background:#14b8a629;border-radius:14px;pointer-events:none;z-index:2}.empty-state{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;color:#456;text-align:center}.note-card{position:absolute;width:240px;min-height:220px;padding:14px 14px 12px;border-radius:18px;box-shadow:0 18px 26px #1233442e;-webkit-user-select:none;user-select:none;touch-action:none;cursor:grab;z-index:3}.note-card.is-dragging{cursor:grabbing;box-shadow:0 24px 36px #1233443d;z-index:5}.note-card.is-selected{box-shadow:0 0 0 3px #0f766eb3,0 18px 26px #1233442e}.note-card--yellow{background:#fff3a3}.note-card--blue{background:#cde8ff}.note-card--pink{background:#ffd0df}.note-card--green{background:#d6f5d7}.note-card--purple{background:#e6dbff}.note-card__toolbar{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px}.note-card__meta{max-width:180px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-size:12px;color:#123344b3}.note-card__delete{width:32px;height:32px;border:none;border-radius:999px;background:#ffffff8c;color:#7f1d1d;font-size:20px;line-height:1}.note-card__textarea{width:100%;min-height:138px;resize:none;border:none;background:transparent;color:#123;font-size:18px;line-height:1.5;outline:none}.note-card__colors{display:flex;gap:10px;justify-content:flex-end}.color-dot{width:18px;height:18px;border-radius:999px;border:2px solid transparent}.color-dot.is-active{border-color:#123}.color-dot--yellow{background:#ffe066}.color-dot--blue{background:#60a5fa}.color-dot--pink{background:#f472b6}.color-dot--green{background:#4ade80}.color-dot--purple{background:#a78bfa}.status-stack{position:fixed;left:20px;bottom:20px;z-index:9999;display:flex;flex-direction:column;gap:10px;pointer-events:none}.status-toast{min-width:220px;max-width:min(360px,calc(100vw - 40px));display:flex;flex-direction:column;gap:4px;padding:14px 16px;border-radius:16px;color:#14324d;background:#fffffff0;border:1px solid rgba(18,51,68,.12);box-shadow:0 18px 42px #1233442e;-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px)}.status-toast--success{background:#dcfce7f2}.status-toast--warn{background:#fef3c7f7}.status-toast--error{background:#fee2e2f7;color:#7f1d1d}.status-toast--info{background:#dbeafef2}.status-toast__label{font-size:12px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;opacity:.72}.boards-layout{display:grid;grid-template-columns:minmax(280px,360px) minmax(0,1fr);gap:18px}.boards-panel{padding:24px;border-radius:24px;background:#ffffffe0;border:1px solid rgba(18,51,68,.12);box-shadow:0 18px 40px #12334414}.boards-panel h2{margin:0 0 16px;font-size:22px}.boards-panel__header{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:16px}.board-create-form{display:flex;flex-direction:column;gap:14px}.board-field{display:flex;flex-direction:column;gap:8px;color:#345;font-weight:600}.board-field input{width:100%;padding:13px 14px;border-radius:14px;border:1px solid rgba(18,51,68,.16);background:#fff;color:#123}.board-quick-links{margin-top:14px;display:flex;gap:10px;flex-wrap:wrap}.board-quick-links a{text-decoration:none}.boards-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:14px}.board-card{display:flex;flex-direction:column;gap:14px;padding:18px;min-height:138px;border-radius:20px;text-decoration:none;color:#123;background:linear-gradient(180deg,#ffffffeb,#f3fafceb),linear-gradient(135deg,rgba(20,184,166,.08),transparent 45%);border:1px solid rgba(18,51,68,.12);box-shadow:0 14px 26px #12334414;transition:transform .12s ease,box-shadow .12s ease,border-color .12s ease}.board-card:hover{transform:translateY(-2px);border-color:#0f766e4d;box-shadow:0 20px 32px #1233441f}.board-card__header{display:flex;flex-direction:column;gap:6px}.board-card__header strong{font-size:18px;line-height:1.4}.board-card__header span{color:#567;font-size:13px}.board-card__meta{display:flex;flex-direction:column;gap:6px;color:#456;font-size:13px}.boards-empty,.boards-error{padding:18px;border-radius:18px;color:#456;background:#f8fafc}.boards-error{color:#991b1b;background:#fee2e2;margin-bottom:12px}@media(max-width:860px){.topbar{flex-direction:column}.topbar__actions{width:100%;justify-content:flex-start}.viewer-chip,.board-chip{min-width:0;width:100%}.status-stack{left:14px;right:14px;bottom:14px}.status-toast{min-width:0;max-width:none}.boards-layout{grid-template-columns:1fr}}
