:root{--bg:#f1f5f9;--surface:#fff;--surface-2:#f8fafc;--text:#1e293b;--muted:#64748b;--border:#e2e8f0;--primary:#4f46e5;--primary-hover:#4338ca;--primary-soft:#eef2ff;--danger:#dc2626;--danger-hover:#b91c1c;--admin:#0f172a;--radius:12px;--radius-sm:8px;--shadow:0 1px 3px #0f172a14, 0 1px 2px #0f172a0a;--shadow-lg:0 10px 30px #0f172a1f;color:var(--text);background:var(--bg);-webkit-font-smoothing:antialiased;font-family:system-ui,-apple-system,Hiragino Sans,Noto Sans JP,sans-serif;line-height:1.6}*{box-sizing:border-box}body{margin:0}h1,h2,h3{font-weight:600;line-height:1.3}a{color:var(--primary)}.center-screen{background:linear-gradient(160deg,#eef2ff 0%,#f1f5f9 60%);justify-content:center;align-items:center;min-height:100vh;padding:1rem;display:flex}.login-card{background:var(--surface);width:100%;max-width:380px;box-shadow:var(--shadow-lg);border-radius:16px;flex-direction:column;gap:.9rem;padding:2.25rem;display:flex}.login-card h1{margin:0;font-size:1.5rem}.login-card.admin h1{color:var(--primary)}.login-sub{color:var(--muted);margin:0 0 .75rem;font-size:.85rem}.login-card label{color:var(--muted);flex-direction:column;gap:.35rem;font-size:.8rem;font-weight:500;display:flex}input,select,textarea{border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--surface);width:100%;color:var(--text);padding:.65rem .8rem;font-family:inherit;font-size:1rem;transition:border-color .15s,box-shadow .15s}input:focus,select:focus,textarea:focus{border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-soft);outline:none}input:disabled,select:disabled,textarea:disabled{background:var(--surface-2);color:var(--muted)}textarea{resize:vertical}button,.button{border-radius:var(--radius-sm);background:var(--primary);color:#fff;cursor:pointer;border:1px solid #0000;justify-content:center;align-items:center;gap:.4rem;padding:.6rem 1.1rem;font-family:inherit;font-size:.92rem;font-weight:500;text-decoration:none;transition:background .15s,opacity .15s,transform 50ms;display:inline-flex}button:hover,.button:hover{background:var(--primary-hover)}button:active,.button:active{transform:translateY(1px)}button:disabled{opacity:.5;cursor:default}.button.secondary,button.secondary{background:var(--surface);color:var(--text);border-color:var(--border)}.button.secondary:hover,button.secondary:hover{background:var(--surface-2)}button.danger,.button.danger{background:var(--danger)}button.danger:hover{background:var(--danger-hover)}.login-card button{margin-top:.4rem;padding:.75rem;font-size:1rem}.button.sm,button.sm{padding:.35rem .85rem;font-size:.8rem}.topbar{background:var(--surface);border-bottom:1px solid var(--border);z-index:10;justify-content:space-between;align-items:center;gap:.75rem;padding:.85rem 1.25rem;display:flex;position:sticky;top:0}.topbar.admin{background:var(--admin);color:#fff}.topbar .brand{color:inherit;font-size:1.05rem;font-weight:700;text-decoration:none}.topbar>div{align-items:center;gap:.75rem;display:flex}.topbar .me{opacity:.9;font-size:.85rem}.topbar.admin button.secondary{color:#fff;background:#ffffff1f;border-color:#fff3}.page main{padding:1.5rem 1rem 3rem}.container{width:100%;margin:0 auto}.container.wide{width:100%}.list-head{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:.75rem;margin-bottom:1.25rem;display:flex}.list-head h2{margin:0;font-size:1.3rem}.actions-row{flex-wrap:wrap;align-items:center;gap:.5rem;display:flex}section{margin-bottom:1.5rem}section h3{color:var(--text);margin:0 0 .6rem;font-size:1rem}.table-wrap{-webkit-overflow-scrolling:touch;overflow-x:auto}.data-table{border-collapse:separate;border-spacing:0;background:var(--surface);border-radius:var(--radius);width:100%;box-shadow:var(--shadow);font-size:.9rem;overflow:hidden}.data-table th,.data-table td{text-align:left;border-bottom:1px solid var(--border);padding:.75rem .85rem}.data-table thead th{background:var(--surface-2);color:var(--muted);letter-spacing:.02em;font-size:.78rem;font-weight:600}.data-table tbody tr:last-child td{border-bottom:none}.data-table tbody tr:hover{background:var(--surface-2)}.data-table tr.unread td{font-weight:700}.data-table tr.unread td:first-child:before{content:"●";color:var(--primary);margin-right:.3rem;font-size:.7rem}.detail-table{border-collapse:separate;border-spacing:0;background:var(--surface);border-radius:var(--radius);width:100%;box-shadow:var(--shadow);margin-bottom:1.5rem;overflow:hidden}.detail-table th,.detail-table td{text-align:left;border-bottom:1px solid var(--border);padding:.7rem .9rem;font-size:.9rem}.detail-table tr:last-child th,.detail-table tr:last-child td{border-bottom:none}.detail-table th{background:var(--surface-2);width:120px;color:var(--muted);vertical-align:top;font-weight:600}.prewrap{white-space:pre-wrap}.badge{white-space:nowrap;border-radius:999px;padding:.18rem .6rem;font-size:.75rem;font-weight:600;line-height:1.5;display:inline-block}.badge-gray{color:#475569;background:#f1f5f9}.badge-blue{color:#1d4ed8;background:#dbeafe}.badge-orange{color:#c2410c;background:#ffedd5}.badge-teal{color:#0f766e;background:#ccfbf1}.badge-purple{color:#6d28d9;background:#ede9fe}.badge-green{color:#15803d;background:#dcfce7}.badge-dark{color:#fff;background:#1e293b}.form{background:var(--surface);border-radius:var(--radius);box-shadow:var(--shadow);flex-direction:column;gap:1.1rem;padding:1.5rem;display:flex}.form label{color:var(--muted);flex-direction:column;gap:.35rem;font-size:.82rem;font-weight:500;display:flex}.form>button{align-self:flex-start;padding:.7rem 1.6rem}.photos{border:1px solid var(--border);border-radius:var(--radius-sm);padding:1rem}.photos legend{color:var(--muted);padding:0 .4rem;font-size:.82rem;font-weight:600}.photo-grid{grid-template-columns:repeat(2,1fr);gap:.8rem;display:grid}.photo-slot{color:var(--muted);flex-direction:column;gap:.3rem;font-size:.78rem;display:flex}.card-pad{background:var(--surface);border-radius:var(--radius);box-shadow:var(--shadow);padding:1rem}.upload-slot{border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--surface-2);flex-direction:column;gap:.4rem;padding:.6rem;display:flex}.upload-slot .slot-label{color:var(--muted);font-size:.78rem;font-weight:600}.upload-slot .thumb-mini{width:100%;max-width:140px;height:auto}.upload-slot .slot-actions{flex-wrap:wrap;align-items:center;gap:.5rem;display:flex}.upload-slot label.button{cursor:pointer}.upload-slot label.button.is-busy{opacity:.6;pointer-events:none}.slot-error{color:var(--danger);font-size:.72rem}.movie-box{margin-bottom:.6rem}.movie-box video{border-radius:var(--radius-sm);margin-bottom:.4rem;display:block}.mip-zone{border:2px dashed var(--border);border-radius:var(--radius);text-align:center;background:var(--surface-2);flex-direction:column;align-items:center;gap:.5rem;padding:1.75rem 1rem;transition:border-color .15s,background .15s;display:flex}.mip-zone.over{border-color:var(--primary);background:var(--primary-soft)}.mip-hint{color:var(--muted);margin:0;font-size:.85rem}.mip-count{color:var(--muted);margin:0;font-size:.78rem}.mip-reorder-hint{color:var(--muted);margin:.8rem 0 .4rem;font-size:.78rem}.mip-grid{grid-template-columns:repeat(auto-fill,minmax(110px,1fr));gap:.6rem;display:grid}.mip-item{border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--surface);cursor:grab;aspect-ratio:1;padding:4px;position:relative;overflow:hidden}.mip-item:active{cursor:grabbing}.mip-item.dragging{opacity:.4;outline:2px solid var(--primary)}.mip-item img{object-fit:contain;pointer-events:none;width:100%;height:100%}.mip-no{z-index:1;background:var(--primary);color:#fff;border-radius:999px;justify-content:center;align-items:center;min-width:20px;height:20px;padding:0 5px;font-size:.72rem;font-weight:700;display:flex;position:absolute;top:4px;left:4px}.mip-remove{z-index:1;color:#fff;background:#0009;border-radius:50%;width:22px;height:22px;padding:0;font-size:1rem;line-height:1;position:absolute;top:2px;right:2px}.mip-remove:hover{background:var(--danger)}.thumb-row{flex-wrap:wrap;align-items:flex-start;gap:.6rem;display:flex}.thumb-row img{border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--surface-2);width:auto;max-width:240px;height:auto;max-height:240px;transition:transform .15s;display:block}.thumb-row a:hover img{transform:scale(1.04)}.thumb-mini{border:1px solid var(--border);border-radius:6px;max-width:90px;display:block}.thumb-del{display:inline-block;position:relative}.thumb-del img{border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--surface-2);width:auto;max-width:140px;height:auto;max-height:140px;display:block}.thumb-del-btn{color:#fff;background:#0009;border-radius:50%;width:22px;height:22px;padding:0;font-size:1rem;line-height:1;position:absolute;top:2px;right:2px}.thumb-del-btn:hover{background:var(--danger)}.chat{background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius);flex-direction:column;gap:.6rem;height:360px;margin-bottom:.8rem;padding:1rem;display:flex;overflow-y:auto}.chat-row{align-items:flex-end;gap:.5rem;display:flex}.chat-row.mine{justify-content:flex-end}.chat-row.theirs{justify-content:flex-start}.avatar{background:var(--primary);color:#fff;border-radius:50%;flex:none;justify-content:center;align-items:center;width:36px;height:36px;font-size:.85rem;font-weight:600;display:flex}.avatar.user{background:#f97316}.bubble{background:var(--surface);max-width:72%;box-shadow:var(--shadow);border-radius:14px;padding:.6rem .85rem}.chat-row.mine .bubble{background:var(--primary);color:#fff;cursor:pointer}.bubble p{white-space:pre-wrap;word-break:break-word;margin:0;font-size:.92rem}.read{opacity:.85;margin-top:.2rem;font-size:.68rem;font-weight:600;display:block}.chat-row.mine .read{color:#e0e7ff}.read.unread{color:#fecaca}.reply textarea{width:100%}.reply-actions{gap:.5rem;margin-top:.5rem;display:flex}.reply-actions .ok{background:var(--surface);color:var(--primary);border-color:var(--border)}.error{color:var(--danger);border-radius:var(--radius-sm);background:#fef2f2;border:1px solid #fecaca;margin:0 0 .75rem;padding:.6rem .8rem;font-size:.88rem}.notice{color:#15803d;border-radius:var(--radius-sm);background:#f0fdf4;border:1px solid #bbf7d0;margin:0 0 .75rem;padding:.6rem .8rem;font-size:.88rem}.hint{color:var(--muted);font-size:.82rem}.empty{text-align:center;color:var(--muted);background:var(--surface);border-radius:var(--radius);box-shadow:var(--shadow);padding:2.5rem 1rem}.link-del{color:var(--danger);cursor:pointer;background:0 0;border:none;align-self:flex-start;padding:0;font-size:.72rem;text-decoration:underline}.loading{color:var(--muted);justify-content:center;align-items:center;gap:.6rem;padding:2rem 0;display:flex}.sentinel{justify-content:center;min-height:1px;padding:.5rem 0;display:flex}.spinner{border:3px solid var(--border);border-top-color:var(--primary);border-radius:50%;width:22px;height:22px;animation:.7s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.overlay{z-index:1000;-webkit-backdrop-filter:blur(1px);backdrop-filter:blur(1px);background:#0f172a73;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.overlay-box{background:var(--surface);border-radius:var(--radius);box-shadow:var(--shadow-lg);flex-direction:column;align-items:center;gap:1rem;padding:1.75rem 2.25rem;display:flex}.overlay-label{color:var(--text);font-weight:600}.spinner.big{border-width:4px;width:44px;height:44px}@media (width<=640px){.page main{padding:1rem .75rem 2.5rem}.photo-grid{grid-template-columns:1fr}.topbar{padding:.75rem 1rem}.topbar .brand{font-size:.95rem}.bubble{max-width:82%}.data-table{box-shadow:none;background:0 0}.data-table thead{display:none}.data-table tr{background:var(--surface);border-radius:var(--radius);box-shadow:var(--shadow);margin-bottom:.75rem;padding:.4rem .2rem;display:block}.data-table td{border-bottom:1px dashed var(--border);text-align:right;justify-content:space-between;gap:1rem;padding:.55rem .9rem;display:flex}.data-table tr td:last-child{border-bottom:none}.data-table td:before{content:attr(data-label);color:var(--muted);text-align:left;font-size:.78rem;font-weight:600}.data-table tr.unread td:first-child:before{content:attr(data-label)}}
