:root{--space-black: #000000;--pure-white: #ffffff;--aluminium: #d3d3d3;--science-green: #a8ff00;--science-blue: #7098ff;--island-blue: #282736;--text: var(--space-black);--text-heading: var(--island-blue);--text-muted: #64748b;--bg: #f5f5f5;--bg-card: var(--pure-white);--border: var(--aluminium);--accent: var(--science-green);--accent-hover: #8ed600;--accent-light: rgba(168, 255, 0, .2);--focus-ring: var(--science-green);--spacing-xs: .25rem;--spacing-sm: .5rem;--spacing-md: 1rem;--spacing-lg: 1.5rem;--spacing-xl: 2rem;--spacing-2xl: 3rem;--spacing-3xl: 4rem;--radius: 5px;--radius-lg: 8px;--shadow: 0 1px 3px rgba(0, 0, 0, .08);--shadow-lg: 0 4px 12px rgba(0, 0, 0, .1);--shadow-header: 0 1px 0 rgba(0, 0, 0, .08);--font-sans: "Inter", system-ui, -apple-system, sans-serif;--font-heading: var(--font-sans);--container-max: 1280px;--touch-min: 44px}*,*:before,*:after{box-sizing:border-box}body{margin:0;font-family:var(--font-sans);font-size:1rem;line-height:1.6;color:var(--text);background:var(--bg);-webkit-font-smoothing:antialiased}#root{min-height:100vh;display:flex;flex-direction:column}h1,h2,h3{font-family:var(--font-heading);font-weight:600;color:var(--text-heading);line-height:1.2;margin:0 0 var(--spacing-md)}h1{font-size:clamp(2rem,4vw,2.5rem)}h2{font-size:clamp(1.375rem,3vw,1.5rem)}h3{font-size:1.125rem}p{margin:0 0 var(--spacing-md)}p:last-child{margin-bottom:0}a{color:var(--accent);text-decoration:none}a:hover{color:var(--accent-hover);text-decoration:underline}a:focus-visible{outline:2px solid var(--focus-ring);outline-offset:2px}a[href="/"]:hover{text-decoration:none}.skip-link{position:absolute;top:-100px;left:var(--spacing-md);z-index:100;padding:var(--spacing-sm) var(--spacing-md);background:var(--bg-card);color:var(--text-heading);font-weight:600;border-radius:var(--radius);box-shadow:var(--shadow-lg)}.skip-link:focus{top:var(--spacing-md)}.container{width:100%;max-width:var(--container-max);margin:0 auto;padding-inline:var(--spacing-xl)}.section{padding-block:var(--spacing-3xl);padding-inline:var(--spacing-xl)}.section__title{margin-bottom:var(--spacing-xl)}.header{position:sticky;top:0;z-index:50;background:var(--space-black);color:var(--pure-white)}.header__inner{display:flex;flex-direction:column;align-items:center;gap:var(--spacing-md);padding-block:var(--spacing-md);padding-inline:10px;max-width:var(--container-max);margin:0 auto;overflow:hidden}.header__logo{font-size:1.25rem;font-weight:700;color:var(--science-green);text-decoration:none;display:inline-flex;align-items:center;min-height:var(--touch-min);padding-inline:var(--spacing-sm);order:-1}.header__logo:hover{text-decoration:none;color:var(--accent-hover)}.header__nav{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--spacing-sm);min-width:0;width:100%}.header__list{list-style:none;margin:0;padding:0;display:flex;flex-wrap:nowrap;gap:var(--spacing-xs);align-items:center;justify-content:center;max-width:100%;min-width:0}.header__list li{flex-shrink:1;min-width:0}.header__link{display:inline-flex;align-items:center;justify-content:center;min-height:var(--touch-min);padding-inline:clamp(var(--spacing-sm),1.5vw,var(--spacing-md));border:1px solid rgba(255,255,255,.4);border-radius:var(--radius);font-weight:500;font-size:clamp(.8125rem,2vw,1rem);color:var(--pure-white);text-decoration:none;white-space:nowrap;min-width:0;overflow:hidden;text-overflow:ellipsis}.header__link:hover{background:#ffffff1a;text-decoration:none;border-color:#fff9}.header__link:not(.header__link--active):hover{color:var(--pure-white)}.header__link--active{color:var(--science-green);font-weight:600;text-decoration:none;border-color:var(--science-green)}.header__link--active:hover,.header__link--active:focus{color:var(--science-green);border-color:var(--science-green)}.header__link:focus-visible{outline:2px solid var(--focus-ring);outline-offset:2px}.header__link--btn{background:none;border:1px solid rgba(255,255,255,.4);font:inherit;cursor:pointer;color:var(--pure-white)}.main{flex:1;display:flex;flex-direction:column;min-height:0}.swipe-nav{flex:1;display:flex;flex-direction:column;min-height:0;min-width:100%}.header__list--admin{flex-wrap:nowrap}.header__locale{display:flex;align-items:center;gap:.25rem}.header__link--locale{background:none;border:none;padding:0;font:inherit;cursor:pointer;min-width:auto}.header__locale-sep{color:var(--aluminium);pointer-events:none}@media (max-width: 768px){.header__list{padding-block:var(--spacing-xs);flex-wrap:wrap;justify-content:center;gap:var(--spacing-sm)}.header__list li{flex-shrink:0}.header__list--admin{flex-wrap:wrap;justify-content:center}}.hero{background:var(--pure-white);padding-block:var(--spacing-3xl);padding-inline:var(--spacing-xl);text-align:center;border-bottom:1px solid var(--border)}.hero__inner{max-width:900px;margin:0 auto}.hero__title{margin-bottom:var(--spacing-md);color:var(--island-blue);font-size:clamp(2rem,4vw,2.8rem);font-weight:700}.hero__text{max-width:700px;margin:0 auto var(--spacing-xl);font-size:1.1rem;color:var(--space-black)}.hero__cta{display:inline-flex;align-items:center;justify-content:center;min-height:var(--touch-min);padding:12px 22px;background:var(--science-green);color:var(--space-black);font-weight:600;border-radius:var(--radius);text-decoration:none;border:none;cursor:pointer}.hero__cta:hover{background:var(--accent-hover);text-decoration:none;color:var(--space-black)}.hero__cta:focus-visible{outline:2px solid var(--focus-ring);outline-offset:2px}.carousel{position:relative;width:100%;aspect-ratio:16 / 9;max-height:70vh;background:var(--space-black)}.carousel__inner{position:absolute;top:0;right:0;bottom:0;left:0;overflow:hidden}.carousel__placeholder{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;color:var(--aluminium);font-size:1.125rem}.carousel__slide{position:relative;width:100%;height:100%}.carousel__slide-content{position:absolute;top:0;right:0;bottom:0;left:0;animation:carousel-fade-in .6s ease-out}@media (prefers-reduced-motion: reduce){.carousel__slide-content{animation:none}}@keyframes carousel-fade-in{0%{opacity:0}to{opacity:1}}.carousel__slide--linked{cursor:pointer;z-index:0}.carousel__slide--linked .carousel__image,.carousel__slide--linked .carousel__caption-wrap{pointer-events:none}.carousel__image{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;object-fit:cover;display:block}.carousel__caption-wrap{position:absolute;bottom:0;left:0;right:0;padding:var(--spacing-xl);background:linear-gradient(transparent,#000000b3);color:var(--pure-white)}.carousel__title{margin:0 0 var(--spacing-xs);font-size:1.5rem;font-weight:700;color:var(--pure-white)}.carousel__caption{margin:0;font-size:1rem;color:var(--aluminium)}.carousel__controls{position:absolute;top:50%;left:0;right:0;transform:translateY(-50%);display:flex;justify-content:space-between;padding-inline:var(--spacing-md);pointer-events:none;z-index:2}.carousel__btn{pointer-events:auto;width:var(--touch-min);height:var(--touch-min);display:flex;align-items:center;justify-content:center;background:#00000080;color:var(--pure-white);border:none;border-radius:var(--radius);font-size:1.5rem;cursor:pointer;line-height:1}.carousel__btn:hover{background:#000c}.carousel__btn:focus-visible{outline:2px solid var(--focus-ring);outline-offset:2px}.carousel__dots{position:absolute;bottom:var(--spacing-md);left:50%;transform:translate(-50%);display:flex;gap:var(--spacing-sm);pointer-events:none;z-index:2}.carousel__dot{pointer-events:auto;width:10px;height:10px;border-radius:50%;border:2px solid var(--pure-white);background:transparent;cursor:pointer;padding:0}.carousel__dot--active{background:var(--science-green);border-color:var(--science-green)}.carousel__dot:focus-visible{outline:2px solid var(--focus-ring);outline-offset:2px}.dot-banner{display:grid;grid-template-columns:repeat(20,8px);gap:8px;justify-content:center;margin:var(--spacing-lg) auto}.dot-banner span{width:8px;height:8px;background:var(--science-green);border-radius:50%;opacity:.6}.info-strip{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:var(--spacing-xl)}.info-card{padding:var(--spacing-lg);background:var(--bg-card);border-radius:var(--radius);box-shadow:var(--shadow)}.info-card__title{font-size:1rem;margin-bottom:var(--spacing-sm)}.info-card__text{margin:0;font-size:.9375rem}.section--alt{background:var(--bg)}.section--bordered{border-top:1px solid var(--border)}.cards-grid{list-style:none;margin:0;padding:0;display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:var(--spacing-lg)}.card{padding:var(--spacing-lg);background:var(--bg-card);border-radius:var(--radius-lg);box-shadow:var(--shadow);height:100%;display:flex;flex-direction:column}.card__date{font-size:.875rem;color:var(--island-blue);font-weight:600;margin-bottom:var(--spacing-sm)}.card__title{margin-bottom:var(--spacing-sm)}.card__text{margin:0;flex:1;font-size:.9375rem}.section-page__event-card{display:flex;flex-direction:column;text-decoration:none;color:inherit}.section-page__event-card:hover{background:var(--bg)}.section-page__events{margin-top:var(--spacing-2xl)}.section-page__events-title{font-size:1.25rem;margin-bottom:var(--spacing-lg)}.news-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:var(--spacing-md)}.news-item{padding:var(--spacing-lg);background:var(--bg-card);border-radius:var(--radius);box-shadow:var(--shadow)}.news-item__date{font-size:.875rem;color:var(--text-muted);margin-bottom:var(--spacing-xs);display:block}.news-item__countdown{font-size:.875rem;color:var(--island-blue);font-weight:600;margin:0 0 var(--spacing-xs)}.next-event{padding:var(--spacing-lg);background:var(--bg-card);border-radius:var(--radius);box-shadow:var(--shadow)}.next-event--link{display:block;text-decoration:none;color:inherit}.next-event--link:hover{background:var(--bg)}.next-event__title{font-size:1.25rem;font-weight:600;color:var(--text-heading);margin:0 0 var(--spacing-sm)}.news-item__title{margin-bottom:var(--spacing-sm)}.news-item__text{margin:0;font-size:.9375rem}.footer{margin-top:auto;background:var(--bg-card);border-top:1px solid var(--border);padding:var(--spacing-xl);text-align:center;font-size:.875rem;color:var(--text)}.footer__text{margin:0}.section-page__title{margin-bottom:var(--spacing-xl);color:var(--text-heading)}.section-page__body{line-height:1.7}.section-page__body p{margin-bottom:var(--spacing-md)}.section-page__empty{color:var(--text-muted);font-style:italic}.event-detail__date{font-size:.9375rem;color:var(--text-muted);margin-bottom:var(--spacing-md)}.event-detail__summary{margin:0 0 var(--spacing-lg);font-size:1.05rem;line-height:1.6;color:var(--text-heading)}.event-detail__body{margin-bottom:var(--spacing-xl)}.event-detail__gallery{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:var(--spacing-lg);margin-bottom:var(--spacing-xl)}.event-detail__gallery-item{margin:0;display:flex;flex-direction:column;gap:var(--spacing-sm)}.event-detail__gallery-image{width:100%;height:auto;display:block;border-radius:var(--radius-lg);object-fit:cover;box-shadow:var(--shadow)}.event-detail__gallery-caption{font-size:.9375rem;color:var(--text-muted)}.section-page__block--image{margin:var(--spacing-lg) 0;max-width:100%}.section-page__block-image{display:block;max-width:100%;height:auto;width:100%;object-fit:contain}@media (max-width: 768px){.section-page__block--image{max-width:100%}.section-page__block-image{width:100%;max-width:100%;height:auto;object-fit:contain}}.section-page__block-caption{margin-top:var(--spacing-sm);font-size:.9375rem;color:var(--text-muted)}.admin-login{padding:var(--spacing-3xl) var(--spacing-xl);max-width:400px;margin:0 auto}.admin-login__inner{background:var(--bg-card);padding:var(--spacing-xl);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg)}.admin-login__title{margin-bottom:var(--spacing-xl);color:var(--text-heading)}.admin-login__form{display:flex;flex-direction:column;gap:var(--spacing-md)}.admin-login__error{color:#b91c1c;margin:0;font-size:.9375rem}.admin-login__label{display:flex;flex-direction:column;gap:var(--spacing-xs);font-weight:500;color:var(--text-heading)}.admin-login__input{padding:var(--spacing-sm) var(--spacing-md);border:1px solid var(--border);border-radius:var(--radius);font:inherit}.admin-login__btn{min-height:var(--touch-min);padding-inline:var(--spacing-lg);background:var(--science-green);color:var(--space-black);font-weight:600;border:none;border-radius:var(--radius);cursor:pointer;margin-top:var(--spacing-sm)}.admin-login__btn:hover:not(:disabled){background:var(--accent-hover)}.admin-login__btn:focus-visible{outline:2px solid var(--focus-ring);outline-offset:2px}.admin-carousel{padding:var(--spacing-3xl) var(--spacing-xl)}.admin-carousel__inner{max-width:900px;margin:0 auto}.admin-carousel__title{margin-bottom:var(--spacing-lg);color:var(--text-heading)}.admin-carousel__message{margin-bottom:var(--spacing-md);color:var(--island-blue);font-weight:500}.admin-carousel__upload{margin-bottom:var(--spacing-2xl);padding:var(--spacing-xl);background:var(--bg-card);border-radius:var(--radius-lg);box-shadow:var(--shadow)}.admin-carousel__subtitle{margin-bottom:var(--spacing-md);font-size:1.125rem}.admin-carousel__details{margin-top:var(--spacing-md);margin-bottom:var(--spacing-md);padding:var(--spacing-md);background:var(--bg);border:1px solid var(--border);border-radius:var(--radius)}.admin-carousel__details summary{cursor:pointer;font-size:.9375rem;font-weight:600;color:var(--text-heading)}.admin-carousel__label{display:flex;flex-direction:column;gap:var(--spacing-xs);margin-bottom:var(--spacing-md);font-weight:500;color:var(--text-heading)}.admin-carousel__label input[type=file],.admin-carousel__label input[type=text],.admin-carousel__textarea{padding:var(--spacing-sm) var(--spacing-md);border:1px solid var(--border);border-radius:var(--radius);font:inherit}.admin-carousel__textarea{resize:vertical;min-height:80px}.admin-layout{display:flex;flex-direction:column;gap:var(--spacing-xl)}.admin-layout__nav{border-bottom:1px solid var(--border);padding-bottom:var(--spacing-md)}.admin-layout__list{list-style:none;margin:0;padding:0;display:flex;gap:var(--spacing-md);flex-wrap:wrap}.admin-layout__link{padding:var(--spacing-sm) var(--spacing-md);border-radius:var(--radius);font-weight:500;color:var(--text-heading);text-decoration:none;background:transparent}.admin-layout__link:hover{background:var(--accent-light);color:var(--accent-hover);text-decoration:none}.admin-layout__link--active{background:var(--accent-light);color:var(--accent)}.admin-layout__link:focus-visible{outline:2px solid var(--focus-ring);outline-offset:2px}.admin-layout__content{flex:1}.admin-carousel__btn{min-height:var(--touch-min);padding-inline:var(--spacing-lg);background:var(--science-green);color:var(--space-black);font-weight:600;border:none;border-radius:var(--radius);cursor:pointer}.admin-carousel__btn:hover:not(:disabled){background:var(--accent-hover)}.admin-carousel__btn:focus-visible{outline:2px solid var(--focus-ring);outline-offset:2px}.admin-page{max-width:var(--container-max);margin:0 auto;padding:var(--spacing-lg)}.admin-page__title{margin-top:0;margin-bottom:var(--spacing-md)}.admin-page__intro{margin-bottom:var(--spacing-lg);color:var(--text-muted)}.admin-page__message{margin-bottom:var(--spacing-md);color:var(--text-muted)}.admin-page__message--success{color:var(--science-green)}.admin-certificate-designs{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:var(--spacing-md)}.admin-certificate-designs__item{display:flex;flex-wrap:wrap;align-items:center;gap:var(--spacing-md);padding:var(--spacing-md);background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius)}.admin-certificate-designs__label{font-weight:500;color:var(--text-heading)}.admin-certificate-designs__toggle{display:inline-flex;align-items:center;gap:var(--spacing-sm);cursor:pointer;font-size:.95rem}.admin-certificate-designs__toggle input{width:1.125rem;height:1.125rem}.admin-certificate-designs__toggle input:focus-visible{outline:2px solid var(--focus-ring);outline-offset:2px}.admin-certificate-designs__toggle-text{color:var(--text-muted)}.admin-certificate-designs__lt{display:flex;align-items:flex-end;gap:var(--spacing-sm);flex:1 1 100%}@media (min-width: 640px){.admin-certificate-designs__lt{flex:1 1 auto;min-width:200px}}.admin-certificate-designs__lt-label{display:flex;flex-direction:column;gap:var(--spacing-xs)}.admin-certificate-designs__lt-label-text{font-size:.875rem;color:var(--text-muted)}.admin-certificate-designs__lt-input{padding:var(--spacing-xs) var(--spacing-sm);border:1px solid var(--border);border-radius:var(--radius);font-size:.95rem;min-width:120px}.admin-certificate-designs__lt-input:focus{outline:2px solid var(--focus-ring);outline-offset:1px}.admin-certificate-designs__save{flex-shrink:0}.admin-blocks-add{margin-top:var(--spacing-lg);margin-bottom:var(--spacing-xl);padding:var(--spacing-xl);background:var(--bg-card);border:2px solid var(--science-green);border-radius:var(--radius-lg);box-shadow:var(--shadow)}.admin-blocks-add__title{margin:0 0 var(--spacing-xs);font-size:1.25rem;color:var(--text-heading)}.admin-blocks-add__hint{margin:0 0 var(--spacing-md);font-size:.95rem;color:var(--space-black)}.admin-blocks-add__buttons{display:flex;flex-wrap:wrap;gap:var(--spacing-md)}.admin-blocks-empty{color:var(--text-heading)}.admin-sections-hint{margin-top:var(--spacing-md);margin-bottom:0;padding:var(--spacing-md);background:var(--accent-light);border-radius:var(--radius);font-size:.95rem;color:var(--space-black)}.admin-carousel__list{margin-top:var(--spacing-xl);list-style:none;padding:0;margin-bottom:0}.admin-carousel__list-item{display:flex;align-items:center;gap:var(--spacing-md);padding:var(--spacing-sm) 0;border-bottom:1px solid var(--border)}.admin-carousel__list-item span:first-child{min-width:6rem}.admin-carousel__intro{margin-bottom:var(--spacing-md);color:var(--text-muted);max-width:42rem}.admin-event-gallery-editor{display:flex;flex-direction:column;gap:var(--spacing-md)}.admin-event-gallery-editor__item{display:flex;gap:var(--spacing-md);align-items:flex-start;padding:var(--spacing-md);background:var(--bg);border:1px solid var(--border);border-radius:var(--radius)}.admin-event-gallery-editor__preview{width:140px;max-width:100%;aspect-ratio:4 / 3;object-fit:cover;border-radius:var(--radius);background:var(--bg-card)}.admin-event-gallery-editor__fields{flex:1;min-width:0}.admin-analytics__grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(10rem,1fr));gap:var(--spacing-lg);margin-top:var(--spacing-lg)}.admin-analytics__card{display:flex;flex-direction:column;gap:var(--spacing-xs);padding:var(--spacing-lg);background:var(--bg-card);border-radius:var(--radius);box-shadow:var(--shadow)}.admin-analytics__label{font-size:.875rem;color:var(--text-muted)}.admin-analytics__value{font-size:1.75rem;font-weight:600;color:var(--text-heading)}.admin-analytics__section-title{font-size:1.25rem;font-weight:600;margin-top:var(--spacing-xl);margin-bottom:0}.admin-carousel__row{display:flex;flex-wrap:wrap;gap:var(--spacing-md);align-items:flex-end}.admin-carousel__row .admin-carousel__label{flex:0 1 auto}.admin-carousel__muted{color:var(--text-muted)}.admin-carousel__section{margin-top:var(--spacing-xl)}.admin-carousel__btn--small{margin-left:auto;padding:var(--spacing-xs) var(--spacing-sm);font-size:.875rem}.admin-carousel__slides{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:var(--spacing-md)}.admin-carousel__slide-item{display:flex;gap:var(--spacing-lg);align-items:center;padding:var(--spacing-md);background:var(--bg-card);border-radius:var(--radius);box-shadow:var(--shadow)}.admin-carousel__thumb{width:120px;height:80px;object-fit:cover;border-radius:var(--radius)}.admin-carousel__meta{flex:1;display:flex;align-items:center;justify-content:space-between;gap:var(--spacing-md);flex-wrap:wrap}.admin-carousel__order{font-weight:500;color:var(--text-heading)}.admin-carousel__actions{display:flex;gap:var(--spacing-sm)}.admin-carousel__actions button{min-height:36px;padding-inline:var(--spacing-md);background:var(--bg);border:1px solid var(--border);border-radius:var(--radius);font:inherit;cursor:pointer}.admin-carousel__actions button:hover:not(:disabled){background:var(--border)}.admin-carousel__actions button:focus-visible{outline:2px solid var(--focus-ring);outline-offset:2px}@media (max-width: 768px){body{font-size:1rem}.section{padding-block:var(--spacing-2xl)}.admin-carousel__slide-item{flex-direction:column;align-items:stretch;gap:var(--spacing-sm);padding:var(--spacing-sm)}.admin-carousel__meta{flex-direction:column;align-items:stretch;gap:var(--spacing-sm)}.admin-event-gallery-editor__item{flex-direction:column}.admin-event-gallery-editor__preview{width:100%;aspect-ratio:auto}.admin-carousel__order{word-break:break-word}.admin-carousel__actions{flex-wrap:wrap}.admin-carousel__actions .admin-carousel__btn{min-height:36px}}.certificate-modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:var(--spacing-md);overflow-y:auto}.certificate-modal{background:var(--bg-card);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);padding:var(--spacing-xl);max-width:400px;width:100%;max-height:calc(100vh - 2 * var(--spacing-md));overflow-y:auto}.certificate-modal__title{margin-top:0;margin-bottom:var(--spacing-lg);font-size:1.25rem}.certificate-modal__label{display:block;margin-bottom:var(--spacing-md);font-weight:500;color:var(--text-heading)}.certificate-modal__input{display:block;width:100%;margin-top:var(--spacing-xs);padding:var(--spacing-sm) var(--spacing-md);border:1px solid var(--border);border-radius:var(--radius);font:inherit}.certificate-modal__input:focus{outline:2px solid var(--focus-ring);outline-offset:2px}.certificate-modal__photos{margin-bottom:var(--spacing-lg)}.certificate-modal__photos-label{display:block;margin-bottom:var(--spacing-sm);font-weight:500;color:var(--text-heading)}.certificate-modal__photo-slot{display:inline-flex;align-items:center;justify-content:center;width:48px;height:48px;min-width:var(--touch-min);min-height:var(--touch-min);margin-right:var(--spacing-sm);margin-bottom:var(--spacing-sm);border:2px dashed var(--border);border-radius:var(--radius);cursor:pointer;background:var(--bg)}.certificate-modal__photo-slot:hover{border-color:var(--accent);background:var(--accent-light)}.certificate-modal__file-input{position:absolute;width:0;height:0;opacity:0}.certificate-modal__photo-placeholder{font-size:1.25rem;color:var(--text-muted)}.certificate-modal__preview{margin-bottom:var(--spacing-lg);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;max-height:320px;display:flex;justify-content:center;background:var(--bg)}.certificate-modal__preview .certificate-canvas{max-height:320px;max-width:100%;width:auto;height:auto;aspect-ratio:1080 / 1920}.certificate-modal__actions{display:flex;flex-wrap:wrap;gap:var(--spacing-md)}.certificate-modal__btn{padding:var(--spacing-sm) var(--spacing-lg);min-height:var(--touch-min);border-radius:var(--radius);font:inherit;font-weight:500;cursor:pointer;border:none}.certificate-modal__btn:focus-visible{outline:2px solid var(--focus-ring);outline-offset:2px}.certificate-modal__btn--primary{background:var(--accent);color:var(--space-black)}.certificate-modal__btn--primary:hover:not(:disabled){background:var(--accent-hover)}.certificate-modal__btn--primary:disabled{opacity:.6;cursor:not-allowed}.certificate-modal__btn--secondary{background:var(--bg);color:var(--text-heading);border:1px solid var(--border)}.certificate-modal__btn--secondary:hover{background:var(--border)}.certificate-design-selector{margin-bottom:var(--spacing-lg)}.certificate-design-selector__label{display:block;margin-bottom:var(--spacing-sm);font-weight:500;color:var(--text-heading)}.certificate-design-selector__options{display:flex;flex-wrap:wrap;gap:var(--spacing-sm)}.certificate-design-selector__option{display:inline-flex;cursor:pointer}.certificate-design-selector__input{position:absolute;width:0;height:0;opacity:0}.certificate-design-selector__btn{display:inline-block;padding:var(--spacing-sm) var(--spacing-md);min-height:var(--touch-min);border:2px solid var(--border);border-radius:var(--radius);font:inherit;font-weight:500;background:var(--bg-card);color:var(--text-heading)}.certificate-design-selector__input:focus-visible+.certificate-design-selector__btn{outline:2px solid var(--focus-ring);outline-offset:2px}.certificate-design-selector__input:checked+.certificate-design-selector__btn{border-color:var(--accent);background:var(--accent-light);color:var(--text-heading)}.certificate-design-selector__option:hover .certificate-design-selector__btn{border-color:var(--accent)}.certificate-page__label{display:block;margin-bottom:var(--spacing-md);font-weight:500;color:var(--text-heading)}.certificate-page__input{display:block;width:100%;max-width:20rem;margin-top:var(--spacing-xs);padding:var(--spacing-sm) var(--spacing-md);border:1px solid var(--border);border-radius:var(--radius);font:inherit}.certificate-page__input:focus{outline:2px solid var(--focus-ring);outline-offset:2px}.certificate-page__preview{margin-bottom:var(--spacing-xl);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;background:var(--bg);display:flex;justify-content:center}.certificate-page__preview .certificate-canvas{max-width:100%;width:100%;height:auto;aspect-ratio:1080 / 1920;display:block}.certificate-page__upload{margin-bottom:var(--spacing-xl)}.certificate-page__upload-label{display:block;margin-bottom:var(--spacing-sm);font-weight:500;color:var(--text-heading)}.certificate-page__upload-slots{display:flex;flex-wrap:wrap;gap:var(--spacing-sm)}.certificate-page__upload-slots--single{justify-content:center}.certificate-page__upload-slot{position:relative;display:inline-flex;align-items:center;justify-content:center;width:48px;height:48px;min-width:var(--touch-min);min-height:var(--touch-min);border:2px dashed var(--border);border-radius:var(--radius);cursor:pointer;background:var(--bg)}.certificate-page__upload-slot:hover{border-color:var(--accent);background:var(--accent-light)}.certificate-page__upload-slot--earth{width:120px;height:120px;min-width:120px;min-height:120px;border-radius:50%;border-color:#2d7d46}.certificate-page__upload-slot--earth:hover{border-color:#1e5c33}.certificate-page__upload-slot--earth .certificate-page__upload-placeholder{font-size:2rem}.certificate-page__file-input{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;opacity:0;cursor:pointer;font-size:0;z-index:1}.certificate-page__upload-placeholder{font-size:1.25rem;color:var(--text-muted)}.certificate-page__actions{margin-top:var(--spacing-lg)}.certificate-page__empty{color:var(--text-muted)}
