html,body,div,span,applet,object,iframe,h1,h2,h3,h4,h5,h6,p,blockquote,pre,a,abbr,acronym,address,big,cite,code,del,dfn,em,img,ins,kbd,q,s,samp,small,strike,strong,sub,sup,tt,var,b,u,i,center,dl,dt,dd,ol,ul,li,fieldset,form,label,legend,table,caption,tbody,tfoot,thead,tr,th,td,article,aside,canvas,details,embed,figure,figcaption,footer,header,hgroup,menu,nav,output,ruby,section,summary,time,mark,audio,video{margin:0;padding:0;border:0;font-size:100%;font:inherit;vertical-align:baseline}article,aside,details,figcaption,figure,footer,header,hgroup,menu,nav,section{display:block}body{line-height:1}ol,ul{list-style:none}blockquote,q{quotes:none}blockquote:before,blockquote:after,q:before,q:after{content:"";content:none}table{border-collapse:collapse;border-spacing:0}button{margin:0;padding:0;border:none;background:none;font:inherit;color:inherit;cursor:pointer;appearance:none;-webkit-appearance:none;-webkit-tap-highlight-color:transparent}:root{color-scheme:light;--bg: #f6f1e8;--bg-strong: #efe7d9;--surface: #ffffff;--surface-2: #f8f5ee;--text: #1b1e28;--muted: #5d6677;--accent: #0b6b6f;--accent-strong: #0a585b;--accent-warm: #f29f3a;--accent-cool: #2d7ff9;--border: #e3ddcf;--ring: rgba(11, 107, 111, .28);--shadow: 0 22px 48px rgba(24, 32, 46, .12);--shadow-soft: 0 12px 24px rgba(24, 32, 46, .08)}html{font-size:10px;line-height:1.4;font-weight:400}body{font-family:Space Grotesk,Sora,Pretendard,SUIT,Segoe UI,system-ui,-apple-system,sans-serif;background-color:var(--bg);color:var(--text);min-height:100vh}*,*:before,*:after{box-sizing:border-box}img{max-width:100%;display:block}a{color:inherit;text-decoration:none}input,textarea,select{font:inherit;color:inherit;border:none;background:none}main{display:block}.page{min-height:100vh;padding:6rem 2rem 8rem;position:relative;overflow:hidden;background:radial-gradient(120rem 70rem at 80% -10%,rgba(45,127,249,.16),transparent 60%),radial-gradient(90rem 60rem at -10% 20%,rgba(242,159,58,.2),transparent 55%),linear-gradient(135deg,var(--bg) 0%,var(--bg-strong) 100%)}.layout-center{width:100%;max-width:112rem;margin:0 auto;display:flex;flex-direction:column;gap:4.5rem}.project-header{display:flex;justify-content:space-between;align-items:center;gap:1.6rem}.project-header__eyebrow{display:block;font-size:1.2rem;font-weight:700;letter-spacing:.18rem;text-transform:uppercase;color:var(--accent);margin-bottom:.6rem}.project-header__title{display:block;font-size:2rem;font-weight:700;color:var(--text)}.project-header__link{flex:none}.hero{display:grid;grid-template-columns:minmax(0,1.2fr) minmax(0,.8fr);gap:3rem;align-items:center}.hero__text{display:flex;flex-direction:column;gap:1.6rem;animation:float-in .7s ease both}.hero__eyebrow{font-size:1.3rem;letter-spacing:.2rem;text-transform:uppercase;color:var(--muted);font-weight:600}.hero__title{font-size:clamp(3.4rem,5vw,5.6rem);font-weight:700;color:var(--text);line-height:1.1}.hero__subtitle{font-size:1.8rem;color:var(--muted);max-width:52rem;line-height:1.4}.hero__badges{display:flex;flex-wrap:wrap;gap:1rem}.badge{padding:.6rem 1.2rem;border-radius:999px;font-size:1.2rem;font-weight:600;background:#0b6b6f1f;color:var(--accent-strong);border:1px solid rgba(11,107,111,.2)}.hero__card{background:linear-gradient(145deg,#fff,#f7f2e8);border-radius:2.4rem;padding:2.8rem;box-shadow:var(--shadow);border:1px solid rgba(255,255,255,.7);display:flex;flex-direction:column;gap:1.4rem;animation:float-in .7s ease .1s both}.hero__cardLabel{font-size:1.2rem;font-weight:700;color:var(--accent);text-transform:uppercase;letter-spacing:.18rem}.hero__cardTitle{font-size:2.4rem;font-weight:700;color:var(--text)}.hero__cardText{font-size:1.5rem;color:var(--muted);line-height:1.4}.hero__cardMeta{display:flex;flex-wrap:wrap;gap:.8rem;font-size:1.2rem;font-weight:600;color:var(--accent-cool)}.panel{background:var(--surface);border-radius:2.6rem;padding:2.8rem;box-shadow:var(--shadow-soft);border:1px solid var(--border)}.panel__header{display:flex;justify-content:space-between;align-items:flex-end;gap:2rem;margin-bottom:2.4rem}.panel__title{font-size:2.4rem;font-weight:700;color:var(--text)}.panel__subtitle{font-size:1.4rem;color:var(--muted);margin-top:.6rem}.panel__hint{font-size:1.3rem;color:var(--muted);background:var(--surface-2);padding:.8rem 1.4rem;border-radius:999px;border:1px solid var(--border)}.stack{display:flex;flex-direction:column;gap:1.6rem;padding:2rem 2.2rem}.stack__header{display:flex;justify-content:space-between;align-items:flex-end;gap:1.6rem}.stack__title{font-size:2rem;font-weight:700;color:var(--text)}.stack__subtitle{margin-top:.5rem;font-size:1.35rem;color:var(--muted);max-width:72rem}.stack__summary{display:flex;flex-wrap:wrap;justify-content:flex-end;gap:.8rem}.stack__summaryTag{padding:.6rem 1rem;border-radius:999px;font-size:1.2rem;font-weight:600;color:var(--accent-strong);background:#0b6b6f1a;border:1px solid rgba(11,107,111,.18)}.stack__grid{display:flex;flex-wrap:wrap;gap:1rem}.stack__group{flex:1 1 30rem;min-width:0;padding:1.4rem 1.5rem;border-radius:1.8rem;border:1px solid var(--border);background:linear-gradient(180deg,#fffc,#f8f5eeeb)}.stack__groupHeader{margin-bottom:1rem}.stack__groupTitle{font-size:1.55rem;font-weight:700;color:var(--text)}.stack__list{list-style:none;margin:0;padding:0;display:flex;flex-wrap:wrap;gap:.8rem}.stack__item{display:flex;gap:.8rem;align-items:center;padding:.8rem 1rem;border-radius:999px;background:#ffffffb8;border:1px solid rgba(227,221,207,.9)}.stack__icon{width:2.8rem;height:2.8rem;flex:none;display:grid;place-items:center;border-radius:999px;background:#fff;box-shadow:inset 0 0 0 1px #e3ddcfb8}.stack__icon svg{width:1.8rem;height:1.8rem;display:block}.stack__itemName{font-size:1.25rem;font-weight:700;color:var(--text);line-height:1}.loading{width:9rem;height:9rem;margin:6rem auto;display:block;filter:drop-shadow(0 10px 12px rgba(24,32,46,.14))}.error{margin:6rem auto;display:flex;align-items:center;flex-direction:column;gap:1.6rem;padding:2.4rem;border-radius:2rem;border:1px solid rgba(220,91,78,.3);background:#dc5b4e14}.error__img{width:8rem;height:8rem}.error__text{font-size:1.6rem;color:#b04a3f;text-align:center}.nodata{margin:6rem auto;text-align:center;padding:2.4rem;border-radius:2rem;background:var(--surface-2);border:1px dashed var(--border)}.nodata__text{font-size:1.6rem;color:var(--muted)}@keyframes float-in{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}@media(max-width:960px){.project-header{align-items:flex-start;flex-direction:column}.hero{grid-template-columns:1fr}.stack__header{flex-direction:column;align-items:flex-start}.stack__summary{justify-content:flex-start}.panel__header{flex-direction:column;align-items:flex-start}}@media(max-width:600px){.page{padding:4rem 1.6rem 6rem}.hero__card{padding:2.2rem}.panel{padding:2rem}.stack__group{flex-basis:100%;padding:1.2rem 1.3rem}.stack__item{padding:.75rem .95rem}}button,.button{display:inline-block;padding:1rem 1.8rem;background:linear-gradient(135deg,var(--accent) 0%,#128c91 100%);color:#fff;border-radius:999px;font-weight:600;letter-spacing:.02em;transition:background-color .15s ease,transform .12s ease,box-shadow .2s ease;box-shadow:0 10px 18px #0b6b6f33}button.line,.button.line{background:#fff;border:1px solid var(--border);color:var(--text);box-shadow:none}button:hover,.button:hover{background-color:var(--accent-strong);transform:translateY(-1px);box-shadow:0 12px 20px #0b6b6f3d}button.line:hover,.button.line:hover{background-color:var(--surface-2);transform:translateY(-1px)}button:active,.button:active{transform:scale(.98);box-shadow:none}button:focus-visible,.button:focus-visible{outline:3px solid var(--ring);outline-offset:2px}button:disabled,.button:disabled{background:#cfe3e4;color:#6f8a8b;cursor:not-allowed;transform:none;box-shadow:none}button.line:disabled,.button.line:disabled{background-color:#f6f2ea;border-color:var(--border);color:#8c95a4}button:disabled:hover,button.line:disabled:hover,button:disabled:active,button.line:disabled:active,.button:disabled:hover,.button.line:disabled:hover,.button:disabled:active,.button.line:disabled:active{background-color:inherit;transform:none}.users{margin-top:2rem}.users__list{display:flex;flex-direction:column;gap:1.6rem}.users__head{display:flex;justify-content:space-between;align-items:center;gap:1.6rem;padding:1.6rem 2rem;border-radius:1.6rem;background:var(--surface-2);border:1px solid var(--border)}.users__body{margin-top:2rem}.users__result{font-size:1.5rem;font-weight:600;color:var(--muted)}.users__actions{flex-shrink:0;display:flex;gap:1rem;flex-wrap:wrap}.users__newForm{margin-top:2rem}.userItem{list-style:none;background:var(--surface);border-radius:2rem;border:1px solid var(--border);box-shadow:var(--shadow-soft);padding:2rem;transition:transform .2s ease,box-shadow .2s ease,border-color .2s ease;animation:fade-up .4s ease both}.userItem.is-editing{border-color:#0b6b6f80;box-shadow:0 16px 28px #0b6b6f24}.userItem.is-selecting{background:#0b6b6f0a}.userItem:hover{transform:translateY(-2px);box-shadow:0 18px 32px #18202e1f}.userItem__box{display:flex;justify-content:space-between;align-items:center;gap:2rem}.userItem__actions{flex-shrink:0;margin-left:2rem}.userItem__info{display:flex;align-items:center;flex-grow:1}.userItem__profileWrap{position:relative;margin-right:2rem}.userItem__profile{width:8rem;height:8rem;border-radius:100%;overflow:hidden;flex-shrink:0;border:2px solid rgba(11,107,111,.15);background:#0b6b6f14}.userItem__profile img{width:100%;height:100%;object-fit:cover}.userItem__profileBtn{margin-top:1rem}.userItem__profileBtns{display:flex;flex-direction:column}.userItem__texts{display:flex;flex-direction:column;gap:.5rem;flex-grow:1}.userItem__name{font-size:1.8rem;font-weight:600;color:var(--text)}.userItem__email{font-size:1.4rem;color:var(--muted)}.userItem__actions{display:flex;gap:1rem;flex-wrap:wrap}.userItem__editer{display:flex;flex-direction:column;gap:1rem;width:100%}.userItem__checkbox{margin-right:1rem}.userItem__checkbox input{width:1.8rem;height:1.8rem;accent-color:var(--accent)}.userItem__profileName{font-size:1.2rem;font-weight:500;display:block;margin-top:1rem}.userItem__checkLabel{display:flex;flex-direction:column;gap:.5rem;cursor:pointer}.userForm{background:var(--surface);border-radius:2rem;border:1px solid var(--border);box-shadow:var(--shadow-soft);padding:2rem}.userForm__box{display:flex;align-items:center;gap:2rem}.userForm__profileWrap{position:relative;margin-right:2rem;flex-shrink:0}.userForm__profile{width:8rem;height:8rem;border-radius:100%;overflow:hidden;flex-shrink:0;border:2px solid rgba(11,107,111,.15);background:#0b6b6f14}.userForm__profile img{width:100%;height:100%;object-fit:cover}.userForm__profileBtn{margin-top:1rem}.userForm__profileBtns{display:flex;flex-direction:column}.userForm__editer{display:flex;flex-direction:column;gap:1rem;flex-grow:1;width:100%}.userForm__profileName{font-size:1.2rem;font-weight:500;display:block;margin-top:1rem}.input-group{width:100%;display:flex;flex-direction:column;gap:.4rem}.input-group input{padding:1rem 1.2rem;border-radius:1.2rem;border:1px solid transparent;background:var(--surface-2);transition:border-color .2s ease,box-shadow .2s ease,background .2s ease}.input-group input:focus{border-color:var(--accent);box-shadow:0 0 0 4px var(--ring);background:#fff;outline:none}.error-msg{display:block;font-size:1.2rem;color:#b04a3f;margin-top:.5rem}@keyframes fade-up{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}@media(max-width:900px){.users__head,.userItem__box,.userForm__box{flex-direction:column;align-items:flex-start}.userItem__actions{margin-left:0}}
