.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--spacing-2);font-weight:var(--font-weight-medium);border-radius:var(--radius-md);transition:all var(--transition-base);cursor:pointer;white-space:nowrap;-webkit-user-select:none;user-select:none}.btn--primary{background-color:var(--color-accent-orange);color:#fff;box-shadow:var(--shadow-sm)}.btn--primary:hover:not(:disabled){background-color:var(--color-accent-orange-dark);box-shadow:var(--shadow-base);transform:translateY(-1px)}.btn--primary:active:not(:disabled){transform:translateY(0);box-shadow:var(--shadow-sm)}.btn--secondary{background-color:var(--color-primary-blue);color:#fff;box-shadow:var(--shadow-sm)}.btn--secondary:hover:not(:disabled){background-color:var(--color-primary-blue-dark);box-shadow:var(--shadow-base);transform:translateY(-1px)}.btn--outline{background-color:transparent;color:var(--color-primary-blue);border:2px solid var(--color-primary-blue)}.btn--outline:hover:not(:disabled){background-color:var(--color-primary-blue);color:#fff}.btn--ghost{background-color:transparent;color:var(--color-text)}.btn--ghost:hover:not(:disabled){background-color:var(--color-bg-hover)}.btn--danger{background-color:var(--color-error);color:#fff}.btn--danger:hover:not(:disabled){background-color:var(--color-error-light)}.btn--small{padding:var(--spacing-2) var(--spacing-4);font-size:var(--font-size-sm);min-height:36px}.btn--medium{padding:var(--spacing-3) var(--spacing-6);font-size:var(--font-size-base);min-height:44px}.btn--large{padding:var(--spacing-4) var(--spacing-8);font-size:var(--font-size-lg);min-height:52px}.btn--full-width{width:100%}.btn--disabled{opacity:.5;cursor:not-allowed;pointer-events:none}.btn--loading{cursor:wait;pointer-events:none}.spinner--small{width:16px;height:16px;border-width:2px}@media(pointer:coarse){.btn{min-height:48px}}.header{position:sticky;top:0;z-index:var(--z-sticky);background-color:var(--color-bg);border-bottom:1px solid var(--color-border);box-shadow:var(--shadow-sm)}.header__content{display:flex;align-items:center;justify-content:space-between;height:64px}.header__logo{display:flex;align-items:center;gap:var(--spacing-2)}.header__logo-img{height:1.5em;width:auto;border-radius:var(--radius-sm)}.header__logo h1{font-size:var(--font-size-xl);font-weight:var(--font-weight-bold);color:var(--color-primary-blue);margin:0}.header__logo:hover h1{color:var(--color-accent-orange)}.header__nav--desktop{display:none;align-items:center;gap:var(--spacing-6)}.header__nav-link{font-weight:var(--font-weight-medium);color:var(--color-text);transition:color var(--transition-fast)}.header__nav-link:hover{color:var(--color-primary-blue)}.header__nav-link.active{color:var(--color-primary-blue);font-weight:var(--font-weight-semibold)}.header__hamburger{display:flex;flex-direction:column;justify-content:space-around;width:30px;height:30px;background:transparent;border:none;cursor:pointer;padding:4px;z-index:calc(var(--z-sticky) + 1)}.header__hamburger span{display:block;width:100%;height:2px;background-color:var(--color-text);border-radius:var(--radius-full);transition:all .3s cubic-bezier(.4,0,.2,1)}.header__hamburger.active span:nth-child(1){transform:translateY(8px) rotate(45deg)}.header__hamburger.active span:nth-child(2){opacity:0;transform:translate(-10px)}.header__hamburger.active span:nth-child(3){transform:translateY(-8px) rotate(-45deg)}.header__mobile-menu{position:absolute;top:100%;left:0;right:0;background-color:var(--color-bg);border-bottom:1px solid var(--color-border);box-shadow:var(--shadow-md);max-height:0;overflow:hidden;transition:max-height .3s ease-in-out,opacity .2s ease;opacity:0;pointer-events:none}.header__mobile-menu.active{max-height:500px;opacity:1;pointer-events:auto}.header__nav--mobile{display:flex;flex-direction:column;padding:var(--spacing-4) var(--spacing-6)}.header__nav--mobile .header__nav-link{display:block;padding:var(--spacing-4) 0;font-size:var(--font-size-lg);border-bottom:1px solid var(--color-bg-subtle);transition:color var(--transition-fast)}.header__nav--mobile .header__nav-link:last-child{border-bottom:none}.header__auth-group{margin-top:var(--spacing-4);display:flex;flex-direction:column;gap:var(--spacing-3);padding-top:var(--spacing-4);border-top:2px solid var(--color-bg-subtle)}@media(min-width:768px){.header__nav--desktop{display:flex}.header__hamburger,.header__mobile-menu{display:none}}.footer{background-color:var(--color-bg-subtle);border-top:1px solid var(--color-border);padding:var(--spacing-12) 0 var(--spacing-6);margin-top:auto}.footer__content{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:var(--spacing-8);margin-bottom:var(--spacing-8)}.footer__section{display:flex;flex-direction:column;gap:var(--spacing-3)}.footer__brand-wrapper{display:flex;align-items:center;gap:var(--spacing-2)}.footer__logo-img{height:1.5em;width:auto;border-radius:var(--radius-sm)}.footer__brand{font-size:var(--font-size-xl);font-weight:var(--font-weight-bold);color:var(--color-primary-blue);margin:0}.footer__tagline{color:var(--color-subtext);font-size:var(--font-size-sm);line-height:var(--line-height-relaxed)}.footer__heading{font-size:var(--font-size-base);font-weight:var(--font-weight-semibold);color:var(--color-text);margin:0}.footer__address{font-style:normal;color:var(--color-subtext);font-size:var(--font-size-sm);line-height:var(--line-height-relaxed)}.footer__links{display:flex;flex-direction:column;gap:var(--spacing-2)}.footer__link{color:var(--color-subtext);font-size:var(--font-size-sm);transition:color var(--transition-fast)}.footer__link:hover{color:var(--color-primary-blue)}.footer__bottom{padding-top:var(--spacing-6);border-top:1px solid var(--color-border);text-align:center}.footer__copyright{color:var(--color-subtext);font-size:var(--font-size-sm)}@media(max-width:768px){.footer__content{grid-template-columns:1fr;gap:var(--spacing-6)}}.layout{display:flex;flex-direction:column;min-height:100vh}.layout__main{flex:1;padding:var(--spacing-8) 0}@media(max-width:768px){.layout__main{padding:var(--spacing-6) 0}}.error-boundary{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:var(--spacing-8);background-color:var(--color-bg-subtle)}.error-boundary__content{max-width:600px;text-align:center}.error-boundary__icon{font-size:5rem;margin-bottom:var(--spacing-6)}.error-boundary__title{font-size:var(--font-size-3xl);margin-bottom:var(--spacing-4)}.error-boundary__message{font-size:var(--font-size-lg);color:var(--color-subtext);margin-bottom:var(--spacing-8);line-height:var(--line-height-relaxed)}.error-boundary__actions{display:flex;gap:var(--spacing-4);justify-content:center;flex-wrap:wrap}.error-boundary__details{margin:var(--spacing-8) 0;text-align:left;background-color:var(--color-bg);border-radius:var(--radius-md);padding:var(--spacing-4)}.error-boundary__details summary{cursor:pointer;font-weight:var(--font-weight-semibold);margin-bottom:var(--spacing-3)}.error-boundary__stack{font-family:Courier New,monospace;font-size:var(--font-size-xs);color:var(--color-error);overflow-x:auto;white-space:pre-wrap;word-break:break-word}.card{background-color:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius-lg);overflow:hidden;transition:all var(--transition-base)}.card--default{box-shadow:var(--shadow-sm)}.card--elevated{box-shadow:var(--shadow-md)}.card--hoverable:hover{box-shadow:var(--shadow-lg);transform:translateY(-2px)}.card--clickable{cursor:pointer}.card--clickable:active{transform:translateY(0)}.lazy-image{position:relative;overflow:hidden;background-color:var(--color-bg-subtle)}.lazy-image__img{width:100%;height:100%;object-fit:cover;opacity:0;transition:opacity var(--transition-slow)}.lazy-image__img--visible{opacity:1}.lazy-image__placeholder{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center}.lazy-image__skeleton{width:100%;height:100%;background:linear-gradient(90deg,var(--color-bg-subtle) 0%,#e0e0e0 50%,var(--color-bg-subtle) 100%);background-size:200% 100%;animation:skeleton-loading 1.5s ease-in-out infinite}@keyframes skeleton-loading{0%{background-position:200% 0}to{background-position:-200% 0}}.lazy-image__error{display:flex;flex-direction:column;align-items:center;justify-content:center;width:100%;height:100%;min-height:200px;color:var(--color-subtext);background-color:var(--color-bg-subtle)}.lazy-image__error span{font-size:3rem;margin-bottom:var(--spacing-3)}.lazy-image__error p{font-size:var(--font-size-sm)}.hero{background:linear-gradient(135deg,#04a9e3,#3bc0f0);color:#fff;padding:var(--spacing-16) 0;text-align:center}.hero__content{max-width:800px;margin:0 auto}.hero__title{font-size:var(--font-size-4xl);font-weight:var(--font-weight-bold);margin-bottom:var(--spacing-6);line-height:var(--line-height-tight)}.hero__subtitle{font-size:var(--font-size-lg);line-height:var(--line-height-relaxed);margin-bottom:var(--spacing-8);opacity:.95}.hero__actions{display:flex;gap:var(--spacing-4);justify-content:center;flex-wrap:wrap}.home-section{padding:var(--spacing-12) 0;width:100%;overflow:hidden}.home-section--gray{background-color:var(--color-bg-subtle)}.section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-8)}.section-title{font-size:var(--font-size-3xl);font-weight:var(--font-weight-bold);color:var(--color-text)}.section-link{color:var(--color-primary-blue);font-weight:var(--font-weight-medium);transition:color var(--transition-fast)}.section-link:hover{color:var(--color-accent-orange)}.notices-list{display:flex;flex-direction:column;gap:var(--spacing-4)}.notice-item__content{padding:var(--spacing-6);display:flex;justify-content:space-between;align-items:flex-start;gap:var(--spacing-4)}.notice-item__title{font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold);color:var(--color-text);margin-bottom:var(--spacing-2)}.notice-item__preview{font-size:var(--font-size-sm);color:var(--color-subtext);line-height:var(--line-height-relaxed)}.gallery-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:var(--spacing-6);width:100%;box-sizing:border-box}.gallery-item__image{aspect-ratio:1;overflow:hidden;background-color:var(--color-bg-subtle);position:relative}.gallery-item__image img{width:100%;height:100%;object-fit:cover;transition:transform var(--transition-slow)}.gallery-item:hover .gallery-item__image img{transform:scale(1.05)}.gallery-item__info{padding:var(--spacing-4)}.gallery-item__title{font-size:var(--font-size-base);font-weight:var(--font-weight-semibold);color:var(--color-text);margin-bottom:var(--spacing-2);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.gallery-item__artist{font-size:var(--font-size-sm);color:var(--color-subtext);margin-bottom:var(--spacing-2)}.gallery-item__meta{font-size:var(--font-size-sm);color:var(--color-subtext)}.loading{display:flex;flex-direction:column;align-items:center;gap:var(--spacing-4);padding:var(--spacing-12);color:var(--color-subtext)}.empty-state{text-align:center;padding:var(--spacing-12);color:var(--color-subtext);font-size:var(--font-size-lg)}@media(max-width:768px){.hero{padding:var(--spacing-10) 0}.hero__title{font-size:var(--font-size-2xl)}.home-section{padding:var(--spacing-8) 0}.gallery-grid{grid-template-columns:repeat(2,1fr);gap:var(--spacing-3)}.gallery-item__info{padding:var(--spacing-3)}.gallery-item__title{font-size:var(--font-size-sm)}}@media(max-width:480px){.gallery-grid{gap:var(--spacing-2)}}.input-wrapper{display:flex;flex-direction:column;gap:var(--spacing-2)}.input-wrapper--full-width{width:100%}.input-label{font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-text)}.input-required{color:var(--color-error);margin-left:var(--spacing-1)}.input{padding:var(--spacing-3) var(--spacing-4);font-size:var(--font-size-base);border:1px solid var(--color-border);border-radius:var(--radius-md);background-color:var(--color-bg);transition:all var(--transition-base);min-height:44px}.input:focus{outline:none;border-color:var(--color-primary-blue);box-shadow:0 0 0 3px #04a9e31a}.input::placeholder{color:var(--color-subtext)}.input--error{border-color:var(--color-error)}.input--error:focus{border-color:var(--color-error);box-shadow:0 0 0 3px #ef44441a}.input--full-width{width:100%}.input-error-message{font-size:var(--font-size-sm);color:var(--color-error)}.input-helper-text{font-size:var(--font-size-sm);color:var(--color-subtext)}@media(pointer:coarse){.input{min-height:48px;font-size:16px}}.gallery-page{padding:var(--spacing-8) 0;min-height:80vh;overflow-x:hidden}.gallery-page__header{text-align:center;margin-bottom:var(--spacing-10)}.gallery-page__header h1{font-size:var(--font-size-4xl);margin-bottom:var(--spacing-3);font-weight:800;letter-spacing:-.02em}.gallery-page__subtitle{color:var(--color-subtext);font-size:var(--font-size-lg);font-weight:500}.gallery-page__controls{display:flex;gap:var(--spacing-4);align-items:center;margin-bottom:var(--spacing-8);flex-wrap:wrap;background-color:var(--color-bg-primary);padding:var(--spacing-2) 0}.gallery-search{display:flex;gap:var(--spacing-3);flex:1;min-width:300px;position:relative}.gallery-filter{display:flex;background-color:var(--color-bg-subtle);padding:4px;border-radius:var(--radius-lg);gap:0}.gallery-filter button{border:none;background:transparent;border-radius:var(--radius-md);padding:var(--spacing-2) var(--spacing-4);font-size:var(--font-size-sm);font-weight:600;color:var(--color-subtext);transition:all .2s ease}.gallery-filter button.button--primary{background-color:var(--color-bg-primary);color:var(--color-text-primary);box-shadow:0 1px 3px #0000001a}.gallery-filter button:hover:not(.button--primary){color:var(--color-text-primary);background-color:#0000000d}.gallery-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:var(--spacing-6);animation:fadeIn .5s ease-out;width:100%;box-sizing:border-box}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.gallery-card{display:block;text-decoration:none;color:inherit;height:100%}.gallery-card>div{height:100%;display:flex;flex-direction:column;transition:transform .3s cubic-bezier(.34,1.56,.64,1),box-shadow .3s ease;border:1px solid var(--color-border);overflow:hidden;border-radius:var(--radius-lg)}.gallery-card:hover>div{transform:translateY(-4px);box-shadow:var(--shadow-lg);border-color:transparent}.gallery-card__image{aspect-ratio:1;overflow:hidden;background-color:var(--color-bg-subtle);position:relative}.gallery-card__image img{width:100%;height:100%;object-fit:cover;transition:transform .5s ease}.gallery-card:hover .gallery-card__image img{transform:scale(1.08)}.gallery-card__content{padding:var(--spacing-4);flex:1;display:flex;flex-direction:column;background-color:var(--color-bg-primary)}.gallery-card__title{font-size:var(--font-size-lg);font-weight:700;margin-bottom:var(--spacing-1);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:var(--color-text-primary)}.gallery-card__artist{font-size:var(--font-size-sm);color:var(--color-text-secondary);margin-bottom:var(--spacing-4)}.gallery-card__meta{display:flex;justify-content:space-between;align-items:center;font-size:var(--font-size-xs);color:var(--color-subtext);margin-top:auto;padding-top:var(--spacing-3);border-top:1px solid var(--color-border-subtle)}.status-badge{padding:2px 8px;border-radius:var(--radius-full);font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.05em}.status-badge--public{background-color:#10b9811a;color:var(--color-success)}.status-badge--private{background-color:#6b72801a;color:var(--color-subtext)}.loading,.error-state,.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--spacing-20) 0;text-align:center;color:var(--color-subtext);min-height:300px}.spinner{width:40px;height:40px;border:3px solid var(--color-bg-subtle);border-top-color:var(--color-primary);border-radius:50%;animation:spin 1s linear infinite;margin-bottom:var(--spacing-4)}@media(max-width:768px){.gallery-page{padding:var(--spacing-4) 0}.gallery-page__header{margin-bottom:var(--spacing-6);padding:0 var(--spacing-4)}.gallery-page__header h1{font-size:var(--font-size-2xl)}.gallery-page__controls{flex-direction:column;align-items:stretch;gap:var(--spacing-3);padding:0 var(--spacing-4);margin-bottom:var(--spacing-6)}.gallery-search{min-width:100%}.gallery-filter{width:100%;justify-content:center;margin-top:var(--spacing-1)}.gallery-filter button{flex:1;justify-content:center;padding:var(--spacing-2) 0}.gallery-grid{grid-template-columns:repeat(2,1fr);gap:var(--spacing-3);padding:0 var(--spacing-4)}.gallery-card__content{padding:var(--spacing-3)}.gallery-card__title{font-size:var(--font-size-md)}.gallery-card__artist{margin-bottom:var(--spacing-2);font-size:11px}.gallery-card__meta{padding-top:var(--spacing-2)}}@media(max-width:360px){.gallery-grid{grid-template-columns:1fr;gap:var(--spacing-4)}}.gallery-detail{padding:var(--spacing-8) 0}.gallery-detail__back{margin-bottom:var(--spacing-6);padding-left:0}.gallery-detail__content{display:grid;grid-template-columns:1fr 400px;gap:var(--spacing-8);align-items:start}.gallery-detail__image-wrapper{position:sticky;top:calc(64px + var(--spacing-4))}.gallery-detail__image{width:100%;height:auto;display:block}.video-container{position:relative;width:100%;cursor:pointer;background-color:#000;border-radius:var(--radius-lg);overflow:hidden}.video-poster{position:relative;line-height:0}.play-button-overlay{position:absolute;top:0;left:0;width:100%;height:100%;display:flex;justify-content:center;align-items:center;background-color:#0003;transition:background-color .3s}.video-poster:hover .play-button-overlay{background-color:#0006}.play-button-icon{width:80px;height:80px;background-color:#ffffffe6;border-radius:50%;display:flex;justify-content:center;align-items:center;box-shadow:0 4px 15px #0000004d;transition:transform .2s}.video-poster:hover .play-button-icon{transform:scale(1.1)}.video-loader-overlay{aspect-ratio:16 / 9;display:flex;justify-content:center;align-items:center;background-color:#000;width:100%}.play-button-icon:after{content:"";display:block;width:0;height:0;border-style:solid;border-width:15px 0 15px 25px;border-color:transparent transparent transparent var(--color-primary-blue);margin-left:5px}.gallery-detail__info-content{padding:var(--spacing-6)}.gallery-detail__title{font-size:var(--font-size-3xl);margin-bottom:var(--spacing-6)}.gallery-detail__meta{display:flex;flex-direction:column;gap:var(--spacing-3);padding-bottom:var(--spacing-6);border-bottom:1px solid var(--color-border);margin-bottom:var(--spacing-6)}.meta-item{display:flex;justify-content:space-between;align-items:center}.meta-label{font-size:var(--font-size-sm);color:var(--color-subtext);font-weight:var(--font-weight-medium)}.meta-value{font-size:var(--font-size-base);color:var(--color-text)}.gallery-detail__description{margin-bottom:var(--spacing-6);padding-bottom:var(--spacing-6);border-bottom:1px solid var(--color-border)}.gallery-detail__description h3{font-size:var(--font-size-lg);margin-bottom:var(--spacing-3)}.gallery-detail__description p{color:var(--color-text-light);line-height:var(--line-height-relaxed);white-space:pre-wrap}.gallery-detail__actions{margin-bottom:var(--spacing-6)}.gallery-detail__stats{display:flex;gap:var(--spacing-6);padding-top:var(--spacing-6);border-top:1px solid var(--color-border)}.stat-item{display:flex;flex-direction:column;align-items:center;gap:var(--spacing-2)}.stat-value{font-size:var(--font-size-2xl);font-weight:var(--font-weight-bold);color:var(--color-primary-blue)}.stat-label{font-size:var(--font-size-sm);color:var(--color-subtext)}@media(max-width:1024px){.gallery-detail__content{grid-template-columns:1fr}.gallery-detail__image-wrapper{position:static}}.notice-list-page{padding:var(--spacing-8) 0}.notice-list-page__header{text-align:center;margin-bottom:var(--spacing-10)}.notice-list-page__header h1{font-size:var(--font-size-4xl);margin-bottom:var(--spacing-3)}.notice-list-page__header p{color:var(--color-subtext);font-size:var(--font-size-lg)}.notice-list{max-width:900px;margin:0 auto;display:flex;flex-direction:column;gap:var(--spacing-4)}.notice-item{display:block}.notice-item__content{padding:var(--spacing-6);display:flex;justify-content:space-between;align-items:flex-start;gap:var(--spacing-6)}.notice-item__main{flex:1}.notice-item__badge{display:inline-block;font-size:var(--font-size-sm);color:var(--color-error);font-weight:var(--font-weight-semibold);margin-bottom:var(--spacing-2)}.notice-item__title{font-size:var(--font-size-xl);font-weight:var(--font-weight-semibold);margin-bottom:var(--spacing-3);color:var(--color-text)}.notice-item__preview{font-size:var(--font-size-base);color:var(--color-subtext);line-height:var(--line-height-relaxed);margin-bottom:var(--spacing-3)}.notice-item__meta{display:flex;gap:var(--spacing-2);font-size:var(--font-size-sm);color:var(--color-subtext)}.notice-item__date{font-size:var(--font-size-sm);color:var(--color-subtext);white-space:nowrap}@media(max-width:768px){.notice-item__content{flex-direction:column;gap:var(--spacing-3)}}.notice-detail{padding:var(--spacing-8) 0}.notice-detail__back{margin-bottom:var(--spacing-6);padding-left:0}.notice-detail__card{max-width:900px;margin:0 auto;padding:var(--spacing-8)}.notice-detail__header{margin-bottom:var(--spacing-6)}.notice-detail__badge{display:inline-block;font-size:var(--font-size-sm);color:var(--color-error);font-weight:var(--font-weight-semibold);margin-bottom:var(--spacing-3)}.notice-detail__title{font-size:var(--font-size-3xl);margin-bottom:var(--spacing-4);line-height:var(--line-height-tight)}.notice-detail__meta{display:flex;gap:var(--spacing-2);font-size:var(--font-size-sm);color:var(--color-subtext)}.notice-detail__divider{height:1px;background-color:var(--color-border);margin:var(--spacing-6) 0}.notice-detail__content{font-size:var(--font-size-base);line-height:var(--line-height-relaxed);color:var(--color-text-light)}.notice-detail__content p{white-space:pre-wrap;margin-bottom:var(--spacing-4)}@media(max-width:768px){.notice-detail__card{padding:var(--spacing-6) var(--spacing-4)}.notice-detail__title{font-size:var(--font-size-2xl)}}.auth-page{min-height:calc(100vh - 200px);display:flex;align-items:center;padding:var(--spacing-8) 0}.auth-page__content{display:flex;justify-content:center;width:100%}.auth-card{width:100%;max-width:500px;padding:var(--spacing-8)}.auth-card__header{text-align:center;margin-bottom:var(--spacing-8)}.auth-card__header h2{font-size:var(--font-size-3xl);margin-bottom:var(--spacing-3)}.auth-card__header p{color:var(--color-subtext)}.auth-form{display:flex;flex-direction:column;gap:var(--spacing-5)}.auth-form__error{padding:var(--spacing-4);background-color:#ef44441a;color:var(--color-error);border-radius:var(--radius-md);font-size:var(--font-size-sm)}.auth-form__agreements{display:flex;flex-direction:column;gap:var(--spacing-3)}.checkbox-label{display:flex;align-items:flex-start;gap:var(--spacing-2);cursor:pointer}.checkbox-label input[type=checkbox]{margin-top:2px;width:18px;height:18px;cursor:pointer}.auth-card__footer{margin-top:var(--spacing-6);text-align:center;color:var(--color-subtext);font-size:var(--font-size-sm)}.auth-link{color:var(--color-primary-blue);font-weight:var(--font-weight-semibold)}.auth-link:hover{color:var(--color-accent-orange)}.auth-card__success{text-align:center;padding:var(--spacing-8)}.auth-card__success h2{font-size:var(--font-size-2xl);margin-bottom:var(--spacing-4)}.auth-card__success p{color:var(--color-subtext);line-height:var(--line-height-relaxed)}.policy-page{padding:var(--spacing-12) 0;line-height:var(--line-height-relaxed)}.policy-page__header{text-align:center;margin-bottom:var(--spacing-12)}.policy-page__header h1{font-size:var(--font-size-3xl);margin-bottom:var(--spacing-2)}.policy-page__header p{color:var(--color-subtext)}.policy-card{padding:var(--spacing-10);background-color:var(--color-bg)}.policy-content h2{font-size:var(--font-size-xl);margin:var(--spacing-8) 0 var(--spacing-4);color:var(--color-text);border-bottom:2px solid var(--color-bg-subtle);padding-bottom:var(--spacing-2)}.policy-content h3{font-size:var(--font-size-lg);margin:var(--spacing-6) 0 var(--spacing-3);color:var(--color-text-light)}.policy-content p,.policy-content li{font-size:var(--font-size-base);color:var(--color-text-light);margin-bottom:var(--spacing-3)}.policy-content ul,.policy-content ol{margin-bottom:var(--spacing-6);padding-left:var(--spacing-6)}.policy-content ul li{list-style-type:disc}.policy-content ol li{list-style-type:decimal}.policy-content .effective-date{margin-top:var(--spacing-12);text-align:right;font-weight:var(--font-weight-medium);color:var(--color-subtext)}@media(max-width:768px){.policy-card{padding:var(--spacing-6) var(--spacing-4)}.policy-page__header h1{font-size:var(--font-size-2xl)}}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background-color:#00000080;display:flex;align-items:center;justify-content:center;z-index:var(--z-modal-backdrop);padding:var(--spacing-4);animation:fadeIn var(--transition-base)}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal{background-color:var(--color-bg);border-radius:var(--radius-lg);box-shadow:var(--shadow-xl);display:flex;flex-direction:column;max-height:90vh;width:100%;animation:slideUp var(--transition-base);z-index:var(--z-modal)}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.modal--small{max-width:400px}.modal--medium{max-width:600px}.modal--large{max-width:900px}.modal__header{display:flex;align-items:center;justify-content:space-between;padding:var(--spacing-6);border-bottom:1px solid var(--color-border)}.modal__title{font-size:var(--font-size-xl);font-weight:var(--font-weight-semibold);margin:0}.modal__close{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border-radius:var(--radius-base);color:var(--color-subtext);font-size:var(--font-size-xl);transition:all var(--transition-fast)}.modal__close:hover{background-color:var(--color-bg-hover);color:var(--color-text)}.modal__body{flex:1;overflow-y:auto;padding:var(--spacing-6)}.modal__footer{display:flex;gap:var(--spacing-3);justify-content:flex-end;padding:var(--spacing-6);border-top:1px solid var(--color-border)}.attendance-graph{background:#fff;border-radius:var(--radius-lg);padding:var(--spacing-6);box-shadow:var(--shadow-sm);margin-top:var(--spacing-8)}.attendance-graph__header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-4)}.attendance-graph__mobile-hint{display:none;font-size:10px;color:var(--color-subtext);background:var(--color-bg-subtle);padding:2px 8px;border-radius:var(--radius-full)}.attendance-graph__scroll-wrapper{overflow-x:auto;-webkit-overflow-scrolling:touch;padding-bottom:var(--spacing-2)}.attendance-graph__title{font-size:var(--font-size-lg);font-weight:var(--font-weight-bold);margin:0;color:var(--color-text)}.attendance-graph__container{display:flex;gap:var(--spacing-2);min-width:650px}@media(max-width:768px){.attendance-graph{padding:var(--spacing-4)}.attendance-graph__mobile-hint{display:block}.attendance-graph__cell{width:14px;height:14px}.attendance-graph__grid{grid-template-rows:repeat(7,14px);grid-template-columns:repeat(24,14px);gap:5px}}.attendance-graph__labels{display:grid;grid-template-rows:repeat(7,12px);gap:4px;padding-top:2px}.attendance-graph__label{font-size:10px;color:var(--color-subtext);line-height:12px}.attendance-graph__grid{display:grid;grid-auto-flow:column;grid-template-rows:repeat(7,12px);grid-template-columns:repeat(24,12px);gap:4px}.attendance-graph__cell{width:12px;height:12px;background-color:#ebedf0;border-radius:2px;cursor:pointer;transition:background-color .2s}.attendance-graph__cell.active{background-color:var(--color-primary-blue)}.attendance-graph__cell:hover{outline:1px solid #999}.attendance-graph__legend{display:flex;align-items:center;justify-content:flex-end;gap:4px;margin-top:var(--spacing-4);font-size:12px;color:var(--color-subtext)}.attendance-graph__legend .attendance-graph__cell{cursor:default}.mypage{padding:var(--spacing-8) 0}.mypage__profile{padding:var(--spacing-8);margin-bottom:var(--spacing-8);display:flex;justify-content:space-between;align-items:center;gap:var(--spacing-6)}.profile__content{display:flex;gap:var(--spacing-8);align-items:center}.profile__info{display:flex;flex-direction:column;gap:var(--spacing-2)}.profile__name{font-size:var(--font-size-2xl);font-weight:var(--font-weight-bold);margin:0}.profile__username{color:var(--color-subtext);font-size:var(--font-size-base)}.profile__email{color:var(--color-subtext);font-size:var(--font-size-sm)}.profile__stats{display:flex;gap:var(--spacing-8)}.mypage__attendance{margin-top:var(--spacing-6);padding:var(--spacing-6)}.attendance__header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-4)}.attendance__header h3{font-size:var(--font-size-xl);font-weight:var(--font-weight-bold);margin-bottom:4px}.attendance__desc{color:var(--color-subtext);font-size:var(--font-size-sm)}.mypage__artworks{margin-top:var(--spacing-8)}.mypage__artworks-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-6)}.mypage__artworks-header h3{font-size:var(--font-size-2xl);margin:0}.mypage__filters{display:flex;gap:var(--spacing-2);margin-bottom:var(--spacing-6)}.artworks-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:var(--spacing-6)}.artwork-card__image{aspect-ratio:1;overflow:hidden;position:relative;background-color:var(--color-bg-subtle)}.artwork-card__image img{width:100%;height:100%;object-fit:cover}.artwork-card__overlay{position:absolute;top:var(--spacing-3);right:var(--spacing-3)}.artwork-card__content{padding:var(--spacing-4)}.artwork-card__title{font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold);margin-bottom:var(--spacing-2);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.artwork-card__meta{display:flex;gap:var(--spacing-4);font-size:var(--font-size-sm);color:var(--color-subtext);margin-bottom:var(--spacing-3)}.artwork-card__actions{display:flex;gap:var(--spacing-2)}@media(max-width:768px){.mypage__profile{flex-direction:column;align-items:flex-start}.profile__content{flex-direction:column;align-items:flex-start;width:100%}.profile__stats{width:100%;justify-content:space-around}.artworks-grid{grid-template-columns:repeat(2,1fr);gap:var(--spacing-4)}}.auth-form{display:flex;flex-direction:column;gap:20px}.form-group{display:flex;flex-direction:column;gap:8px;width:100%}.form-group label{font-size:14px;font-weight:600;color:#333;text-align:left}.form-group input{padding:12px 16px;border:1px solid #ddd;border-radius:8px;font-size:16px;width:100%;box-sizing:border-box;transition:border-color .2s}.form-group input:focus{outline:none;border-color:var(--color-primary-blue)}.form-group input.input-disabled{background-color:#f5f5f5;color:#888;cursor:not-allowed}.form-actions{margin-top:10px;display:flex;justify-content:center}.textarea-wrapper{display:flex;flex-direction:column;gap:var(--spacing-2)}.textarea-wrapper--full-width{width:100%}.textarea-label{font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-text)}.textarea-required{color:var(--color-error);margin-left:var(--spacing-1)}.textarea{padding:var(--spacing-3) var(--spacing-4);font-size:var(--font-size-base);font-family:inherit;line-height:var(--line-height-normal);border:1px solid var(--color-border);border-radius:var(--radius-md);background-color:var(--color-bg);transition:all var(--transition-base);resize:vertical}.textarea:focus{outline:none;border-color:var(--color-primary-blue);box-shadow:0 0 0 3px #04a9e31a}.textarea::placeholder{color:var(--color-subtext)}.textarea--error{border-color:var(--color-error)}.textarea--error:focus{border-color:var(--color-error);box-shadow:0 0 0 3px #ef44441a}.textarea--full-width{width:100%}.textarea-error-message{font-size:var(--font-size-sm);color:var(--color-error)}.textarea-helper-text{font-size:var(--font-size-sm);color:var(--color-subtext)}.upload-page{padding:var(--spacing-8) 0}.upload-page__header{text-align:center;margin-bottom:var(--spacing-8)}.upload-page__header h1{font-size:var(--font-size-3xl);margin-bottom:var(--spacing-3)}.upload-page__header p{color:var(--color-subtext)}.upload-card{max-width:700px;margin:0 auto;padding:var(--spacing-8)}.upload-form{display:flex;flex-direction:column;gap:var(--spacing-6)}.upload-form__error{padding:var(--spacing-4);background-color:#ef44441a;color:var(--color-error);border-radius:var(--radius-md);font-size:var(--font-size-sm)}.upload-form__label{display:block;font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-text);margin-bottom:var(--spacing-2)}.upload-form__image-section{display:flex;flex-direction:column;gap:var(--spacing-2)}.image-upload__input{display:none}.image-upload__label{display:block;cursor:pointer}.image-upload__placeholder{border:2px dashed var(--color-border);border-radius:var(--radius-lg);padding:var(--spacing-12);text-align:center;transition:all var(--transition-base)}.image-upload__placeholder:hover{border-color:var(--color-primary-blue);background-color:var(--color-bg-subtle)}.image-upload__icon{font-size:3rem;display:block;margin-bottom:var(--spacing-3)}.image-upload__placeholder p{color:var(--color-text);margin-bottom:var(--spacing-2)}.image-upload__hint{font-size:var(--font-size-sm);color:var(--color-subtext)}.image-preview{position:relative;border-radius:var(--radius-lg);overflow:hidden;background-color:var(--color-bg-subtle)}.image-preview img{width:100%;height:auto;display:block}.image-preview__remove{position:absolute;top:var(--spacing-3);right:var(--spacing-3);background-color:#000000b3;color:#fff}.image-preview__remove:hover{background-color:#000000e6}.upload-form__checkbox{padding:var(--spacing-4);background-color:var(--color-bg-subtle);border-radius:var(--radius-md)}.upload-form__actions{display:flex;gap:var(--spacing-3);justify-content:flex-end;padding-top:var(--spacing-6);border-top:1px solid var(--color-border)}@media(max-width:768px){.upload-card{padding:var(--spacing-6) var(--spacing-4)}.upload-form__actions{flex-direction:column-reverse}.upload-form__actions button{width:100%}}:root{--color-primary-blue: #04A9E3;--color-primary-blue-light: #3BC0F0;--color-primary-blue-dark: #0389C0;--color-accent-orange: #F98A4F;--color-accent-orange-light: #FFA76F;--color-accent-orange-dark: #E0733A;--color-text: #1B1B1B;--color-text-light: #4A4A4A;--color-subtext: #666666;--color-border: #EAEAEA;--color-bg: #FFFFFF;--color-bg-subtle: #F8FAFC;--color-bg-hover: #F1F5F9;--color-success: #10B981;--color-success-light: #34D399;--color-error: #EF4444;--color-error-light: #F87171;--color-warning: #F59E0B;--color-warning-light: #FBBF24;--color-info: #3B82F6;--color-info-light: #60A5FA;--font-family: "Pretendard", -apple-system, BlinkMacSystemFont, system-ui, sans-serif;--font-size-xs: .75rem;--font-size-sm: .875rem;--font-size-base: 1rem;--font-size-lg: 1.125rem;--font-size-xl: 1.25rem;--font-size-2xl: 1.5rem;--font-size-3xl: 1.875rem;--font-size-4xl: 2.25rem;--font-weight-normal: 400;--font-weight-medium: 500;--font-weight-semibold: 600;--font-weight-bold: 700;--line-height-tight: 1.25;--line-height-normal: 1.5;--line-height-relaxed: 1.75;--spacing-0: 0;--spacing-1: .25rem;--spacing-2: .5rem;--spacing-3: .75rem;--spacing-4: 1rem;--spacing-5: 1.25rem;--spacing-6: 1.5rem;--spacing-8: 2rem;--spacing-10: 2.5rem;--spacing-12: 3rem;--spacing-16: 4rem;--spacing-20: 5rem;--radius-none: 0;--radius-sm: .25rem;--radius-base: .5rem;--radius-md: .75rem;--radius-lg: 1rem;--radius-xl: 1.5rem;--radius-full: 9999px;--shadow-xs: 0 1px 2px 0 rgba(0, 0, 0, .05);--shadow-sm: 0 1px 3px 0 rgba(0, 0, 0, .1), 0 1px 2px -1px rgba(0, 0, 0, .1);--shadow-base: 0 4px 6px -1px rgba(0, 0, 0, .1), 0 2px 4px -2px rgba(0, 0, 0, .1);--shadow-md: 0 10px 15px -3px rgba(0, 0, 0, .1), 0 4px 6px -4px rgba(0, 0, 0, .1);--shadow-lg: 0 20px 25px -5px rgba(0, 0, 0, .1), 0 8px 10px -6px rgba(0, 0, 0, .1);--shadow-xl: 0 25px 50px -12px rgba(0, 0, 0, .25);--transition-fast: .15s cubic-bezier(.4, 0, .2, 1);--transition-base: .2s cubic-bezier(.4, 0, .2, 1);--transition-slow: .3s cubic-bezier(.4, 0, .2, 1);--z-dropdown: 1000;--z-sticky: 1020;--z-fixed: 1030;--z-modal-backdrop: 1040;--z-modal: 1050;--z-popover: 1060;--z-tooltip: 1070;--breakpoint-mobile: 480px;--breakpoint-tablet: 768px;--breakpoint-desktop: 1024px;--breakpoint-wide: 1280px}*,*:before,*:after{box-sizing:border-box}*{margin:0;padding:0}html,body{height:100%}body{line-height:var(--line-height-normal);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}img,picture,video,canvas,svg{display:block;max-width:100%;height:auto}input,button,textarea,select{font:inherit}p,h1,h2,h3,h4,h5,h6{overflow-wrap:break-word}button{cursor:pointer;border:none;background:none}a{color:inherit;text-decoration:none}ul,ol{list-style:none}#root{isolation:isolate}body{font-family:var(--font-family);font-size:var(--font-size-base);color:var(--color-text);background-color:var(--color-bg)}h1,h2,h3,h4,h5,h6{font-weight:var(--font-weight-semibold);line-height:var(--line-height-tight);color:var(--color-text)}h1{font-size:var(--font-size-4xl)}h2{font-size:var(--font-size-3xl)}h3{font-size:var(--font-size-2xl)}h4{font-size:var(--font-size-xl)}h5{font-size:var(--font-size-lg)}h6{font-size:var(--font-size-base)}a{transition:color var(--transition-fast)}a:hover{color:var(--color-primary-blue)}a:focus-visible{outline:2px solid var(--color-primary-blue);outline-offset:2px;border-radius:var(--radius-sm)}:focus-visible{outline:2px solid var(--color-primary-blue);outline-offset:2px}::selection{background-color:var(--color-primary-blue);color:#fff}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:var(--color-bg-subtle)}::-webkit-scrollbar-thumb{background:var(--color-border);border-radius:var(--radius-full)}::-webkit-scrollbar-thumb:hover{background:var(--color-subtext)}.container{width:100%;max-width:1200px;margin:0 auto;padding:0 var(--spacing-4)}@media(min-width:768px){.container{padding:0 var(--spacing-6)}}@media(min-width:1024px){.container{padding:0 var(--spacing-8)}}.visually-hidden{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.text-center{text-align:center}.text-left{text-align:left}.text-right{text-align:right}.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-center{justify-content:center}.justify-between{justify-content:space-between}.gap-2{gap:var(--spacing-2)}.gap-4{gap:var(--spacing-4)}.gap-6{gap:var(--spacing-6)}@media(max-width:480px){html{font-size:14px}h1{font-size:var(--font-size-3xl)}h2{font-size:var(--font-size-2xl)}h3{font-size:var(--font-size-xl)}}@keyframes spin{to{transform:rotate(360deg)}}.spinner{width:40px;height:40px;border:4px solid var(--color-border);border-top-color:var(--color-primary-blue);border-radius:50%;animation:spin .6s linear infinite}.video-badge{position:absolute;bottom:6px;right:6px;top:auto;background-color:#0009;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);color:#fff;width:24px;height:24px;border-radius:50%;font-size:10px;display:flex;align-items:center;justify-content:center;z-index:10;box-shadow:0 1px 3px #0000004d;padding-left:2px}
