body{margin:0;background:linear-gradient(135deg,#0b1020,#0f172a,#020617);color:#e5e7eb;font-family:Arial,Helvetica,sans-serif;background-repeat:no-repeat;background-size:cover;background-attachment:fixed}.home{min-height:calc(100vh - 64px);padding:60px 20px;background:radial-gradient(1200px 700px at 50% 20%,rgba(124,58,237,.18),transparent 55%),linear-gradient(135deg,#0b1020,#101634);color:#ffffffe6}.hero{text-align:center;margin-bottom:34px}.hero-title{font-size:44px;font-weight:800;letter-spacing:-.5px;margin:0 0 10px}.hero-title span{color:#a78bfa}.hero-sub{margin:0;color:#ffffffa6;font-size:14px}.toggle-row{max-width:980px;margin:0 auto 16px;display:grid;grid-template-columns:1fr 1fr;gap:14px}.toggle-btn{width:100%;height:44px;padding:0 16px;border-radius:14px;display:flex;align-items:center;justify-content:space-between;background:#ffffff0f;border:1px solid rgba(255,255,255,.12);color:#ffffffeb;font-size:14px;font-weight:800;letter-spacing:-.1px;cursor:pointer;transition:transform .12s ease,background .12s ease,border-color .12s ease}.toggle-btn:hover{transform:translateY(-1px);background:#ffffff14;border-color:#a78bfa47}.toggle-btn.active{background:linear-gradient(135deg,#7c3aed8c,#a78bfa40);border-color:#a78bfa73}.chev{opacity:.9}.panel-wrap{max-width:980px;margin:0 auto 18px}.panel-card{padding:18px;border-radius:18px;background:#ffffff0b;border:1px solid rgba(255,255,255,.1);box-shadow:0 16px 40px #00000040;transform-origin:top;animation:panelDrop .16s ease-out}@keyframes panelDrop{0%{opacity:0;transform:translateY(-6px) scaleY(.98)}to{opacity:1;transform:translateY(0) scaleY(1)}}.panel-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;align-items:stretch;grid-template-columns:1fr}.panel-col{padding:14px;border-radius:14px;background:#0000001a;border:1px solid rgba(255,255,255,.08)}.panel-head{display:flex;align-items:center;gap:10px;margin-bottom:10px}.panel-dot{width:10px;height:10px;border-radius:50%;background:#a78bfa;box-shadow:0 0 18px #a78bfa8c}.panel-col h3{margin:0;font-size:14px;font-weight:800;color:#ffffffeb}.panel-col ul{margin:0;padding-left:16px;color:#ffffffb8;font-size:13px;line-height:1.7}.action-row{max-width:780px;margin:18px auto 0;display:flex;gap:12px;justify-content:center;flex-wrap:wrap}.btn{padding:14px 18px;border-radius:14px;text-decoration:none;font-weight:800;font-size:14px;letter-spacing:-.1px;transition:transform .15s ease,box-shadow .15s ease,background .15s ease}.btn:hover{transform:translateY(-2px)}.btn-primary{background:linear-gradient(135deg,#7c3aed,#a78bfa);color:#0b1020;box-shadow:0 18px 45px #7c3aed59}.btn-ghost{background:#ffffff0f;color:#ffffffe6;border:1px solid rgba(255,255,255,.12)}.btn-outline{background:transparent;color:#ffffffe6;border:1px solid rgba(167,139,250,.45)}@media(max-width:900px){.toggle-row,.panel-grid{grid-template-columns:1fr}}.toggle-grid{max-width:980px;margin:0 auto 18px;display:grid;grid-template-columns:1fr 1fr;gap:14px;align-items:start}.toggle-col{display:flex;flex-direction:column;gap:12px}.panel-card{padding:16px;border-radius:18px;background:#ffffff0b;border:1px solid rgba(255,255,255,.1);box-shadow:0 16px 40px #00000040}.panel-stack{display:flex;flex-direction:column;gap:12px}.panel-item{padding:14px;border-radius:14px;background:#0000001a;border:1px solid rgba(255,255,255,.08)}.panel-item h3{margin:0 0 8px;font-size:14px;font-weight:800}.panel-item ul{margin:0;padding-left:16px;font-size:13px;line-height:1.7;color:#ffffffb8}@media(max-width:900px){.toggle-grid{grid-template-columns:1fr}}.signup-form{width:360px;margin:120px auto;padding:32px;display:flex;flex-direction:column;gap:12px;background:#1e293b;border-radius:12px;box-shadow:0 4px 12px #00000014}.signup-form h2{text-align:center;margin-bottom:12px}.signup-form input{height:44px;padding:0 12px;background:#0f172a;color:#e5e7eb;border:1px solid #334155;border-radius:6px;font-size:14px}.signup-form input:focus{outline:none;border-color:#7c3aed}.signup-form button{height:44px;margin-top:8px;background:#6d28d9;color:#fff;font-size:15px;font-weight:700;border:none;border-radius:8px;cursor:pointer;transition:background .15s ease,transform .12s ease}.signup-form button:hover{background:#6d28d9;transform:translateY(-1px)}.login-form{width:360px;margin:120px auto;padding:32px;display:flex;flex-direction:column;gap:12px;background:#1e293b;border-radius:12px;box-shadow:0 4px 12px #00000014}.login-form h2{text-align:center;margin-bottom:12px}.login-form input{height:44px;padding:0 12px;background:#0f172a;color:#e5e7eb;border:1px solid #334155;border-radius:6px;font-size:14px}.login-form input:focus{outline:none;border-color:#7c3aed}.login-form button{height:44px;margin-top:8px;background:#6d28d9;color:#fff;font-size:15px;font-weight:700;border:none;border-radius:8px;cursor:pointer;transition:background .15s ease,transform .12s ease}.login-form button:hover{background:#6d28d9;transform:translateY(-1px)}.mypage-container{display:flex;justify-content:center;margin-top:80px;margin-bottom:40px}.mypage-card{width:500px;padding:32px;background:#1e293b;border-radius:12px;box-shadow:0 4px 12px #00000014}.mypage-card h2{text-align:center;margin-bottom:24px}.row{display:flex;align-items:center;gap:12px;padding:12px 0;border-bottom:1px solid #eee;font-size:14px}.row:last-child{border-bottom:none}.row span:first-child{color:#a5a5a5}.row span:last-child{font-weight:600}.mypage-actions{margin-top:16px;display:flex;justify-content:flex-start}.mypage-btn{height:36px;padding:0 12px;border-radius:10px;font-size:13px;font-weight:600;cursor:pointer;border:1px solid #334155;background:#111827;color:#e5e7eb;transition:background .15s ease,border-color .15s ease,transform .05s ease}.mypage-btn:hover{background:#0b1220;border-color:#475569}.mypage-btn:active{transform:translateY(1px)}.mypage-btn:disabled{opacity:.55;cursor:not-allowed}.mypage-btn.btn-delete{border-color:#f8717180;background:#f871711f}.mypage-btn.btn-delete:hover{background:#f871712e;border-color:#f87171b3}.navbar{height:64px;background:linear-gradient(180deg,#141436,#0b1020);display:flex;align-items:center;justify-content:space-between;padding:0 24px;border-bottom:1px solid rgba(167,139,250,.25)}.logo{color:#a78bfa;font-weight:800;font-size:18px;text-decoration:none}.nav-left{display:flex;align-items:center;gap:18px}.nav-link{text-decoration:none;font-weight:600;color:#ffffffd9;font-size:15px}.nav-link:hover{color:#a78bfa}.nav-right{display:flex;align-items:center;gap:16px}.nav-right a{text-decoration:none;font-weight:600;color:#ffffffd9}.nav-right button{color:#ffffff80;margin-left:18px;background:none;border:none;cursor:pointer;font-size:14px;font-weight:600}.nav-right a:hover,.nav-right button:hover{color:#a78bfa}.user-email{font-size:14px;color:#b4b3b3}.navbar button{background:none;border:none;color:#ffffffd9;font-size:14px;cursor:pointer;font-weight:600}.navbar button:hover{color:#4f46e5;text-decoration:none}.toggle-row{max-width:980px;margin:0 auto 16px;display:grid;grid-template-columns:1fr 1fr;gap:12px}.toggle-btn{width:100%;padding:16px 18px;border-radius:16px;border:1px solid rgba(167,139,250,.22);background:#ffffff0a;color:#ffffffe6;font-weight:800;font-size:14px;letter-spacing:-.1px;display:flex;align-items:center;justify-content:space-between;cursor:pointer;box-shadow:0 16px 40px #0000002e;transition:transform .15s ease,background .15s ease,border .15s ease}.toggle-btn:hover{transform:translateY(-2px);background:#ffffff0f;border-color:#a78bfa59}.toggle-btn.active{background:linear-gradient(135deg,#7c3aed59,#a78bfa2e);border-color:#a78bfa8c}.chev{opacity:.85}@media(max-width:900px){.toggle-row{grid-template-columns:1fr}}.admin-container{display:flex;justify-content:center;margin-top:80px}.admin-card{width:800px;padding:32px;background:#1e293b;border-radius:12px;box-shadow:0 4px 12px #00000014}.admin-card h2{text-align:center;margin-bottom:24px}.admin-table{width:100%;border-collapse:collapse;font-size:14px}.admin-table th{text-align:center;padding:12px;background:#1e293b;color:#e5e7eb;border-bottom:1px solid #ddd}.admin-table td{padding:12px;text-align:center;color:#e5e7eb;border-bottom:1px solid #334155;vertical-align:middle}.admin-table tr:hover{background:#020617}.admin-actions{display:flex;justify-content:center;align-items:center;gap:10px;flex-wrap:wrap}.role-select{height:36px;padding:0 12px;background:#0f172a;color:#e5e7eb;border:1px solid #334155;border-radius:10px;outline:none;cursor:pointer;transition:border-color .15s ease,box-shadow .15s ease}.role-select:hover{border-color:#475569}.role-select:focus{border-color:#60a5fa;box-shadow:0 0 0 3px #60a5fa40}.role-select option{background:#0f172a;color:#e5e7eb}.admin-btn{height:36px;padding:0 12px;border-radius:10px;font-size:13px;font-weight:600;cursor:pointer;border:1px solid #334155;background:#111827;color:#e5e7eb;transition:background .15s ease,border-color .15s ease,transform .05s ease}.admin-btn:hover{background:#0b1220;border-color:#475569}.admin-btn:active{transform:translateY(1px)}.admin-btn:disabled{opacity:.55;cursor:not-allowed}.btn-role{border-color:#60a5fa80;background:#60a5fa1f}.btn-role:hover{background:#60a5fa2e;border-color:#60a5fab3}.btn-delete{border-color:#f8717180;background:#f871711f}.btn-delete:hover{background:#f871712e;border-color:#f87171b3}.post-create-container{min-height:calc(100vh - 80px);padding:40px 16px;display:flex;justify-content:center;align-items:flex-start}.post-create-card{width:720px;max-width:100%;background:#1e293b;border-radius:14px;padding:28px;box-shadow:0 10px 30px #00000040;border:1px solid rgba(255,255,255,.06)}.post-create-card h2{margin:0 0 18px;color:#e5e7eb;font-size:22px}.post-create-form{display:flex;flex-direction:column;gap:14px}.label{color:#cbd5e1;font-size:13px}.post-create-form input,.post-create-form textarea{width:100%;background:#0f172a;color:#e5e7eb;border:1px solid rgba(255,255,255,.1);border-radius:10px;padding:12px;font-size:14px;outline:none}.post-create-form textarea{resize:vertical;min-height:220px}.post-create-form input:focus,.post-create-form textarea:focus{border-color:#6366f1a6;box-shadow:0 0 0 4px #6366f126}.error{color:#fecaca;background:#ef44441f;border:1px solid rgba(239,68,68,.25);padding:10px 12px;border-radius:10px;font-size:13px}.actions{display:flex;gap:10px;justify-content:flex-end;margin-top:6px}.btn:disabled{opacity:.6;cursor:not-allowed}.btn.ghost{background:transparent;color:#e5e7eb;border:1px solid rgba(255,255,255,.18)}@media(max-width:520px){.post-create-card{padding:20px}}.postlist-container{min-height:calc(100vh - 80px);padding:40px 16px;max-width:600px;margin:0 auto}.postlist-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:14px}.postlist-header h2{margin:0;color:#e5e7eb;font-size:22px}.postlist-card{background:#1e293b;border-radius:14px;border:1px solid rgba(255,255,255,.06);box-shadow:0 10px 30px #00000040;overflow:hidden}.postlist-row{display:grid;grid-template-columns:1fr 140px 120px;gap:12px;padding:12px 14px;align-items:center}.postlist-row.head{background:#ffffff0a;color:#cbd5e1;font-size:13px;border-bottom:1px solid rgba(255,255,255,.08)}.postlist-row.item{width:100%;text-align:left;border:0;background:transparent;cursor:pointer;color:#e5e7eb}.postlist-row.item:hover{background:#ffffff0d}.col.title{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.col.author,.col.date{color:#cbd5e1;font-size:13px;text-align:right}.empty{padding:14px 12px;color:#cbd5e1;background:#ffffff0a;border:1px solid rgba(255,255,255,.08);border-radius:12px;margin-bottom:12px}.error{color:#fecaca;background:#ef44441f;border:1px solid rgba(239,68,68,.25);padding:10px 12px;border-radius:10px;font-size:13px;margin-bottom:12px}.btn{border:0;border-radius:10px;padding:10px 14px;font-size:14px;cursor:pointer}.btn.primary{background:#6366f1;color:#fff}.pagination{margin-top:14px;display:flex;gap:8px;align-items:center;justify-content:center;flex-wrap:wrap}.pagination .btn{padding:6px 12px;border-radius:10px;background:#0f172a8c;border:1px solid rgba(148,163,184,.2);color:#e5e7eb;font-size:13px;cursor:pointer;transition:all .15s ease}.pagination .btn:hover:not(:disabled){background:#1e293be6}.pagination .btn.page.active{background:#fff;color:#0f172a;font-weight:700}.pagination .btn:disabled{opacity:.4;cursor:not-allowed}.page-info{margin-left:6px;font-size:13px;color:#e2e8f0cc}.postlist-actions{display:flex;gap:10px;align-items:center}.searchbar{display:flex;gap:8px;align-items:center}.searchbar input{width:240px;height:36px;padding:0 12px;border-radius:10px;background:#0f172a8c;border:1px solid rgba(148,163,184,.2);color:#e5e7eb;outline:none}.searchbar input::placeholder{color:#e2e8f08c}@media(max-width:560px){.postlist-row{grid-template-columns:1fr 90px;grid-template-areas:"title title" "author date";row-gap:6px}.col.title{grid-area:title}.col.author{grid-area:author;text-align:left}.col.date{grid-area:date;text-align:right}}.post-detail-container{padding:60px 16px;max-width:600px;margin:0 auto;display:flex;flex-direction:column;gap:18px}.post-detail-card{width:100%;background:#1e293b;border-radius:14px;padding:26px;box-shadow:0 10px 30px #00000040;border:1px solid rgba(255,255,255,.06)}.post-detail-top{padding-bottom:14px;border-bottom:1px solid rgba(255,255,255,.08);margin-bottom:18px}.post-title{margin:0 0 10px;font-size:22px;color:#e5e7eb;line-height:1.25}.post-meta{display:flex;gap:12px;flex-wrap:wrap;font-size:13px}.meta-item{display:inline-flex;gap:8px;align-items:center;padding:6px 10px;border-radius:10px;background:#0f172ab3;border:1px solid rgba(255,255,255,.06)}.meta-label{color:#94a3b8}.meta-value{color:#e2e8f0}.post-content{white-space:pre-wrap;line-height:1.7;color:#e5e7eb;font-size:15px;padding:6px 2px 18px}.post-actions{display:flex;align-items:center;justify-content:space-between;gap:10px;padding-top:12px;border-top:1px solid rgba(255,255,255,.08)}.right-actions{display:flex;gap:10px;align-items:center}.btn{height:40px;padding:0 14px;border-radius:10px;cursor:pointer;border:1px solid transparent;display:inline-flex;align-items:center;justify-content:center;text-decoration:none;font-weight:600;font-size:14px}.btn.primary:hover{filter:brightness(1.05)}.btn.ghost:hover{background:#ffffff0f}.btn.danger{background:#ef4444;color:#fff}.btn.danger:hover{filter:brightness(1.05)}.comments-section{width:100%;padding:22px;border-radius:14px;background:#0f172a8c;border:1px solid rgba(148,163,184,.14);box-shadow:0 8px 24px #00000040}.post-detail-skeleton{color:#cbd5e1;padding:18px 4px}@media(max-width:520px){.post-actions{flex-direction:column;align-items:stretch}.right-actions{justify-content:flex-end;flex-wrap:wrap}.btn{width:100%}}.comment-item{padding:12px 14px;border-radius:12px;background:#0f172a8c;border:1px solid rgba(148,163,184,.14)}.comments-title{font-size:15px;font-weight:700;color:#e2e8f0f2;margin-bottom:10px;letter-spacing:-.2px}.comments-list{display:flex;flex-direction:column;gap:10px;margin-bottom:14px}.comment-row{display:grid;grid-template-columns:40px 1fr auto;gap:12px;align-items:center}.comment-author{font-size:13px;font-weight:600;color:#93c5fd;white-space:nowrap}.comment-content{font-size:14px;color:#e2e8f0f2;word-break:break-word}.comment-date{margin-top:10px;font-size:12px;color:#e2e8f073;padding-left:50px}.comment-item-actions{display:flex;gap:18px;align-items:center}.comment-item-actions button{background:none;border:none;padding:0;font-size:13px;font-weight:500;color:#e2e8f099;cursor:pointer}.comment-item-actions button:hover{text-decoration:underline}.comment-form{display:flex;gap:10px;align-items:center;padding:12px 14px;border-radius:12px;background:#02061740;border:1px solid rgba(148,163,184,.14)}.comment-input{flex:1;height:42px;padding:0 12px;border-radius:10px;border:1px solid rgba(148,163,184,.18);background:#0f172ad9;color:#e2e8f0f2;outline:none;font-size:14px}.comment-input::placeholder{color:#e2e8f073}.comment-input:focus{border-color:#6366f18c;box-shadow:0 0 0 3px #6366f12e}.comment-form button{background:none;border:none;padding:0;font-size:14px;font-weight:600;color:#93c5fd;cursor:pointer}.comment-form button:hover{text-decoration:underline}.comment-edit{grid-column:2 / -1;display:flex;align-items:center;gap:10px;min-width:0}.comment-edit-input{flex:1;height:34px;padding:0 10px;border-radius:10px;border:1px solid rgba(148,163,184,.18);background:#0f172ad9;color:#e2e8f0f2;outline:none;font-size:14px;min-width:0}.comment-edit-input:focus{border-color:#6366f18c;box-shadow:0 0 0 3px #6366f12e}.comment-edit-actions{display:flex;gap:12px;align-items:center;flex-shrink:0}.comment-edit-actions button{background:none;border:none;padding:0;font-size:13px;font-weight:600;color:#e2e8f0bf;cursor:pointer}.comment-edit-actions button:hover{text-decoration:underline}@media(max-width:520px){.comment-edit{grid-column:1 / -1}}@media(max-width:520px){.comment-row{grid-template-columns:40px 1fr;row-gap:6px}.comment-item-actions{justify-content:flex-end;grid-column:1 / -1;gap:14px}}.post-edit-container{padding:60px 16px;display:flex;justify-content:center}.post-edit-card{width:860px;max-width:100%;background:#1e293b;border-radius:14px;padding:26px;box-shadow:0 10px 30px #00000040;border:1px solid rgba(255,255,255,.06)}.post-edit-card h2{margin:0 0 16px;color:#e5e7eb}.post-edit-form{display:flex;flex-direction:column;gap:14px}.field{display:flex;flex-direction:column;gap:8px}.label{color:#94a3b8;font-size:13px}.post-edit-form input,.post-edit-form textarea{background:#0f172a;color:#e5e7eb;border:1px solid rgba(255,255,255,.12);border-radius:10px;padding:12px;outline:none}.post-edit-form textarea{resize:vertical;min-height:220px}.actions{display:flex;justify-content:flex-end;gap:10px;margin-top:10px;padding-top:12px;border-top:1px solid rgba(255,255,255,.08)}.btn{height:40px;padding:0 14px;border-radius:10px;cursor:pointer;border:1px solid transparent;display:inline-flex;align-items:center;justify-content:center;font-weight:600;font-size:14px}.btn.primary{background:#2563eb;color:#fff}.btn.ghost{background:transparent;color:#e5e7eb;border-color:#ffffff1f}.post-image{width:100%;height:320px;border-radius:12px;background:#0f172a;overflow:hidden;display:flex;align-items:center;justify-content:center}.post-image img{width:100%;height:100%;object-fit:contain;display:block}.post-edit-image{width:100%;height:150px;background:#0f172a;border-radius:12px;overflow:hidden;display:flex;align-items:center;justify-content:center}.post-edit-image img{max-width:360px;width:100%;height:100%;object-fit:contain}.toast-wrapper{position:fixed;top:50px;left:50%;transform:translate(-50%);z-index:9999;pointer-events:none}.toast{width:fit-content;max-width:360px;padding:12px 16px;background:#020617d1;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);color:#e5e7eb;text-align:center;border-radius:999px;border:1px solid rgba(96,165,250,.55);font-size:14px;font-weight:800;letter-spacing:.2px;box-shadow:0 14px 40px #0000008c,0 0 0 1px #60a5fa59,0 0 18px #60a5fa40;animation:toastIn .18s ease-out}@keyframes toastIn{0%{opacity:0;transform:translateY(-10px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}
