.app-shell{min-height:100vh}.shell-main{width:min(1040px,100% - 32px);margin:0 auto;padding:24px 0 56px}@media (width<=768px){.shell-main{width:min(100%,100% - 24px);padding:20px 0 40px}}.login-page{background:radial-gradient(circle at top,#3b82f62e,#0000 32%),linear-gradient(#0a102033 0%,#0f172a1a 100%);place-items:center;min-height:calc(100vh - 104px);padding:12px 0;display:grid}.login-card{-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);box-sizing:border-box;background:#0f172ad6;border:1px solid #94a3b829;border-radius:20px;width:min(100%,440px);padding:28px 24px 24px;box-shadow:0 16px 36px #02061747,0 6px 18px #11182724}.login-copy{text-align:left;margin-bottom:20px}.login-eyebrow{letter-spacing:.18em;text-transform:uppercase;color:#60a5fa;margin-bottom:10px;font-size:13px;font-weight:700}.login-copy h1{color:#f8fafc;margin:0 0 10px;font-size:clamp(1.6rem,3vw,2.1rem);line-height:1.1}.login-description{color:#94a3b8;font-size:14px;line-height:1.6}.login-form{flex-direction:column;gap:14px;display:flex}.auth-mode-switch{grid-template-columns:repeat(2,minmax(0,1fr));gap:8px;margin-bottom:16px;display:grid}.auth-mode-switch__button{color:#cbd5e1;cursor:pointer;background:#0f172a8a;border:1px solid #94a3b82e;border-radius:12px;min-height:40px;font-size:14px}.auth-mode-switch__button.is-active{color:#fff;background:#2563eb29;border-color:#60a5fa59}.login-field{text-align:left;flex-direction:column;gap:6px;display:flex}.login-field span{color:#e2e8f0;font-size:13px;font-weight:600}.login-field input{color:#f8fafc;box-sizing:border-box;background:#0f172ab8;border:1px solid #94a3b82e;border-radius:12px;height:46px;padding:0 14px;font-size:14px;transition:border-color .2s,box-shadow .2s,transform .2s}.login-field input::placeholder{color:#94a3b8}.login-field input:focus{border-color:#60a5fab3;outline:none;transform:translateY(-1px);box-shadow:0 0 0 4px #3b82f624}.login-button{color:#fff;letter-spacing:.01em;cursor:pointer;background:linear-gradient(135deg,#2563eb 0%,#7c3aed 100%);border:0;border-radius:14px;height:46px;margin-top:4px;font-size:14px;font-weight:600;transition:transform .2s,box-shadow .2s,filter .2s;box-shadow:0 10px 20px #2563eb33}.login-button:hover{filter:saturate(1.05);transform:translateY(-2px)}.login-button:focus-visible{outline-offset:3px;outline:3px solid #3b82f63d}.login-button:active{transform:translateY(0)}.login-actions{flex-direction:column;gap:10px;display:flex}.login-skip-button{color:#cbd5e1;cursor:pointer;background:#0f172a8a;border:1px solid #94a3b838;border-radius:14px;justify-content:center;align-items:center;height:44px;font-size:14px;font-weight:600;transition:transform .2s,border-color .2s,background-color .2s;display:inline-flex}.login-skip-button:hover{background:#1e293bc7;border-color:#60a5fa59;transform:translateY(-1px)}.login-skip-button:focus-visible{outline-offset:3px;outline:3px solid #3b82f63d}@media (width<=640px){.login-page{padding:12px 16px}.login-card{border-radius:18px;padding:22px 18px 20px}}:root{color:#d7ddf0;font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:radial-gradient(circle at top,#234eff3d,#0000 24%),linear-gradient(#0a1020 0%,#0f172a 44%,#111827 100%);font-family:Space Grotesk,Noto Sans KR,Segoe UI,sans-serif;font-weight:400;line-height:1.5}*{box-sizing:border-box}html{scroll-behavior:smooth}body{min-width:320px;min-height:100vh;margin:0}body,button,input,textarea{font:inherit}a{color:inherit;text-decoration:none}button{border:0}img{max-width:100%;display:block}#root{min-height:100vh}h1,h2,h3,p{margin:0}.site-header{z-index:10;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);background:#080e1eb3;border-bottom:1px solid #94a3b824;position:sticky;top:0}.site-header__inner{justify-content:space-between;align-items:center;gap:16px;width:min(1120px,100% - 32px);height:64px;margin:0 auto;display:flex}.brand{align-items:center;gap:10px;display:inline-flex}.brand__mark{color:#eff6ff;background:linear-gradient(135deg,#2563eb 0%,#7c3aed 100%);border-radius:12px;place-items:center;width:38px;height:38px;font-size:12px;font-weight:700;display:grid;box-shadow:0 10px 20px #2563eb33}.brand__text{flex-direction:column;gap:2px;display:flex}.brand__text strong{color:#f8fafc;font-size:16px}.brand__text small{color:#94a3b8;font-size:12px}.site-nav{align-items:center;gap:8px;display:flex}.site-nav__auth{align-items:center;gap:10px;display:flex}.site-nav__status,.site-nav__user{color:#cbd5e1;background:#1e293bb8;border-radius:999px;padding:8px 12px;font-size:13px}.site-nav__button{color:#eff6ff;cursor:pointer;background:#3b82f62e;border-radius:999px;min-height:36px;padding:0 14px}.site-nav__link{color:#cbd5e1;border-radius:999px;padding:8px 12px;font-size:14px;transition:background-color .2s,color .2s,transform .2s}.site-nav__link:hover,.site-nav__link.is-active{color:#fff;background:#3b82f62e}.site-nav__link:hover{transform:translateY(-1px)}.page{flex-direction:column;gap:18px;display:flex}.page--detail{gap:16px}.hero-panel,.panel,.detail-card,.status-panel,.empty-state{background:#0f172abd;border:1px solid #94a3b824;border-radius:20px;box-shadow:0 16px 40px #0206173d,inset 0 1px #ffffff08}.hero-panel{background:radial-gradient(circle at 100% 0,#38bdf829,#0000 24%),linear-gradient(135deg,#2563eb29,#7c3aed1f),#0f172ad1;padding:24px}.hero-panel h1,.panel h1,.detail-card h1{color:#f8fafc;font-size:clamp(1.6rem,3vw,2.4rem);line-height:1.12}.section-heading{justify-content:space-between;align-items:flex-end;gap:16px;display:flex}.section-heading--compact{margin-bottom:20px}.section-heading h2{color:#f8fafc;font-size:1.3rem}.pagination-summary,.pagination-controls{flex-wrap:wrap;align-items:center;gap:12px;display:flex}.eyebrow{color:#60a5fa;text-transform:uppercase;letter-spacing:.14em;margin-bottom:6px;font-size:11px;font-weight:700}.muted{color:#94a3b8;max-width:60ch;font-size:14px}.status-panel,.empty-state{padding:20px}.status-panel--error,.feedback.error{color:#fecaca;background:#7f1d1d2e;border-color:#ef444433}.feedback{border-radius:12px;padding:10px 12px;font-size:13px}.feedback.success{color:#bbf7d0;background:#15803d2e;border:1px solid #22c55e3d}.feedback.helper{color:#bfdbfe;background:#1e40af29;border:1px solid #60a5fa33}.post-grid{grid-template-columns:repeat(3,minmax(0,1fr));gap:14px;display:grid}.post-card{background:#0f172acc;border:1px solid #94a3b824;border-radius:18px;transition:transform .22s,border-color .22s,box-shadow .22s;overflow:hidden}.post-card:hover{border-color:#60a5fa57;transform:translateY(-2px);box-shadow:0 14px 28px #080f203d}.post-card__media{aspect-ratio:16/10;background:linear-gradient(135deg,#2563eb4d,#7c3aed33)}.post-card__image,.detail-image,.image-preview img{object-fit:cover;width:100%;height:100%}.post-card__placeholder,.detail-image--placeholder,.image-preview__placeholder{color:#dbeafe;background:radial-gradient(circle,#3b82f63d,#0000 32%),linear-gradient(135deg,#2563eb47,#7c3aed38);place-items:center;width:100%;height:100%;min-height:180px;display:grid}.post-card__placeholder span{letter-spacing:.2em;background:#ffffff14;border-radius:999px;padding:12px 16px;font-size:12px;font-weight:700}.post-card__body{flex-direction:column;gap:10px;padding:16px;display:flex}.post-card__author{color:#60a5fa;font-size:13px}.post-card h3{color:#f8fafc;font-size:1.05rem}.post-card__preview{color:#cbd5e1;min-height:54px;font-size:14px}.tag-row{flex-wrap:wrap;gap:8px;display:flex}.tag-pill{color:#bfdbfe;background:#2563eb29;border-radius:999px;padding:4px 8px;font-size:12px}.post-card__meta,.detail-meta{color:#94a3b8;flex-wrap:wrap;gap:10px;font-size:13px;display:flex}.detail-card{grid-template-columns:minmax(0,1.7fr) minmax(280px,.7fr);gap:0;display:grid;overflow:hidden}.detail-card__content{flex-direction:column;gap:18px;padding:28px 30px;display:flex}.detail-card__media{min-height:100%}.detail-image{height:100%;min-height:300px}.detail-content{color:#dbe4f0;letter-spacing:.01em;white-space:pre-wrap;max-width:76ch;font-size:18px;line-height:1.9}.detail-actions{flex-wrap:wrap;align-items:center;gap:14px;display:flex}.panel{padding:22px}.panel--comments{align-self:flex-start;width:min(100%,760px);max-height:420px;padding:16px 18px;overflow-y:auto}.panel--comments .section-heading--compact{margin-bottom:14px}.panel--comments .section-heading h2{font-size:1.1rem}.panel--comments .comment-form{gap:10px}.panel--comments .field textarea{min-height:88px}.panel--comments::-webkit-scrollbar{width:10px}.panel--comments::-webkit-scrollbar-thumb{background:#60a5fa47;border-radius:999px}.panel__header{flex-direction:column;gap:8px;margin-bottom:18px;display:flex}.post-form,.comment-form,.login-form{flex-direction:column;gap:14px;display:flex}.field{flex-direction:column;gap:8px;display:flex}.field span{color:#e2e8f0;font-size:13px;font-weight:600}.field input,.field textarea{color:#f8fafc;background:#0f172ab8;border:1px solid #94a3b82e;border-radius:14px;width:100%;padding:12px 14px;transition:border-color .2s,box-shadow .2s,transform .2s}.field input:focus,.field textarea:focus{border-color:#60a5fab3;outline:none;transform:translateY(-1px);box-shadow:0 0 0 4px #3b82f624}.field textarea{resize:vertical;min-height:120px}.field input:disabled,.field textarea:disabled,.primary-button:disabled,.secondary-button:disabled,.like-button:disabled,.login-button:disabled,.ghost-button:disabled{opacity:.7;cursor:not-allowed}.file-input{padding:12px}.image-preview{background:#0f172a70;border:1px dashed #94a3b83d;border-radius:16px;min-height:200px;overflow:hidden}.primary-button,.secondary-button,.like-button,.login-button,.ghost-button{cursor:pointer;border-radius:14px;justify-content:center;align-items:center;gap:10px;min-height:44px;padding:0 16px;font-size:14px;font-weight:600;transition:transform .2s,filter .2s,box-shadow .2s;display:inline-flex}.primary-button,.login-button{color:#eff6ff;background:linear-gradient(135deg,#2563eb 0%,#7c3aed 100%);box-shadow:0 18px 40px #2563eb3d}.secondary-button,.like-button{color:#eff6ff;background:#1e293beb;border:1px solid #60a5fa2e}.ghost-button{color:#cbd5e1;background:0 0;border:1px solid #94a3b82e}.ghost-button.danger{color:#fecaca;border-color:#f8717147}.primary-button:hover,.secondary-button:hover,.like-button:hover,.login-button:hover{filter:brightness(1.04);transform:translateY(-2px)}.like-button.is-liked{background:#2563eb2e;border-color:#60a5fa6b}.comment-list{flex-direction:column;gap:10px;display:flex}.comment-item{background:#0f172a99;border:1px solid #94a3b824;border-radius:16px;padding:12px 13px}.comment-item__header{color:#94a3b8;justify-content:space-between;align-items:center;gap:12px;margin-bottom:6px;font-size:13px;display:flex}.comment-item__header strong{color:#f8fafc}.comment-item__editor{flex-direction:column;gap:12px;display:flex}.comment-item__textarea{color:#f8fafc;background:#0f172ab3;border:1px solid #94a3b82e;border-radius:14px;width:100%;min-height:76px;padding:10px 12px}.comment-item__actions{flex-wrap:wrap;gap:10px;margin-top:12px;display:flex}.empty-state--compact{padding:20px}@media (width<=960px){.post-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.detail-card{grid-template-columns:1fr}}@media (width<=768px){.site-header__inner{flex-direction:column;align-items:flex-start;width:min(100%,100% - 24px);height:auto;padding:16px 0}.site-nav{width:100%;overflow-x:auto}.site-nav__auth{width:100%}.hero-panel,.panel,.detail-card__content,.status-panel,.empty-state{padding:18px}.post-grid{grid-template-columns:1fr}}
