:root{--color-background: #3d2b2b;--color-surface: #ffffff;--color-surface-alt: #f4f4f4;--color-surface-cream: #fdf6ec;--color-chrome: #3d2b2b;--color-chrome-strong: #2a1d1d;--color-text: #1a1a1a;--color-text-muted: #555555;--color-text-inverse: #ffffff;--color-text-on-chrome: #ffffff;--color-primary: #ff7fa8;--color-primary-hover: #ff9cbd;--color-primary-dark: #5a3a44;--color-textbox-dark: #a55d66;--color-textbox-dark-hover: #c27580;--color-textbox-light: #f099b2;--color-textbox-light-hover: #ffb4c9;--color-translucid-base: rgba(61, 43, 43, .45);--color-translucid-opaque: #3d2b2b;--color-accent: #2b2b2b;--color-border: #2b2b2b;--color-border-soft: rgba(0, 0, 0, .15);--color-shadow: rgba(0, 0, 0, .25);--color-shadow-strong: rgba(0, 0, 0, .45);--color-overlay: rgba(0, 0, 0, .55);--color-focus-ring: #ffd34d}:root{--font-family-base: "Mochiy Pop One", "Trebuchet MS", system-ui, sans-serif;--font-family-heading: "Mochiy Pop One", "Trebuchet MS", system-ui, sans-serif;--font-size-xs: .75rem;--font-size-sm: .875rem;--font-size-base: 1rem;--font-size-md: 1.125rem;--font-size-lg: 1.5rem;--font-size-xl: 2rem;--font-weight-regular: 400;--font-weight-bold: 700;--line-height-base: 1.4;--line-height-tight: 1.15}:root{--space-xs: .25rem;--space-sm: .5rem;--space-md: 1rem;--space-lg: 1.5rem;--space-xl: 2rem;--radius-sm: 6px;--radius-md: 14px;--radius-lg: 22px;--radius-pill: 9999px;--transition-fast: .15s ease-out;--transition-base: .25s ease-out}*,*:before,*:after{box-sizing:border-box}html,body{margin:0;padding:0}img{max-width:100%;display:block}button{font:inherit;color:inherit;background:none;border:none;padding:0;cursor:pointer}@media (prefers-reduced-motion: reduce){*,*:before,*:after{animation-duration:.01ms!important;transition-duration:.01ms!important}}html,body{overscroll-behavior:none}body{font-family:var(--font-family-base);font-size:var(--font-size-base);line-height:var(--line-height-base);color:var(--color-text-on-chrome);background-color:var(--color-background);-webkit-font-smoothing:antialiased;margin:0}.app-shell{min-height:100vh;min-height:100dvh}h1,h2,h3,h4,h5,h6{font-family:var(--font-family-heading);line-height:var(--line-height-tight);margin:0}:focus-visible{outline:3px solid var(--color-focus-ring);outline-offset:3px}.campaign-card{--campaign-card-size: 14rem;position:relative;display:inline-block;width:var(--campaign-card-size);height:var(--campaign-card-size);border:5px solid var(--color-border);border-radius:var(--radius-lg);background-color:var(--color-surface);box-shadow:0 4px 10px var(--color-shadow);overflow:hidden;cursor:pointer;transition:transform var(--transition-base),box-shadow var(--transition-base),outline-color var(--transition-base);outline:4px solid transparent;outline-offset:2px}.campaign-card__image-wrapper{position:relative;width:100%;height:100%}.campaign-card__image{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;object-fit:cover;transition:opacity var(--transition-base)}.campaign-card__image--hover{opacity:0}.campaign-card:hover,.campaign-card:focus-visible{transform:scale(1.06);box-shadow:0 8px 18px var(--color-shadow-strong);outline-color:var(--color-textbox-light-hover)}.campaign-card:hover .campaign-card__image--base,.campaign-card:focus-visible .campaign-card__image--base{opacity:0}.campaign-card:hover .campaign-card__image--hover,.campaign-card:focus-visible .campaign-card__image--hover{opacity:1}.campaign-card--plus{background-color:var(--color-surface-cream);border-color:var(--color-border)}.campaign-card--plus:hover,.campaign-card--plus:focus-visible{background-color:var(--color-surface);outline-color:var(--color-primary)}.campaign-card__plus-icon{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;padding:20%;-webkit-user-select:none;user-select:none;pointer-events:none}.profile{--profile-size: 4.5rem;position:relative;display:inline-block;width:var(--profile-size);height:var(--profile-size);border-radius:var(--radius-md);background-color:var(--color-primary-dark);border:3px solid var(--color-border);overflow:hidden;cursor:pointer;transition:transform var(--transition-fast),box-shadow var(--transition-fast),background-color var(--transition-fast)}.profile__image,.profile__placeholder{width:100%;height:100%;object-fit:cover;display:block}.profile__placeholder{display:flex;align-items:center;justify-content:center;color:var(--color-primary);font-family:var(--font-family-base);font-size:var(--font-size-xl)}.profile--active{background-color:var(--color-primary)}.profile--active .profile__placeholder{color:var(--color-surface)}.profile:hover,.profile:focus-visible{transform:scale(1.1);box-shadow:0 6px 14px var(--color-shadow)}.text-box{display:block;padding:var(--space-lg) var(--space-xl);border:4px solid var(--color-border);border-radius:var(--radius-lg);background-color:var(--color-textbox-dark);color:var(--color-text-inverse);font-family:var(--font-family-base);font-size:var(--font-size-base);line-height:var(--line-height-base);box-shadow:0 4px 10px var(--color-shadow);transition:background-color var(--transition-base)}.text-box:hover{background-color:var(--color-textbox-dark-hover)}.text-box--light{background-color:var(--color-textbox-light);color:var(--color-text)}.text-box--light:hover{background-color:var(--color-textbox-light-hover)}.translucid-text-box{display:block;padding:var(--space-md) var(--space-xl);border:3px solid var(--color-border);border-radius:var(--radius-lg);background-color:var(--color-translucid-base);color:var(--color-text-inverse);font-family:var(--font-family-base);font-size:var(--font-size-base);line-height:var(--line-height-base);box-shadow:0 4px 10px var(--color-shadow);transition:background-color var(--transition-base)}.translucid-text-box__content{opacity:1}.translucid-text-box:hover,.translucid-text-box:focus-visible{background-color:var(--color-translucid-opaque)}.translucid-text-box--dark{background-color:var(--color-chrome-strong)}.translucid-text-box--dark:hover,.translucid-text-box--dark:focus-visible{background-color:var(--color-chrome-strong)}.translucid-text-box--tall{min-height:12rem;display:flex;align-items:flex-start}.button{display:inline-flex;align-items:center;justify-content:center;padding:var(--space-md) clamp(1.5rem,3vw,2.5rem);border:6px solid var(--color-border);border-radius:var(--radius-lg);background:linear-gradient(180deg,var(--color-primary) 0%,var(--color-primary-dark) 100%);color:var(--color-text-inverse);font-family:var(--font-family-base);font-size:var(--font-size-lg);font-weight:var(--font-weight-bold);letter-spacing:.02em;cursor:pointer;box-shadow:0 6px 14px var(--color-shadow);transition:background var(--transition-base),transform var(--transition-fast)}.button:hover:not(:disabled),.button:focus-visible:not(:disabled){background:linear-gradient(180deg,var(--color-primary-hover) 0%,var(--color-primary) 100%)}.button:active:not(:disabled){transform:translateY(1px)}.button:disabled{opacity:.5;cursor:not-allowed}.button--small{padding:var(--space-xs) var(--space-lg);font-size:var(--font-size-base);border-width:4px;border-radius:var(--radius-md)}.header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-md) var(--space-xl);background-color:var(--color-chrome);color:var(--color-text-on-chrome);border-radius:var(--radius-md);position:relative}.header--transparent{background-color:transparent;box-shadow:none;border-radius:0}.header__spacer{display:block;width:1px}.header__logo{font-family:var(--font-family-heading);font-size:var(--font-size-lg);color:var(--color-text-on-chrome);text-decoration:none;letter-spacing:.05em}.header__logo:hover,.header__logo:focus-visible{color:var(--color-primary)}.header__nav{display:flex;align-items:center;gap:var(--space-lg)}.header__link{color:var(--color-text-on-chrome);text-decoration:none;font-family:var(--font-family-base);font-size:var(--font-size-base)}.header__link:hover,.header__link:focus-visible{color:var(--color-primary)}.header__menu-toggle{display:none;width:2.4rem;height:2.4rem;padding:.5rem;background:transparent;border:2px solid var(--color-border);border-radius:var(--radius-sm);cursor:pointer;flex-direction:column;justify-content:space-between;align-items:stretch}.header__menu-toggle:hover,.header__menu-toggle:focus-visible{border-color:var(--color-primary)}.header__menu-toggle-bar{display:block;height:2px;background-color:var(--color-text-on-chrome);border-radius:1px;transition:transform .2s,opacity .2s}@media (max-width: 480px){.header{flex-wrap:nowrap;padding:var(--space-sm) var(--space-md)}.header__menu-toggle{display:flex}.header__nav{display:none;position:absolute;top:100%;right:.5rem;margin-top:.4rem;flex-direction:column;align-items:stretch;gap:var(--space-sm);padding:var(--space-md);background-color:var(--color-chrome);border:2px solid var(--color-border);border-radius:var(--radius-md);box-shadow:0 8px 20px var(--color-shadow);z-index:50;min-width:11rem}.header--menu-open .header__nav{display:flex}.header--menu-open .header__menu-toggle-bar:nth-child(1){transform:translateY(.5rem) rotate(45deg)}.header--menu-open .header__menu-toggle-bar:nth-child(2){opacity:0}.header--menu-open .header__menu-toggle-bar:nth-child(3){transform:translateY(-.5rem) rotate(-45deg)}.header__link{padding:var(--space-xs) var(--space-sm);border-radius:var(--radius-sm)}.header__link:hover,.header__link:focus-visible{background-color:var(--color-textbox-dark-hover)}}.footer{display:flex;align-items:center;justify-content:space-between;gap:var(--space-lg);padding:var(--space-md) var(--space-xl);background-color:var(--color-chrome-strong);color:var(--color-text-on-chrome);border-radius:var(--radius-md)}.footer__nav{display:flex;flex-wrap:wrap;gap:var(--space-lg)}.footer__link{color:var(--color-text-on-chrome);text-decoration:none;font-family:var(--font-family-base);font-size:var(--font-size-base)}.footer__link:hover,.footer__link:focus-visible{color:var(--color-primary)}.footer__lang{padding:var(--space-xs) var(--space-sm);border:2px solid var(--color-border);border-radius:var(--radius-pill);background-color:var(--color-primary-dark);color:var(--color-text-inverse);font-family:var(--font-family-base);font-size:var(--font-size-xs);letter-spacing:.08em;cursor:pointer;transition:background-color var(--transition-fast)}.footer__lang:hover,.footer__lang:focus-visible{background-color:var(--color-primary)}.footer__socials{display:flex;gap:var(--space-md)}.footer__social{color:var(--color-text-on-chrome);display:inline-flex;align-items:center;justify-content:center;width:2rem;height:2rem}.footer__social:hover,.footer__social:focus-visible{color:var(--color-primary)}.footer__social svg{width:100%;height:100%;fill:currentColor}.auth-modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background-color:var(--color-overlay);display:flex;align-items:center;justify-content:center;z-index:1000;padding:var(--space-md)}.auth-modal{position:relative;width:100%;max-width:20rem;padding:var(--space-xl) var(--space-lg) var(--space-lg);background-color:var(--color-chrome);color:var(--color-text-on-chrome);border:3px solid var(--color-border);border-radius:var(--radius-lg);box-shadow:0 10px 30px var(--color-shadow-strong);text-align:center;font-family:var(--font-family-base)}.auth-modal__title{margin-bottom:var(--space-lg);font-size:var(--font-size-lg)}.auth-modal__form{display:flex;flex-direction:column;gap:var(--space-md)}.auth-modal__field{width:100%;padding:var(--space-sm) var(--space-md);border:2px solid var(--color-border);border-radius:var(--radius-pill);background-color:var(--color-surface-cream);color:var(--color-text);font-family:var(--font-family-base);font-size:var(--font-size-sm);text-align:center}.auth-modal__field::placeholder{color:var(--color-text-muted)}.auth-modal__field:focus-visible{outline:3px solid var(--color-focus-ring);outline-offset:2px}.auth-modal__field--error{border-color:var(--color-error, #c0392b)}.auth-modal__field--ok{border-color:var(--color-success, #27ae60)}.auth-modal__field-wrap{display:flex;flex-direction:column;gap:2px}.auth-modal__field-hint{font-size:var(--font-size-xs);text-align:center}.auth-modal__field-hint--error{color:var(--color-error, #c0392b)}.auth-modal__actions{margin-top:var(--space-sm);display:flex;justify-content:center}.auth-modal__switch{margin-top:var(--space-md);background:none;border:none;color:var(--color-text-on-chrome);font-family:var(--font-family-base);font-size:var(--font-size-sm);cursor:pointer;text-decoration:underline}.auth-modal__switch:hover,.auth-modal__switch:focus-visible{color:var(--color-primary)}.auth-modal__close{position:absolute;top:-.75rem;right:-.75rem;width:2rem;height:2rem;border-radius:50%;border:3px solid var(--color-border);background-color:var(--color-primary);color:var(--color-border);font-size:var(--font-size-base);font-weight:var(--font-weight-bold);display:flex;align-items:center;justify-content:center;cursor:pointer}.auth-modal__close:hover,.auth-modal__close:focus-visible{background-color:var(--color-primary-hover)}.main-page{display:flex;flex-direction:column;gap:clamp(3rem,7vw,5rem);padding:0 clamp(3rem,10vw,8rem) clamp(3rem,6vw,5rem)}.main-page__hero{min-height:calc(100vh - 14rem);display:flex;flex-direction:column;justify-content:center;gap:clamp(2rem,4vw,3rem);padding-left:clamp(1rem,4vw,3rem)}.main-page__logo{font-family:var(--font-family-heading);font-size:clamp(3rem,8vw,6rem);letter-spacing:.04em;font-style:italic;color:var(--color-text-on-chrome);line-height:1;margin:0}.main-page__taglines{display:flex;flex-direction:column;gap:var(--space-lg);font-family:var(--font-family-base);font-size:var(--font-size-lg);color:var(--color-text-on-chrome)}.main-page__cta{align-self:flex-start;margin-top:var(--space-lg)}.main-page__section{display:flex;flex-direction:column;gap:var(--space-xl)}.main-page__section-header{display:flex;align-items:center;justify-content:space-between;padding:0 var(--space-sm)}.main-page__section-title{font-family:var(--font-family-heading);font-size:var(--font-size-xl);color:var(--color-text-on-chrome);margin:0}.main-page__see-more{color:var(--color-text-on-chrome);text-decoration:none;font-family:var(--font-family-base);font-size:var(--font-size-base)}.main-page__see-more:hover,.main-page__see-more:focus-visible{color:var(--color-primary)}.main-page__grid{display:flex;flex-wrap:wrap;gap:clamp(1.5rem,4vw,3rem);justify-content:center;padding:var(--space-md) 0}.main-page__row{display:flex;flex-wrap:nowrap;gap:clamp(1.5rem,4vw,3rem);padding:var(--space-md) var(--space-xs);overflow-x:auto;overflow-y:visible;scroll-snap-type:x proximity;scrollbar-gutter:stable}.main-page__row>*{flex:0 0 auto;scroll-snap-align:start}.main-page__row:focus-visible{outline:3px solid var(--color-focus-ring);outline-offset:2px}.main-page__card-visibility-toggle{position:absolute;top:-.5rem;right:-.5rem;width:1.75rem;height:1.75rem;border-radius:50%;border:2px solid var(--color-border);background-color:var(--color-textbox-light);color:var(--color-text);font-size:.85rem;cursor:pointer;z-index:3;display:inline-flex;align-items:center;justify-content:center;transition:transform var(--transition-fast),background-color var(--transition-fast)}.main-page__card-visibility-toggle:hover{transform:scale(1.1)}.main-page__card-visibility-toggle--public{background-color:var(--color-primary);color:var(--color-text-inverse)}.main-page__card-wrapper{position:relative;display:inline-flex;flex-direction:column;align-items:center;gap:var(--space-xs)}.main-page__card-name{max-width:14rem;font-family:var(--font-family-heading);font-size:var(--font-size-base);color:var(--color-text-on-chrome);text-align:center;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;width:100%}.main-page__card-role{position:absolute;top:-.5rem;left:-.5rem;padding:.15rem .5rem;border:2px solid var(--color-border);border-radius:var(--radius-pill);font-family:var(--font-family-base);font-size:var(--font-size-xs);font-weight:700;text-transform:uppercase;letter-spacing:.06em;z-index:3}.main-page__card-role--dm{background-color:var(--color-primary);color:var(--color-text-inverse)}.main-page__card-role--codm{background-color:var(--color-primary-dark);color:var(--color-text-inverse)}.main-page__card-role--player{background-color:var(--color-surface-cream);color:var(--color-text)}.main-page__search{display:flex;flex-direction:column;align-items:center;gap:var(--space-lg)}.main-page__search-input{width:100%;max-width:28rem;padding:var(--space-sm) var(--space-lg);border:4px solid var(--color-border);border-radius:var(--radius-pill);background-color:var(--color-surface-cream);color:var(--color-text);font-family:var(--font-family-base);font-size:var(--font-size-base);background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='%23555'%3E%3Cpath d='M21 20l-5.6-5.6A7.5 7.5 0 1 0 14 16l5.6 5.6L21 20zm-11.5-3a5.5 5.5 0 1 1 0-11 5.5 5.5 0 0 1 0 11z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right var(--space-md) center;background-size:1.25rem 1.25rem;padding-right:2.75rem}.main-page__search-input:focus-visible{outline:3px solid var(--color-focus-ring);outline-offset:2px}.profile-page{display:flex;flex-direction:column;gap:var(--space-xl);padding:var(--space-xl) clamp(3rem,10vw,8rem)}.profile-page__bar{display:flex;justify-content:flex-end;gap:var(--space-sm)}.profile-page__logout{display:inline-flex;align-items:center;gap:var(--space-xs);padding:.55rem 1rem;border:3px solid var(--color-border);border-radius:var(--radius-md);background-color:var(--color-textbox-dark);color:var(--color-text-inverse);font-family:var(--font-family-base);font-size:var(--font-size-sm);cursor:pointer;transition:background-color var(--transition-fast),transform var(--transition-fast)}.profile-page__logout:hover,.profile-page__logout:focus-visible{background-color:var(--color-primary);transform:translateY(-1px)}.profile-page__logout svg{flex-shrink:0}.profile-page__top{display:grid;grid-template-columns:auto 1fr;gap:var(--space-xl);align-items:start}.profile-page__identity{display:flex;flex-direction:column;align-items:flex-start;gap:var(--space-sm)}.profile-page__identity .profile{--profile-size: 9rem}.profile-page__avatar{position:relative;display:inline-block}.profile-page__avatar-edit{position:absolute;right:-.4rem;bottom:-.4rem;display:inline-flex;align-items:center;justify-content:center;width:2.4rem;height:2.4rem;padding:0;border:3px solid var(--color-border);border-radius:50%;background-color:var(--color-primary);color:var(--color-text-inverse);cursor:pointer;box-shadow:0 3px 8px var(--color-shadow);transition:transform var(--transition-fast),background-color var(--transition-fast)}.profile-page__avatar-edit:hover,.profile-page__avatar-edit:focus-visible{background-color:var(--color-primary-hover);transform:scale(1.06)}.profile-page__name-row{display:flex;align-items:center;gap:var(--space-sm)}.profile-page__name{font-family:var(--font-family-heading);font-size:var(--font-size-lg);color:var(--color-text-on-chrome)}.profile-page__name-input{padding:.25rem .5rem;border:2px solid var(--color-border);border-radius:var(--radius-md);background-color:var(--color-surface-cream);color:var(--color-text);font-family:var(--font-family-heading);font-size:var(--font-size-lg);min-width:12rem}.profile-page__privacy{display:inline-flex;align-items:center;flex-wrap:wrap;gap:var(--space-xs) var(--space-sm);color:var(--color-text-on-chrome);font-family:var(--font-family-base);font-size:var(--font-size-sm);cursor:pointer}.profile-page__privacy input[type=checkbox]{width:1.1rem;height:1.1rem;cursor:pointer}.profile-page__privacy-hint{flex-basis:100%;font-size:var(--font-size-xs);opacity:.7;font-style:italic}.profile-page__security{margin-top:var(--space-sm);display:flex;flex-direction:column;gap:var(--space-xs)}.profile-page__security-buttons{display:flex;gap:var(--space-xs)}.profile-page__security-btn{padding:var(--space-xs) var(--space-sm);border:2px solid var(--color-border);border-radius:var(--radius-md);background-color:var(--color-textbox-dark);color:var(--color-text-inverse);font-family:var(--font-family-base);font-size:var(--font-size-sm);cursor:pointer;transition:background-color var(--transition-fast)}.profile-page__security-btn:hover{background-color:var(--color-textbox-dark-hover)}.profile-page__security-btn--active{background-color:var(--color-textbox-dark-hover);border-color:var(--color-text-on-chrome)}.profile-page__security-form{display:flex;flex-direction:column;gap:var(--space-xs)}.profile-page__security-input{padding:var(--space-xs) var(--space-sm);border:2px solid var(--color-border);border-radius:var(--radius-md);background-color:var(--color-surface-cream);color:var(--color-text);font-family:var(--font-family-base);font-size:var(--font-size-sm)}.profile-page__security-input::placeholder{opacity:.6}.profile-page__security-submit{align-self:flex-start;padding:var(--space-xs) var(--space-md);border:2px solid var(--color-border);border-radius:var(--radius-md);background-color:var(--color-textbox-dark);color:var(--color-text-inverse);font-family:var(--font-family-base);font-size:var(--font-size-sm);cursor:pointer;transition:background-color var(--transition-fast)}.profile-page__security-submit:hover:not(:disabled){background-color:var(--color-textbox-dark-hover)}.profile-page__security-submit:disabled{opacity:.4;cursor:not-allowed}.profile-page__security-msg{font-size:var(--font-size-sm);color:var(--color-error, #c0392b);padding:var(--space-xs) 0}.profile-page__security-msg--ok{color:var(--color-success, #27ae60)}.profile-page__description-input{width:100%;min-height:5rem;padding:var(--space-sm) var(--space-md);border:3px solid var(--color-border);border-radius:var(--radius-md);background-color:var(--color-surface-cream);color:var(--color-text);font-family:var(--font-family-base);font-size:var(--font-size-base);resize:vertical}.profile-page__edit{display:inline-flex;align-items:center;justify-content:center;width:2rem;height:2rem;padding:0;border:none;background:transparent;color:var(--color-text-on-chrome);cursor:pointer;border-radius:var(--radius-sm);transition:color var(--transition-fast),transform var(--transition-fast)}.profile-page__edit:hover,.profile-page__edit:focus-visible{color:var(--color-primary);transform:scale(1.1)}.profile-page__description{display:flex;align-items:stretch}.profile-page__description>.translucid-text-box{width:100%}.profile-page__campaigns{display:flex;flex-direction:column;gap:var(--space-md)}.profile-page__section-header{display:flex;align-items:center;justify-content:space-between;padding:0 var(--space-sm)}.profile-page__section-title{font-family:var(--font-family-heading);font-size:var(--font-size-xl);color:var(--color-text-on-chrome);margin:0}.profile-page__see-more{color:var(--color-text-on-chrome);text-decoration:none;font-family:var(--font-family-base);font-size:var(--font-size-base)}.profile-page__see-more:hover,.profile-page__see-more:focus-visible{color:var(--color-primary)}.profile-page__grid{display:flex;flex-wrap:wrap;gap:var(--space-xl);justify-content:flex-start}.profile-page__row{display:flex;flex-wrap:nowrap;gap:var(--space-xl);padding:var(--space-sm) var(--space-xs);overflow-x:auto;overflow-y:visible;scroll-snap-type:x proximity;scrollbar-gutter:stable}.profile-page__row>*{flex:0 0 auto;scroll-snap-align:start}.profile-page__row:focus-visible{outline:3px solid var(--color-focus-ring);outline-offset:2px}.profile-page__campaigns-controls{display:flex;align-items:center;gap:var(--space-md)}.profile-page__campaigns-tabs{display:inline-flex;border:3px solid var(--color-border);border-radius:var(--radius-pill);overflow:hidden;background-color:var(--color-textbox-dark)}.profile-page__campaigns-tab{padding:.55rem 1rem;border:none;background:transparent;color:var(--color-text-inverse);font-family:var(--font-family-base);font-size:var(--font-size-sm);cursor:pointer;transition:background-color var(--transition-fast)}.profile-page__campaigns-tab:hover,.profile-page__campaigns-tab:focus-visible{background-color:var(--color-textbox-dark-hover)}.profile-page__campaigns-tab--active{background-color:var(--color-primary);color:var(--color-text-inverse)}.profile-page__card-wrapper{position:relative;display:inline-flex;flex-direction:column;align-items:center;gap:var(--space-xs)}.profile-page__card-name{max-width:14rem;font-family:var(--font-family-heading);font-size:var(--font-size-base);color:var(--color-text-on-chrome);text-align:center;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;width:100%}.profile-page__card-role{position:absolute;top:-.5rem;left:-.5rem;padding:.15rem .5rem;border:2px solid var(--color-border);border-radius:var(--radius-pill);font-family:var(--font-family-base);font-size:var(--font-size-xs);font-weight:700;text-transform:uppercase;letter-spacing:.06em;z-index:3}.profile-page__card-role--dm{background-color:var(--color-primary);color:var(--color-text-inverse)}.profile-page__card-role--codm{background-color:var(--color-primary-dark);color:var(--color-text-inverse)}.profile-page__card-role--player{background-color:var(--color-surface-cream);color:var(--color-text)}.profile-page__card-actions{position:absolute;bottom:-.6rem;left:50%;transform:translate(-50%);display:inline-flex;gap:.25rem;padding:.2rem .4rem;border:3px solid var(--color-border);border-radius:var(--radius-pill);background-color:var(--color-chrome);z-index:4}.profile-page__card-action{width:1.9rem;height:1.9rem;padding:0;border:none;border-radius:50%;background-color:var(--color-textbox-dark);color:var(--color-text-inverse);cursor:pointer;font-size:.95rem;line-height:1;transition:background-color var(--transition-fast)}.profile-page__card-action:hover:not(:disabled),.profile-page__card-action:focus-visible:not(:disabled){background-color:var(--color-primary)}.profile-page__card-action:disabled{opacity:.4;cursor:not-allowed}.profile-page__card-action--danger{background-color:#c0392b}.profile-page__card-action--danger:hover:not(:disabled),.profile-page__card-action--danger:focus-visible:not(:disabled){background-color:#e74c3c}.profile-page__card-action--public{background-color:var(--color-primary)}.profile-page__card-name-input{max-width:14rem;width:100%;padding:.25rem .5rem;border:2px solid var(--color-border);border-radius:var(--radius-md);background-color:var(--color-surface-cream);color:var(--color-text);font-family:var(--font-family-heading);font-size:var(--font-size-base);text-align:center}.profile-page__card-visibility-toggle{position:absolute;right:-.5rem;bottom:2.2rem;width:2.4rem;height:2.4rem;padding:0;display:inline-flex;align-items:center;justify-content:center;border:3px solid var(--color-border);border-radius:50%;background-color:var(--color-textbox-dark);color:var(--color-text-inverse);font-size:1.05rem;line-height:1;cursor:pointer;box-shadow:0 3px 8px var(--color-shadow);z-index:4;transition:background-color var(--transition-fast),transform var(--transition-fast)}.profile-page__card-visibility-toggle:hover,.profile-page__card-visibility-toggle:focus-visible{transform:scale(1.06)}.profile-page__card-visibility-toggle--public{background-color:var(--color-primary)}.profile-page__card-block{position:absolute;top:0;right:0;bottom:0;left:0;border-radius:var(--radius-lg);background-color:#0000000a;cursor:default;z-index:2}.profile-page__card-index{position:absolute;top:-.5rem;right:-.5rem;padding:.15rem .5rem;border:2px solid var(--color-border);border-radius:var(--radius-pill);background-color:var(--color-textbox-light);color:var(--color-text);font-family:var(--font-family-base);font-size:var(--font-size-xs);font-weight:700;z-index:3}.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}.creator-selector{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--space-xl);min-height:calc(100vh - 14rem);padding:var(--space-xl) clamp(3rem,10vw,8rem)}.creator-selector__title{font-family:var(--font-family-heading);font-size:var(--font-size-xl);color:var(--color-text-on-chrome);margin:0;text-align:center}.creator-selector__buttons{display:flex;flex-wrap:wrap;gap:var(--space-xl);justify-content:center}.chapter-selector{display:flex;flex-direction:column;align-items:center;gap:var(--space-xl);padding:var(--space-xl) clamp(3rem,10vw,8rem)}.chapter-selector__add{display:flex;justify-content:center}.chapter-selector__add-button{min-width:14rem;font-size:2rem;line-height:1}.chapter-selector__list-wrapper{width:100%;max-width:44rem}.chapter-selector__list-wrapper>.text-box{min-height:24rem;max-height:32rem;overflow-y:auto;padding:var(--space-md)}.chapter-selector__list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:var(--space-md)}.chapter-selector__item{width:100%}.chapter-selector__row{display:flex;align-items:stretch;gap:var(--space-sm);cursor:pointer}.chapter-selector__row:hover .translucid-text-box,.chapter-selector__row:focus-visible .translucid-text-box{background-color:var(--color-translucid-opaque)}.chapter-selector__row:focus-visible{outline:3px solid var(--color-focus-ring);outline-offset:3px;border-radius:var(--radius-lg)}.chapter-selector__row-text{flex:1}.chapter-selector__row-text>.translucid-text-box{width:100%;font-family:var(--font-family-heading);font-size:var(--font-size-lg)}.chapter-selector__delete{display:inline-flex;align-items:center;justify-content:center;width:3rem;flex-shrink:0;border:3px solid var(--color-border);border-radius:var(--radius-lg);background-color:var(--color-translucid-base);color:var(--color-text-inverse);cursor:pointer;transition:background-color var(--transition-fast),transform var(--transition-fast)}.chapter-selector__delete:hover,.chapter-selector__delete:focus-visible{background-color:var(--color-primary);transform:scale(1.05)}.chapter-selector__empty{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;min-height:20rem;gap:var(--space-sm);color:var(--color-text-inverse);text-align:center}.chapter-selector__empty-title{font-family:var(--font-family-heading);font-size:var(--font-size-lg);margin:0}.chapter-selector__empty-hint{font-family:var(--font-family-base);font-size:var(--font-size-base);margin:0;opacity:.85}.confirm-modal{max-width:24rem}.confirm-modal__description{margin:0 0 var(--space-md);color:var(--color-text-on-chrome);font-family:var(--font-family-base);font-size:var(--font-size-base);line-height:var(--line-height-base)}.confirm-modal__actions{display:flex;justify-content:center;gap:var(--space-md)}.chapter-or-character{position:relative;display:flex;align-items:center;justify-content:center;flex:1;min-height:calc(100vh - 14rem);padding:clamp(2rem,5vw,4rem) clamp(2rem,6vw,5rem)}.chapter-or-character__toolbar{position:absolute;top:1rem;right:1.5rem;left:1.5rem;display:flex;align-items:center;justify-content:space-between;gap:.5rem;z-index:2}.chapter-or-character__toolbar-left{display:flex;align-items:center;gap:.6rem;min-width:0;flex:1}.chapter-or-character__toolbar-right{display:flex;align-items:center;gap:.5rem;flex-shrink:0}.chapter-or-character__image-button{width:2.2rem;height:2.2rem;border-radius:50%;border:2px solid var(--color-border);background-color:var(--color-textbox-dark);color:var(--color-text-inverse);font-size:1rem;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;transition:transform var(--transition-fast),background-color var(--transition-fast)}.chapter-or-character__image-button:hover{transform:scale(1.08);background-color:var(--color-primary)}.chapter-or-character__visibility-toggle{width:2.2rem;height:2.2rem;border-radius:50%;border:2px solid var(--color-border);background-color:var(--color-textbox-dark);color:var(--color-text-inverse);font-size:1rem;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;flex-shrink:0;transition:transform var(--transition-fast),background-color var(--transition-fast)}.chapter-or-character__visibility-toggle:hover{transform:scale(1.08)}.chapter-or-character__visibility-toggle--public{background-color:var(--color-primary)}.chapter-or-character__delete-campaign{position:absolute;bottom:1.5rem;right:1.5rem;padding:.5rem 1rem;border:2px solid var(--color-border);border-radius:var(--radius-md);background-color:var(--color-textbox-dark);color:var(--color-text-inverse);font-family:var(--font-family-base);font-size:var(--font-size-sm);cursor:pointer;z-index:2;transition:background-color var(--transition-fast),color var(--transition-fast);display:inline-flex;align-items:center;gap:.3rem}.chapter-or-character__delete-campaign:hover{background-color:var(--color-primary);color:var(--color-text-inverse)}.chapter-or-character__campaign-title{flex:1;min-width:0}.chapter-or-character__campaign-name{display:inline-flex;align-items:center;gap:.4rem;font-family:var(--font-family-heading);font-size:var(--font-size-lg);color:var(--color-text-inverse);cursor:pointer;padding:.2rem .4rem;border-radius:var(--radius-sm);transition:background-color var(--transition-fast);max-width:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.chapter-or-character__campaign-name:hover{background-color:#ffffff1a}.chapter-or-character__rename-icon{font-size:.9em;opacity:.6;flex-shrink:0}.chapter-or-character__rename-input{font-family:var(--font-family-heading);font-size:var(--font-size-lg);padding:.2rem .4rem;border:2px solid var(--color-border);border-radius:var(--radius-sm);background-color:var(--color-surface-cream);color:var(--color-text);width:100%;max-width:22rem}.chapter-or-character__members-button{padding:.45rem 1rem;border:3px solid var(--color-border);border-radius:var(--radius-md);background-color:var(--color-primary);color:var(--color-text-inverse);font-family:var(--font-family-heading);font-size:var(--font-size-sm);font-weight:700;cursor:pointer;box-shadow:0 3px 8px var(--color-shadow);transition:background-color var(--transition-fast),transform var(--transition-fast)}.chapter-or-character__members-button:hover,.chapter-or-character__members-button:focus-visible{background-color:var(--color-primary-hover);transform:translateY(-1px)}.chapter-or-character__cards{display:flex;flex-wrap:wrap;gap:clamp(2rem,5vw,4rem);justify-content:center;align-items:stretch;width:100%;max-width:80rem}.chapter-or-character__card{flex:1 1 26rem;max-width:36rem;aspect-ratio:3/4;padding:var(--space-lg);border:6px solid var(--color-border);border-radius:var(--radius-lg);background-color:var(--color-textbox-light);box-shadow:0 8px 18px var(--color-shadow);cursor:pointer;transition:transform var(--transition-base),background-color var(--transition-base),box-shadow var(--transition-base)}.chapter-or-character__card:hover,.chapter-or-character__card:focus-visible{transform:scale(1.04);background-color:var(--color-textbox-light-hover);box-shadow:0 14px 28px var(--color-shadow-strong)}.chapter-or-character__image{width:100%;height:100%;display:flex;align-items:center;justify-content:center;background-color:var(--color-surface-cream);border:5px solid var(--color-border);border-radius:var(--radius-lg)}.chapter-or-character__label{font-family:var(--font-family-heading);font-size:clamp(var(--font-size-xl),4vw,3rem);color:var(--color-text);letter-spacing:.05em}.chapter-page__campaign-nav{display:flex;align-items:center;gap:var(--space-xs);width:100%;max-width:min(95vw,85vh);margin-bottom:var(--space-xs);font-family:var(--font-family-base);font-size:var(--font-size-sm)}.chapter-page__campaign-nav-btn{background:none;border:none;padding:.2rem .4rem;border-radius:var(--radius-sm);color:var(--color-text-inverse);opacity:.7;cursor:pointer;transition:opacity var(--transition-fast),background-color var(--transition-fast)}.chapter-page__campaign-nav-btn:hover{opacity:1;background-color:#ffffff1a}.chapter-page__campaign-nav-btn--active{opacity:1;font-weight:700;cursor:default}.chapter-page__campaign-nav-sep{color:var(--color-text-inverse);opacity:.4;-webkit-user-select:none;user-select:none}.chapter-page{display:flex;flex-direction:column;flex:1;min-height:0;padding:var(--space-md) clamp(2rem,6vw,5rem) var(--space-md);align-items:center}.chapter-page__tabs{display:flex;gap:var(--space-xs);width:100%;max-width:min(95vw,85vh);padding-left:var(--space-lg);margin-bottom:-6px;position:relative;z-index:2}.chapter-page__tab{padding:var(--space-sm) var(--space-xl);border:6px solid var(--color-border);border-bottom:none;border-top-left-radius:var(--radius-lg);border-top-right-radius:var(--radius-lg);background-color:var(--color-textbox-dark);color:var(--color-text-inverse);font-family:var(--font-family-heading);font-size:var(--font-size-lg);letter-spacing:.03em;cursor:pointer;transition:background-color var(--transition-fast)}.chapter-page__tab:hover:not(.chapter-page__tab--active),.chapter-page__tab:focus-visible:not(.chapter-page__tab--active){background-color:var(--color-textbox-dark-hover)}.chapter-page__tab--active{background-color:var(--color-textbox-light);color:var(--color-text);padding-bottom:calc(var(--space-sm) + 6px)}.chapter-page__folder{position:relative;aspect-ratio:1/1;width:100%;max-width:min(95vw,85vh);flex:0 0 auto;display:flex;flex-direction:column;padding:clamp(var(--space-md),2vw,var(--space-xl));background-color:var(--color-textbox-light);border:6px solid var(--color-border);border-radius:var(--radius-lg);box-shadow:0 6px 16px var(--color-shadow)}.chapter-page__folder:fullscreen{aspect-ratio:auto;max-width:none;width:100%;height:100%;border-radius:0;padding:var(--space-lg);background-color:var(--color-textbox-light)}.chapter-page__fullscreen{position:absolute;top:var(--space-sm);right:var(--space-sm);z-index:5;display:inline-flex;align-items:center;justify-content:center;width:2rem;height:2rem;padding:0;border:3px solid var(--color-border);border-radius:50%;background-color:var(--color-surface-cream);color:var(--color-text);cursor:pointer;transition:transform var(--transition-fast),background-color var(--transition-fast)}.chapter-page__fullscreen:hover,.chapter-page__fullscreen:focus-visible{background-color:var(--color-primary);color:var(--color-text-inverse);transform:scale(1.05)}.chapter-page__canvas{flex:1;min-height:0;position:relative;display:flex;flex-direction:column;background-color:var(--color-surface-cream);border:5px solid var(--color-border);border-radius:var(--radius-lg);overflow:hidden}.events-canvas{position:relative;display:flex;flex-direction:column;flex:1;min-height:0}.events-canvas__chapter-bar{display:flex;align-items:center;justify-content:flex-end;padding:var(--space-xs) var(--space-md);background-color:var(--color-surface-cream);border-bottom:2px solid var(--color-border-soft)}.events-canvas__chapter-select{display:inline-flex;align-items:center;gap:var(--space-xs);font-family:var(--font-family-base);font-size:var(--font-size-sm);color:var(--color-text)}.events-canvas__chapter-select select{padding:var(--space-xs) var(--space-sm);border:2px solid var(--color-border);border-radius:var(--radius-md);background-color:var(--color-surface);color:var(--color-text);font-family:var(--font-family-base);font-size:var(--font-size-sm)}.events-canvas__chapter-select-label{font-family:var(--font-family-heading);font-size:var(--font-size-xs);text-transform:uppercase;letter-spacing:.06em;color:var(--color-text-muted)}.events-canvas__viewport{position:relative;flex:1;min-height:0;overflow:hidden;background-color:var(--color-surface-cream);touch-action:none;-webkit-user-select:none;user-select:none}.events-canvas__viewport--tool-select{cursor:default}.events-canvas__viewport--tool-pan{cursor:grab}.events-canvas__viewport--tool-text{cursor:text}.events-canvas__viewport--tool-create{cursor:crosshair}.events-canvas__viewport--tool-connect{cursor:cell}.events-canvas__viewport--tool-redact{cursor:pointer}.events-canvas__viewport--tool-zoom{cursor:ns-resize}.events-canvas__world{position:absolute;top:0;right:0;bottom:0;left:0;transform-origin:0 0}.events-canvas__edges{position:absolute;left:0;top:0;width:4000px;height:4000px;pointer-events:none;overflow:visible;color:var(--color-border)}.events-canvas__block{position:absolute;display:flex;flex-direction:column;padding:0;border:4px solid var(--color-border);border-radius:var(--radius-lg);background-color:var(--color-textbox-dark);color:var(--color-text-inverse);font-family:var(--font-family-base);font-size:var(--font-size-sm);line-height:1.3;box-shadow:0 4px 8px var(--color-shadow);cursor:inherit;overflow:hidden}.events-canvas__block--selected{box-shadow:0 0 0 4px var(--color-primary),0 4px 8px var(--color-shadow)}.events-canvas__block--editing{box-shadow:0 0 0 3px var(--color-focus-ring),0 4px 8px var(--color-shadow)}.events-canvas__block-header{position:relative;display:flex;align-items:center;justify-content:center;gap:.4rem;padding:.45rem .6rem;background-color:var(--color-textbox-light);color:var(--color-text-inverse);border-bottom:3px solid var(--color-border)}.events-canvas__block-type-label{font-family:var(--font-family-heading);font-size:var(--font-size-base);font-weight:700;letter-spacing:.05em;text-transform:uppercase}.events-canvas__block-caret{font-size:var(--font-size-sm);opacity:.9}.events-canvas__block-type-select{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;opacity:0;cursor:pointer;border:none;background:transparent;-webkit-appearance:none;-moz-appearance:none;appearance:none}.events-canvas__block-body{flex:1;min-height:0;padding:var(--space-sm) var(--space-md);overflow:hidden}.events-canvas__block-text{margin:0;overflow:hidden;display:-webkit-box;-webkit-box-orient:vertical;-webkit-line-clamp:4}.events-canvas__block-edit{width:100%;height:100%;margin:0;padding:0;border:none;background:transparent;color:var(--color-text-inverse);font-family:var(--font-family-base);font-size:var(--font-size-sm);line-height:1.3;resize:none}.events-canvas__block-edit:focus-visible{outline:none}.events-canvas__terminal{position:absolute;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.4rem;padding:var(--space-sm);border:5px dashed var(--color-primary);border-radius:var(--radius-lg);background-color:var(--color-primary-dark);color:var(--color-text-inverse);font-family:var(--font-family-heading);font-size:var(--font-size-sm);cursor:pointer;box-shadow:0 4px 12px var(--color-shadow);transition:transform var(--transition-fast),background-color var(--transition-fast)}.events-canvas__terminal:hover,.events-canvas__terminal:focus-visible{background-color:var(--color-primary);transform:scale(1.04);outline:none}.events-canvas__terminal-arrow{font-size:2rem;line-height:1}.events-canvas__terminal-label{text-align:center;letter-spacing:.03em}.events-canvas__toolbar{position:absolute;left:50%;bottom:var(--space-lg);transform:translate(-50%);display:flex;align-items:center;gap:var(--space-sm);padding:var(--space-sm) var(--space-md);border:4px solid var(--color-border);border-radius:var(--radius-pill);background-color:var(--color-textbox-dark);box-shadow:0 4px 12px var(--color-shadow);z-index:5}.events-canvas__tool{display:inline-flex;align-items:center;justify-content:center;width:2.25rem;height:2.25rem;border:none;border-radius:50%;background:transparent;color:var(--color-text-inverse);cursor:pointer;transition:background-color var(--transition-fast),transform var(--transition-fast)}.events-canvas__tool:hover,.events-canvas__tool:focus-visible{background-color:var(--color-textbox-dark-hover);transform:scale(1.08)}.events-canvas__tool--active{background-color:var(--color-primary);color:var(--color-text-inverse)}.events-canvas__create-wrapper{position:relative;display:inline-flex;align-items:center;gap:var(--space-xs)}.events-canvas__create-select{padding:var(--space-xs) var(--space-sm);border:2px solid var(--color-border);border-radius:var(--radius-md);background-color:var(--color-surface-cream);color:var(--color-text);font-family:var(--font-family-base);font-size:var(--font-size-sm)}.events-canvas__notes{flex:1;overflow-y:auto;padding:var(--space-lg);background-color:var(--color-surface);color:var(--color-text);font-family:var(--font-family-base);display:flex;flex-direction:column;gap:var(--space-md)}.events-canvas__notes-empty{margin:auto;color:var(--color-text-muted)}.events-canvas__note{display:grid;grid-template-columns:auto auto 1fr;gap:var(--space-sm) var(--space-md);align-items:baseline;padding:var(--space-sm) 0;border-bottom:1px solid var(--color-border-soft)}.events-canvas__note--alt{opacity:.75;font-style:italic}.events-canvas__note-index{font-family:var(--font-family-heading);font-size:var(--font-size-base);color:var(--color-primary-dark)}.events-canvas__note-type{font-size:var(--font-size-xs);text-transform:uppercase;letter-spacing:.08em;color:var(--color-text-muted)}.events-canvas__note-text{grid-column:1/-1;margin:0;line-height:var(--line-height-base)}.map-canvas{position:relative;display:flex;flex-direction:column;flex:1;min-height:0}.map-canvas__controls{display:flex;align-items:center;gap:var(--space-md);flex-wrap:wrap;padding:var(--space-sm) var(--space-md);color:var(--color-text);font-family:var(--font-family-base);background-color:var(--color-surface-cream);border-bottom:2px solid var(--color-border-soft)}.map-canvas__dim{display:inline-flex;align-items:center;gap:var(--space-xs);font-size:var(--font-size-sm)}.map-canvas__dim input{width:3.5rem;padding:var(--space-xs);border:2px solid var(--color-border);border-radius:var(--radius-sm);background-color:var(--color-surface);font-family:var(--font-family-base);font-size:var(--font-size-sm)}.map-canvas__remove{margin-left:auto;padding:var(--space-xs) var(--space-md);border:3px solid var(--color-border);border-radius:var(--radius-md);background-color:var(--color-primary);color:var(--color-text-inverse);cursor:pointer;font-family:var(--font-family-base)}.map-canvas__remove:hover,.map-canvas__remove:focus-visible{background-color:var(--color-primary-hover)}.map-canvas__chapter-select{display:inline-flex;align-items:center;gap:var(--space-xs);font-family:var(--font-family-base);font-size:var(--font-size-sm)}.map-canvas__chapter-select select{padding:var(--space-xs) var(--space-sm);border:2px solid var(--color-border);border-radius:var(--radius-md);background-color:var(--color-surface);color:var(--color-text);font-family:var(--font-family-base);font-size:var(--font-size-sm)}.map-canvas__chapter-select-label{font-family:var(--font-family-heading);font-size:var(--font-size-xs);text-transform:uppercase;letter-spacing:.06em;color:var(--color-text-muted)}.map-canvas__viewport{position:relative;flex:1;min-height:0;overflow:hidden;background-color:var(--color-primary-dark);touch-action:none}.map-canvas__viewport--tool-pan{cursor:grab}.map-canvas__viewport--tool-zoom{cursor:ns-resize}.map-canvas__grid{position:absolute;left:0;top:0;display:grid;gap:0;transform-origin:0 0;background-color:var(--color-surface);border:3px solid var(--color-border);box-shadow:0 4px 14px var(--color-shadow-strong)}.map-canvas__cell{position:relative;width:2rem;height:2rem;padding:0;border:1px solid rgba(61,43,43,.45);background:transparent;cursor:pointer;display:flex;align-items:center;justify-content:center}.map-canvas__cell:hover{background-color:#ff7fa840}.map-canvas__cell--selected{outline:3px solid var(--color-focus-ring);outline-offset:-3px}.map-canvas__stats{position:absolute;left:50%;bottom:-.55rem;transform:translate(-50%);display:inline-flex;align-items:center;gap:.15rem;padding:0 .2rem;border:1px solid var(--color-border);border-radius:var(--radius-sm);background-color:var(--color-chrome);color:var(--color-text-inverse);font-family:var(--font-family-base);font-size:.55rem;line-height:1;white-space:nowrap;pointer-events:none;z-index:2}.map-canvas__stats-row{display:inline-flex;align-items:center;gap:.25rem}.map-canvas__glyph{display:inline-flex;align-items:center;justify-content:center;width:80%;height:80%}.map-canvas__glyph--character{border-radius:50%;background-color:#2ecc71;border:2px solid #145a32}.map-canvas__glyph--enemy{width:0;height:0;border-left:.6rem solid transparent;border-right:.6rem solid transparent;border-bottom:1rem solid #e74c3c;filter:drop-shadow(0 0 1px #641e16)}.map-canvas__glyph--boss{filter:drop-shadow(0 0 6px #ffffff) drop-shadow(0 0 2px #ffffff)}.map-canvas__glyph--boundary{background-color:#000;width:100%;height:100%}.map-canvas__glyph--wall{background-color:#7f7f7f;width:100%;height:100%}.map-canvas__glyph--object{color:#f1c40f;font-size:1.25rem;text-shadow:0 0 2px #7d6608}.map-canvas__glyph--trap{color:#c0392b;font-size:1.25rem;font-weight:700}.map-canvas__glyph--portrait{width:100%;height:100%;object-fit:cover;border-radius:50%;border:2px solid var(--color-border)}.map-canvas__picker{position:absolute;top:4.5rem;right:var(--space-md);width:14rem;padding:var(--space-sm);border:3px solid var(--color-border);border-radius:var(--radius-lg);background-color:var(--color-chrome);color:var(--color-text-inverse);box-shadow:0 6px 16px var(--color-shadow);z-index:6;display:flex;flex-direction:column;gap:var(--space-xs)}.map-canvas__picker-search{width:100%;padding:var(--space-xs) var(--space-sm);border:2px solid var(--color-border);border-radius:var(--radius-pill);background-color:var(--color-surface-cream);color:var(--color-text);font-family:var(--font-family-base);font-size:var(--font-size-sm)}.map-canvas__picker-list{list-style:none;margin:0;padding:0;max-height:10rem;overflow-y:auto;display:flex;flex-direction:column;gap:2px}.map-canvas__picker-empty{padding:var(--space-xs);font-size:var(--font-size-sm);opacity:.7;text-align:center}.map-canvas__picker-item{width:100%;text-align:left;padding:var(--space-xs) var(--space-sm);border:none;border-radius:var(--radius-sm);background:transparent;color:inherit;font-family:var(--font-family-base);font-size:var(--font-size-sm);cursor:pointer;display:flex;align-items:center;justify-content:space-between;gap:var(--space-sm)}.map-canvas__picker-item:hover,.map-canvas__picker-item:focus-visible{background-color:var(--color-textbox-dark-hover)}.map-canvas__picker-item--active{background-color:var(--color-primary);color:var(--color-text-inverse)}.map-canvas__picker-label{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.map-canvas__picker-thumb{flex-shrink:0;width:1.75rem;height:1.75rem;object-fit:cover;border:2px solid var(--color-border);border-radius:var(--radius-sm);background-color:var(--color-surface-cream)}.map-canvas__picker-thumb--placeholder{background-color:var(--color-textbox-dark-hover)}.map-canvas__picker-create{width:100%;margin-top:var(--space-xs);padding:var(--space-xs) var(--space-sm);border:2px dashed var(--color-border);border-radius:var(--radius-sm);background:transparent;color:var(--color-text-inverse);font-family:var(--font-family-base);font-size:var(--font-size-sm);cursor:pointer;text-align:center;opacity:.8;transition:opacity var(--transition-fast),background-color var(--transition-fast)}.map-canvas__picker-create:hover{opacity:1;background-color:var(--color-textbox-dark-hover)}.map-canvas__tooltip{position:absolute;pointer-events:none;padding:var(--space-xs) var(--space-sm);border:2px solid var(--color-border);border-radius:var(--radius-md);background-color:var(--color-chrome);color:var(--color-text-inverse);font-family:var(--font-family-base);font-size:var(--font-size-sm);box-shadow:0 4px 10px var(--color-shadow-strong);z-index:10;white-space:nowrap}.map-canvas__stats-popup{position:absolute;top:4rem;left:var(--space-lg);width:16rem;max-height:calc(100% - 6rem);overflow-y:auto;padding:var(--space-md);border:4px solid var(--color-border);border-radius:var(--radius-lg);background-color:var(--color-chrome);color:var(--color-text-inverse);font-family:var(--font-family-base);box-shadow:0 8px 20px var(--color-shadow-strong);z-index:11;display:flex;flex-direction:column;gap:var(--space-xs)}.map-canvas__stats-popup label{display:flex;align-items:center;justify-content:space-between;gap:var(--space-sm);font-size:var(--font-size-sm)}.map-canvas__stats-popup label input{width:5rem;padding:var(--space-xs);border:2px solid var(--color-border);border-radius:var(--radius-sm);background-color:var(--color-surface-cream);color:var(--color-text);font-family:var(--font-family-base);text-align:right}.map-canvas__stats-popup-header{display:flex;align-items:center;justify-content:space-between;gap:var(--space-sm);margin-bottom:var(--space-xs);font-family:var(--font-family-heading);font-size:var(--font-size-base)}.map-canvas__stats-popup-image{width:2.5rem;height:2.5rem;object-fit:cover;border:2px solid var(--color-border);border-radius:var(--radius-sm);background-color:var(--color-surface-cream)}.map-canvas__stats-popup-close{background:transparent;border:none;color:var(--color-text-inverse);font-size:var(--font-size-lg);cursor:pointer;line-height:1}.map-canvas__stats-popup-close:hover,.map-canvas__stats-popup-close:focus-visible{color:var(--color-primary)}.map-canvas__stats-popup-note{margin:var(--space-xs) 0 0;font-size:var(--font-size-xs);opacity:.7;font-style:italic}.map-canvas__stats-popup-grid{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-xs)}.map-canvas__stats-popup-grid label input[type=text]{width:6rem;text-align:left}.map-canvas__stats-popup-abilities{display:grid;grid-template-columns:repeat(3,1fr);gap:.25rem .5rem;padding:var(--space-xs) 0;border-top:1px dashed var(--color-border);border-bottom:1px dashed var(--color-border)}.map-canvas__stats-popup-abilities label{flex-direction:column;align-items:stretch;gap:.1rem;font-size:var(--font-size-xs);text-transform:uppercase;letter-spacing:.04em}.map-canvas__stats-popup-abilities label input{width:100%;text-align:center}.map-canvas__stats-popup-attacks{display:flex;flex-direction:column;gap:.25rem}.map-canvas__stats-popup-attacks ul{list-style:none;margin:0;padding:0;max-height:8rem;overflow-y:auto;display:flex;flex-direction:column;gap:.2rem;font-size:var(--font-size-xs)}.map-canvas__stats-popup-attacks li{padding:.2rem .4rem;border:1px solid var(--color-border);border-radius:var(--radius-sm);background-color:var(--color-textbox-dark-hover)}.map-canvas__stats-popup-section-label{font-family:var(--font-family-heading);font-size:var(--font-size-xs);text-transform:uppercase;letter-spacing:.05em;opacity:.85}.chapter-page__folder.character-selector__folder{aspect-ratio:auto;flex:1;min-height:0;max-width:min(95vw,78rem);width:100%}.character-selector>.chapter-page__tabs{max-width:min(95vw,78rem);justify-content:flex-start}.character-selector__canvas{background-color:var(--color-chrome);padding:0;display:flex;flex-direction:column;gap:0;min-height:0}.character-selector__grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(14rem,14rem));gap:var(--space-xl);padding:var(--space-xl);overflow-y:auto;flex:1;min-height:0;align-content:start;justify-content:start;justify-items:start}.character-selector__card-wrapper{position:relative;width:14rem;display:flex;justify-content:flex-start}.character-selector__delete{position:absolute;top:-.5rem;right:-.5rem;width:1.75rem;height:1.75rem;border-radius:50%;border:2px solid var(--color-border);background-color:var(--color-textbox-light);color:var(--color-text);font-size:1rem;line-height:1;font-weight:700;cursor:pointer;z-index:3;display:inline-flex;align-items:center;justify-content:center;transition:background-color var(--transition-fast),transform var(--transition-fast)}.character-selector__delete:hover{background-color:var(--color-primary);color:var(--color-text-inverse);transform:scale(1.1)}.character-selector__search{display:flex;flex-direction:column;align-items:center;gap:var(--space-sm);padding:var(--space-md) var(--space-xl);border-top:4px solid var(--color-border);background-color:var(--color-surface-cream)}.character-selector__search-label{font-family:var(--font-family-heading);font-size:var(--font-size-lg);color:var(--color-text)}.character-selector__search-input{width:100%;max-width:22rem;padding:var(--space-sm) var(--space-lg);border:3px solid var(--color-border);border-radius:var(--radius-pill);background-color:var(--color-surface);color:var(--color-text);font-family:var(--font-family-base);font-size:var(--font-size-base)}.character-selector__search-input:focus-visible{outline:3px solid var(--color-focus-ring);outline-offset:2px}.character-selector__suggestions{list-style:none;margin:var(--space-sm) 0 0;padding:0;width:100%;max-width:22rem;max-height:16rem;overflow-y:auto;border:3px solid var(--color-border);border-radius:var(--radius-md);background-color:var(--color-surface);display:flex;flex-direction:column}.character-selector__suggestion{display:flex;align-items:center;justify-content:space-between;gap:var(--space-md);width:100%;padding:var(--space-xs) var(--space-md);border:none;background:transparent;color:var(--color-text);font-family:var(--font-family-base);font-size:var(--font-size-sm);text-align:left;cursor:pointer;border-bottom:1px solid var(--color-border-soft)}.character-selector__suggestion:last-child{border-bottom:none}.character-selector__suggestion:hover,.character-selector__suggestion:focus-visible{background-color:var(--color-textbox-light);outline:none}.character-selector__suggestion--api{color:var(--color-text)}.character-selector__suggestion-name{display:inline-flex;align-items:center;gap:var(--space-xs);flex:1}.character-selector__suggestion-tag{display:inline-block;padding:0 var(--space-xs);border:1px solid var(--color-border);border-radius:var(--radius-sm);background-color:var(--color-primary);color:var(--color-text-inverse);font-size:var(--font-size-xs);font-weight:700;letter-spacing:.05em}.character-selector__suggestion-image,.character-selector__suggestion-placeholder{flex-shrink:0;width:2.25rem;height:2.25rem;object-fit:cover;border:2px solid var(--color-border);border-radius:var(--radius-sm);background-color:var(--color-surface-cream)}.character-sheet{display:flex;flex-direction:column;gap:var(--space-lg);max-width:60rem;margin:0 auto;padding:var(--space-xl) clamp(1rem,3vw,2rem);color:var(--color-text-on-chrome)}.character-sheet--readonly input,.character-sheet--readonly select,.character-sheet--readonly textarea{pointer-events:none;cursor:default;opacity:.85}.character-sheet__readonly-banner{margin:0;padding:var(--space-sm) var(--space-md);border:2px solid var(--color-border);border-radius:var(--radius-md);background-color:var(--color-textbox-dark);color:var(--color-text-inverse);font-family:var(--font-family-base);font-size:var(--font-size-sm);text-align:center}.character-sheet input[type=number]{-moz-appearance:textfield;-webkit-appearance:textfield;appearance:textfield}.character-sheet input[type=number]::-webkit-outer-spin-button,.character-sheet input[type=number]::-webkit-inner-spin-button{-webkit-appearance:none;-moz-appearance:none;appearance:none;margin:0}.character-sheet__top{display:grid;grid-template-columns:14rem 1fr;gap:var(--space-md);align-items:stretch}@media (max-width: 48rem){.character-sheet__top{grid-template-columns:1fr}}.character-sheet__portrait{display:flex;flex-direction:column;padding:0;border:5px solid var(--color-primary);border-radius:var(--radius-lg);background-color:var(--color-primary);box-shadow:0 4px 12px var(--color-shadow);overflow:hidden}.character-sheet__portrait-image{position:relative;flex:1;aspect-ratio:4/5;background-color:var(--color-surface-cream);display:flex;align-items:center;justify-content:center;border:none;border-radius:0}.character-sheet__portrait-image img{width:100%;height:100%;object-fit:cover}.character-sheet__portrait-placeholder{width:70%;height:80%;background-color:var(--color-surface);border-radius:var(--radius-md)}.character-sheet__portrait-name-row{display:flex;align-items:center;gap:var(--space-xs);padding:.4rem .6rem;background-color:var(--color-primary)}.character-sheet__portrait-name{flex:1;min-width:0;padding:.15rem .3rem;border:2px solid transparent;border-radius:var(--radius-sm);background:transparent;color:var(--color-text-inverse);font-family:var(--font-family-heading);font-size:var(--font-size-base);font-weight:700}.character-sheet__portrait-name::placeholder{color:#ffffffb3}.character-sheet__portrait-name:focus-visible{outline:none;border-color:var(--color-border);background-color:#ffffff26}.character-sheet__portrait-edit{display:inline-flex;align-items:center;justify-content:center;width:1.8rem;height:1.8rem;padding:0;border:2px solid var(--color-surface-cream);border-radius:var(--radius-sm);background-color:transparent;color:var(--color-text-inverse);cursor:pointer;transition:transform var(--transition-fast)}.character-sheet__portrait-edit:hover,.character-sheet__portrait-edit:focus-visible{transform:scale(1.08);background-color:var(--color-surface-cream);color:var(--color-primary)}.character-sheet__stats-panel{display:grid;grid-template-columns:auto 1fr;gap:var(--space-lg);padding:var(--space-md) var(--space-lg);border:5px solid var(--color-border);border-radius:var(--radius-lg);background-color:var(--color-chrome-strong)}@media (max-width: 40rem){.character-sheet__stats-panel{grid-template-columns:1fr}}.character-sheet__stats{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:.35rem;align-self:center}.character-sheet__stat{display:grid;grid-template-columns:2.6rem 3.6rem auto;gap:.4rem;align-items:center}.character-sheet__stat-label{font-family:var(--font-family-heading);font-size:var(--font-size-base);font-weight:700;letter-spacing:.05em;color:var(--color-text-inverse)}.character-sheet__stat-value{padding:.15rem .4rem;border:2px solid var(--color-border);border-radius:var(--radius-sm);background-color:var(--color-surface-cream);color:var(--color-text);font-family:var(--font-family-base);font-size:var(--font-size-base);text-align:center;width:100%}.character-sheet__stat-mod{font-family:var(--font-family-base);font-size:var(--font-size-base);font-weight:600;color:var(--color-text-inverse)}.character-sheet__combat{display:flex;flex-direction:column;gap:.4rem;justify-content:center}.character-sheet__combat-badge{display:grid;grid-template-columns:auto 1fr auto;gap:.5rem;align-items:center;padding:.3rem .6rem;border:3px solid var(--color-border);border-radius:var(--radius-md);background-color:var(--color-primary-dark);color:var(--color-text-inverse)}.character-sheet__combat-label{font-family:var(--font-family-heading);font-size:var(--font-size-sm);font-weight:700;letter-spacing:.04em}.character-sheet__combat-value{padding:.15rem .35rem;border:2px solid var(--color-border);border-radius:var(--radius-sm);background-color:var(--color-surface-cream);color:var(--color-text);font-family:var(--font-family-base);font-size:var(--font-size-sm);font-weight:600;text-align:center;width:4.5rem;min-width:0}.character-sheet__combat-value[type=text]{font-size:clamp(.65rem,1.1vw,var(--font-size-sm));text-align:center}.character-sheet__combat-unit{font-family:var(--font-family-base);font-size:var(--font-size-xs);opacity:.85;min-width:1.25rem;text-align:left}.character-sheet__traits{display:grid;grid-template-columns:repeat(auto-fit,minmax(10rem,1fr));gap:var(--space-sm);padding:var(--space-md) var(--space-lg);border:4px solid var(--color-border);border-radius:var(--radius-lg);background-color:var(--color-chrome-strong)}.character-sheet__field{display:flex;flex-direction:column;gap:.2rem}.character-sheet__field-label{font-family:var(--font-family-heading);font-size:var(--font-size-xs);font-weight:700;letter-spacing:.06em;color:var(--color-text-inverse);text-transform:uppercase}.character-sheet__field-input{padding:.3rem .6rem;border:2px solid var(--color-border);border-radius:var(--radius-md);background-color:var(--color-surface-cream);color:var(--color-text);font-family:var(--font-family-base);font-size:var(--font-size-sm)}.character-sheet__field-input:focus-visible{outline:2px solid var(--color-focus-ring);outline-offset:1px}.character-sheet__homebrew-row{display:grid;grid-template-columns:1fr auto;gap:.3rem}.character-sheet__homebrew-cancel{display:inline-flex;align-items:center;justify-content:center;padding:0 .6rem;border:2px solid var(--color-border);border-radius:var(--radius-sm);background-color:var(--color-primary);color:var(--color-text-inverse);cursor:pointer;font-family:var(--font-family-base);font-size:var(--font-size-base)}.character-sheet__homebrew-cancel:hover,.character-sheet__homebrew-cancel:focus-visible{background-color:var(--color-primary-hover)}.character-sheet__lists{display:grid;grid-template-columns:repeat(auto-fit,minmax(12rem,1fr));gap:var(--space-sm)}.character-sheet__list{display:flex;flex-direction:column;gap:.3rem;padding:var(--space-sm) var(--space-md);border:3px solid var(--color-border);border-radius:var(--radius-lg);background-color:var(--color-chrome-strong);color:var(--color-text-inverse)}.character-sheet__list-header{display:flex;align-items:center;justify-content:space-between;gap:var(--space-xs)}.character-sheet__list-label{font-family:var(--font-family-heading);font-size:var(--font-size-sm);font-weight:700;letter-spacing:.04em}.character-sheet__slots{display:inline-flex;align-items:center;gap:.25rem;font-family:var(--font-family-base);font-size:var(--font-size-xs);color:var(--color-text-inverse)}.character-sheet__slots input{width:2.5rem;padding:.1rem .25rem;border:2px solid var(--color-border);border-radius:var(--radius-sm);background-color:var(--color-surface-cream);color:var(--color-text);font-family:var(--font-family-base);font-size:var(--font-size-xs);text-align:center}.character-sheet__list-items{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:.25rem;max-height:10rem;overflow-y:auto}.character-sheet__list--attacks .character-sheet__list-items{max-height:none;overflow:visible}.character-sheet__attack-detail{overflow:visible}.character-sheet__attack-detail .character-sheet__attack-edit{min-height:4rem;height:auto;overflow:visible;white-space:pre-wrap;word-break:break-word}.character-sheet__list-item{display:flex;align-items:center;justify-content:space-between;gap:.3rem;padding:.2rem .5rem;border:2px solid var(--color-border);border-radius:var(--radius-sm);background-color:var(--color-surface-cream);color:var(--color-text);font-family:var(--font-family-base);font-size:var(--font-size-sm)}.character-sheet__list-item--empty{opacity:.45;justify-content:center;font-style:italic;background-color:#ffffff14;color:var(--color-text-inverse);border-color:transparent}.character-sheet__list-remove{border:none;background:transparent;color:var(--color-text);font-size:var(--font-size-base);line-height:1;cursor:pointer;padding:0 .2rem}.character-sheet__list-remove:hover,.character-sheet__list-remove:focus-visible{color:var(--color-primary)}.character-sheet__list-add{margin-top:.15rem}.character-sheet__list-add input{width:100%;padding:.25rem .5rem;border:2px solid var(--color-border);border-radius:var(--radius-md);background-color:var(--color-surface-cream);color:var(--color-text);font-family:var(--font-family-base);font-size:var(--font-size-sm)}.character-sheet__description-wrapper{display:flex;flex-direction:column;gap:var(--space-sm);padding:var(--space-md) var(--space-lg);border:4px solid var(--color-border);border-radius:var(--radius-lg);background-color:var(--color-chrome-strong)}.character-sheet__description-label{font-family:var(--font-family-heading);font-size:var(--font-size-sm);font-weight:700;letter-spacing:.04em;color:var(--color-text-inverse);text-transform:uppercase}.character-sheet__description{width:100%;min-height:18rem;padding:var(--space-sm) var(--space-md);border:3px solid var(--color-border);border-radius:var(--radius-lg);background-color:var(--color-surface-cream);color:var(--color-text);font-family:var(--font-family-base);font-size:var(--font-size-base);line-height:var(--line-height-base);resize:vertical}.character-sheet__description:focus-visible{outline:3px solid var(--color-focus-ring);outline-offset:2px}.character-sheet__actions{display:flex;justify-content:center}.character-sheet__list--attacks{grid-column:1/-1}.character-sheet__attack{display:flex;flex-direction:column;gap:var(--space-xs);padding:var(--space-xs) 0}.character-sheet__attack-summary{display:flex;align-items:center;gap:var(--space-sm);width:100%;padding:var(--space-xs) var(--space-sm);border:2px solid var(--color-border);border-radius:var(--radius-md);background-color:var(--color-surface-cream);color:var(--color-text);font-family:var(--font-family-base);font-size:var(--font-size-sm);text-align:left;cursor:pointer}.character-sheet__attack-summary:hover,.character-sheet__attack-summary:focus-visible{background-color:var(--color-textbox-light);outline:none}.character-sheet__attack-name{flex:1;font-weight:700}.character-sheet__attack-bonus{padding:0 var(--space-xs);border:1px solid var(--color-border);border-radius:var(--radius-sm);background-color:var(--color-primary);color:var(--color-text-inverse);font-size:var(--font-size-xs);font-weight:700}.character-sheet__attack-damage{color:var(--color-text-muted);font-size:var(--font-size-xs)}.character-sheet__attack-detail{display:flex;flex-direction:column;gap:var(--space-xs);padding:var(--space-sm);border:2px dashed var(--color-border);border-radius:var(--radius-md);background-color:var(--color-surface)}.character-sheet__attack-edit{width:100%;padding:var(--space-xs) var(--space-sm);border:2px solid var(--color-border);border-radius:var(--radius-sm);background-color:var(--color-surface-cream);color:var(--color-text);font-family:var(--font-family-base);font-size:var(--font-size-sm);resize:vertical}.character-sheet__attack-edit:focus-visible{outline:2px solid var(--color-focus-ring);outline-offset:1px}.character-sheet__attack-edit-row{display:flex;gap:var(--space-xs)}.character-sheet__attack-edit-row input{flex:1;padding:var(--space-xs) var(--space-sm);border:2px solid var(--color-border);border-radius:var(--radius-sm);background-color:var(--color-surface-cream);color:var(--color-text);font-family:var(--font-family-base);font-size:var(--font-size-sm)}.image-crop-modal{position:fixed;top:0;right:0;bottom:0;left:0;z-index:200;display:flex;align-items:center;justify-content:center;background-color:#0000008c}.image-crop-modal__panel{display:flex;flex-direction:column;gap:var(--space-md);padding:var(--space-lg);border:5px solid var(--color-border);border-radius:var(--radius-lg);background-color:var(--color-chrome-strong);color:var(--color-text-inverse);box-shadow:0 10px 30px var(--color-shadow-strong);max-width:min(92vw,26rem)}.image-crop-modal__title{margin:0;font-family:var(--font-family-heading);font-size:var(--font-size-lg);color:var(--color-text-inverse)}.image-crop-modal__hint{margin:0;font-size:var(--font-size-sm);opacity:.8}.image-crop-modal__viewport{align-self:center;position:relative;overflow:hidden;border:4px solid var(--color-primary);border-radius:var(--radius-md);background-color:var(--color-surface);cursor:grab;touch-action:none}.image-crop-modal__viewport:active{cursor:grabbing}.image-crop-modal__viewport img{display:block;will-change:transform}.image-crop-modal__zoom{display:flex;align-items:center;gap:var(--space-sm);font-family:var(--font-family-base);font-size:var(--font-size-sm)}.image-crop-modal__zoom input[type=range]{flex:1}.image-crop-modal__actions{display:flex;justify-content:flex-end;gap:var(--space-sm)}.image-crop-modal__cancel,.image-crop-modal__confirm{padding:var(--space-xs) var(--space-md);border:3px solid var(--color-border);border-radius:var(--radius-md);font-family:var(--font-family-heading);font-size:var(--font-size-sm);cursor:pointer;transition:background-color var(--transition-fast)}.image-crop-modal__cancel{background-color:var(--color-textbox-dark);color:var(--color-text-inverse)}.image-crop-modal__cancel:hover,.image-crop-modal__cancel:focus-visible{background-color:var(--color-textbox-dark-hover)}.image-crop-modal__confirm{background-color:var(--color-primary);color:var(--color-text-inverse)}.image-crop-modal__confirm:hover,.image-crop-modal__confirm:focus-visible{background-color:var(--color-primary-hover)}.campaigns-page{display:flex;flex-direction:column;gap:var(--space-xl);padding:var(--space-xl) clamp(3rem,10vw,8rem)}.campaigns-page__title{font-family:var(--font-family-heading);font-size:var(--font-size-xl);color:var(--color-text-on-chrome);margin:0}.campaigns-page__grid{display:flex;flex-wrap:wrap;gap:var(--space-xl);justify-content:flex-start}.profile-page__empty{font-family:var(--font-family-base);color:var(--color-text-on-chrome);opacity:.6}.new-campaign-modal__template-label{display:block;margin:var(--space-sm) 0 0;font-family:var(--font-family-base);font-size:var(--font-size-sm);color:var(--color-text-on-chrome);text-align:left}.new-campaign-modal__select{width:100%;padding:var(--space-sm) var(--space-md);border:2px solid var(--color-border);border-radius:var(--radius-md);background-color:var(--color-surface-cream);color:var(--color-text);font-family:var(--font-family-base);font-size:var(--font-size-sm)}.spoiler-text{display:inline}.spoiler-chunk{display:inline-block;padding:.05em .35em;border-radius:.25em;font-family:inherit;font-size:inherit;line-height:inherit;border:none;cursor:default}.spoiler-chunk--dm{background-color:#000000a6;color:var(--color-primary-hover);cursor:pointer;border:2px solid transparent;transition:border-color var(--transition-fast)}.spoiler-chunk--dm:hover,.spoiler-chunk--dm:focus-visible{border-color:var(--color-primary)}.spoiler-chunk--dm.spoiler-chunk--revealed{background-color:#ffd34d40;color:var(--color-focus-ring)}.spoiler-chunk--redacted{background-color:#000;color:#000;-webkit-user-select:none;user-select:none;letter-spacing:.1em}.spoiler-chunk--revealed-player{background-color:#ffd34d40;color:inherit}.spoiler-textarea{display:flex;flex-direction:column;gap:.35rem}.spoiler-textarea__input{width:100%;padding:var(--space-sm) var(--space-md);border:3px solid var(--color-border);border-radius:var(--radius-lg);background-color:var(--color-surface-cream);color:var(--color-text);font-family:var(--font-family-base);font-size:var(--font-size-sm);line-height:var(--line-height-base);resize:vertical}.spoiler-textarea__input:focus-visible{outline:3px solid var(--color-focus-ring);outline-offset:2px}.spoiler-textarea__toolbar{display:flex;align-items:center;gap:var(--space-sm);font-size:var(--font-size-xs);color:var(--color-text-inverse);opacity:.85}.spoiler-textarea__mark{padding:.25rem .65rem;border:2px solid var(--color-border);border-radius:var(--radius-md);background-color:var(--color-primary);color:var(--color-text-inverse);font-family:var(--font-family-base);font-size:var(--font-size-xs);font-weight:700;cursor:pointer}.spoiler-textarea__mark:hover,.spoiler-textarea__mark:focus-visible{background-color:var(--color-primary-hover)}.spoiler-textarea__hint code{background-color:#0000004d;padding:0 .3rem;border-radius:.2rem}.members-panel{max-width:42rem;width:calc(100% - 2rem)}.members-panel__section{display:flex;flex-direction:column;gap:var(--space-sm);padding-top:var(--space-md);border-top:1px solid rgba(255,255,255,.15)}.members-panel__section:first-of-type{border-top:none;padding-top:0}.members-panel__section-title{margin:0;font-family:var(--font-family-heading);font-size:var(--font-size-sm);letter-spacing:.05em;text-transform:uppercase;color:var(--color-text-inverse);opacity:.9}.members-panel__list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:.5rem}.members-panel__row{display:grid;grid-template-columns:minmax(9rem,1fr) auto auto auto;gap:.5rem;align-items:center;padding:.4rem .6rem;border:2px solid var(--color-border);border-radius:var(--radius-md);background-color:var(--color-chrome-strong)}@media (max-width: 36rem){.members-panel__row{grid-template-columns:1fr}}.members-panel__info{display:flex;align-items:center;gap:.5rem;min-width:0}.members-panel__name{color:var(--color-text-inverse);font-family:var(--font-family-base);font-size:var(--font-size-sm);font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.members-panel__role,.members-panel__character{padding:.2rem .45rem;border:2px solid var(--color-border);border-radius:var(--radius-sm);background-color:var(--color-surface-cream);color:var(--color-text);font-family:var(--font-family-base);font-size:var(--font-size-xs);max-width:9rem}.members-panel__role:disabled,.members-panel__character:disabled{opacity:.6;cursor:not-allowed}.members-panel__remove{display:inline-flex;align-items:center;justify-content:center;width:1.75rem;height:1.75rem;padding:0;border:2px solid var(--color-border);border-radius:var(--radius-sm);background-color:var(--color-primary);color:var(--color-text-inverse);font-size:1rem;line-height:1;cursor:pointer}.members-panel__remove:hover,.members-panel__remove:focus-visible{background-color:var(--color-primary-hover)}.members-panel__add{display:grid;grid-template-columns:1fr auto;gap:.5rem;align-items:center}.members-panel__suggestions{list-style:none;margin:0;padding:0;display:flex;flex-wrap:wrap;gap:.35rem}.members-panel__suggestion{padding:.2rem .55rem;border:2px solid var(--color-border);border-radius:var(--radius-md);background-color:var(--color-primary-dark);color:var(--color-text-inverse);font-family:var(--font-family-base);font-size:var(--font-size-xs);cursor:pointer}.members-panel__suggestion:hover,.members-panel__suggestion:focus-visible{background-color:var(--color-primary)}.members-panel__error{margin:0;color:var(--color-primary-hover);font-size:var(--font-size-xs)}.members-panel__links{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-md)}@media (max-width: 36rem){.members-panel__links{grid-template-columns:1fr}}.members-panel__link-block{display:flex;flex-direction:column;gap:var(--space-sm);padding:var(--space-sm);border:2px solid var(--color-border);border-radius:var(--radius-md);background-color:#ffffff08}.members-panel__link-row{display:grid;grid-template-columns:1fr auto auto;gap:.5rem;align-items:center}@media (max-width: 60rem){.members-panel__link-row{grid-template-columns:1fr}}.members-panel__revoke{border:2px solid var(--color-border);border-radius:var(--radius-md);padding:.25rem .6rem;background-color:transparent;color:var(--color-text-inverse);font-family:var(--font-family-base);font-size:var(--font-size-xs);cursor:pointer}.members-panel__revoke:hover,.members-panel__revoke:focus-visible{background-color:#ffffff1a}.members-panel__share-row{display:flex;flex-wrap:wrap;align-items:center;gap:.4rem;margin-top:.35rem}.members-panel__share-label{color:var(--color-text-inverse);font-size:var(--font-size-xs);opacity:.85;margin-right:.25rem}.members-panel__share{display:inline-flex;align-items:center;padding:.25rem .7rem;border:2px solid var(--color-border);border-radius:var(--radius-md);background-color:var(--color-primary-dark);color:var(--color-text-inverse);font-family:var(--font-family-base);font-size:var(--font-size-xs);font-weight:600;text-decoration:none}.members-panel__share:hover,.members-panel__share:focus-visible{background-color:var(--color-primary)}.members-panel__hint{margin:0;color:var(--color-text-inverse);font-size:var(--font-size-xs);opacity:.8;font-style:italic}.follow-button{padding:.2rem .6rem;border:2px solid var(--color-border);border-radius:var(--radius-md);background-color:var(--color-primary);color:var(--color-text-inverse);font-family:var(--font-family-base);font-size:var(--font-size-xs);font-weight:700;cursor:pointer;transition:background-color var(--transition-fast)}.follow-button:hover,.follow-button:focus-visible{background-color:var(--color-primary-hover)}.follow-button--following{background-color:transparent;color:var(--color-text-inverse)}.follow-button--following:hover,.follow-button--following:focus-visible{background-color:#ffffff1f}.annotation-thread{max-width:60rem;margin:var(--space-lg) auto 0;padding:var(--space-md) var(--space-lg);border:4px solid var(--color-border);border-radius:var(--radius-lg);background-color:var(--color-chrome-strong);color:var(--color-text-inverse);display:flex;flex-direction:column;gap:var(--space-sm);max-height:32rem;min-height:0}.annotation-thread__header{display:flex;align-items:center;gap:var(--space-sm)}.annotation-thread__title{margin:0;font-family:var(--font-family-heading);font-size:var(--font-size-base);letter-spacing:.04em}.annotation-thread__count{display:inline-flex;align-items:center;justify-content:center;min-width:1.5rem;padding:0 .4rem;height:1.5rem;border-radius:999px;background-color:var(--color-primary);color:var(--color-text-inverse);font-size:var(--font-size-xs);font-weight:700}.annotation-thread__empty{margin:0;font-style:italic;opacity:.75;font-size:var(--font-size-sm)}.annotation-thread__list{list-style:none;margin:0;padding:0 var(--space-xs) 0 0;display:flex;flex-direction:column;gap:.5rem;flex:1;min-height:0;max-height:16rem;overflow-y:auto;scrollbar-gutter:stable}.annotation-thread__item{padding:.5rem .75rem;border:2px solid var(--color-border);border-radius:var(--radius-md);background-color:#ffffff0f}.annotation-thread__item-head{display:flex;align-items:center;gap:.5rem;font-size:var(--font-size-xs);opacity:.85}.annotation-thread__author{font-weight:700;color:var(--color-primary-hover)}.annotation-thread__time{opacity:.7}.annotation-thread__delete{margin-left:auto;border:none;background:transparent;color:var(--color-text-inverse);font-size:1rem;cursor:pointer;line-height:1;padding:0 .25rem}.annotation-thread__delete:hover,.annotation-thread__delete:focus-visible{color:var(--color-primary)}.annotation-thread__body{margin:.35rem 0 0;font-family:var(--font-family-base);font-size:var(--font-size-sm);line-height:var(--line-height-base);white-space:pre-wrap}.annotation-thread__form{display:grid;grid-template-columns:1fr auto;gap:.5rem;align-items:start}.annotation-thread__input{width:100%;padding:var(--space-sm) var(--space-md);border:3px solid var(--color-border);border-radius:var(--radius-md);background-color:var(--color-surface-cream);color:var(--color-text);font-family:var(--font-family-base);font-size:var(--font-size-sm);resize:vertical}.annotation-thread__submit{padding:.4rem .9rem;border:3px solid var(--color-border);border-radius:var(--radius-md);background-color:var(--color-primary);color:var(--color-text-inverse);font-family:var(--font-family-base);font-size:var(--font-size-sm);font-weight:700;cursor:pointer}.annotation-thread__submit:hover:not(:disabled),.annotation-thread__submit:focus-visible:not(:disabled){background-color:var(--color-primary-hover)}.annotation-thread__submit:disabled{opacity:.5;cursor:not-allowed}.users-page{max-width:48rem;margin:0 auto;padding:var(--space-xl) clamp(1rem,4vw,3rem);color:var(--color-text-on-chrome);display:flex;flex-direction:column;gap:var(--space-md)}.users-page__title{margin:0;font-family:var(--font-family-heading);font-size:var(--font-size-xl);color:var(--color-text-inverse)}.users-page__tabs{display:flex;gap:.4rem;border-bottom:3px solid var(--color-border)}.users-page__tab{padding:.35rem .9rem;border:3px solid var(--color-border);border-bottom:none;border-radius:var(--radius-md) var(--radius-md) 0 0;background-color:var(--color-chrome-strong);color:var(--color-text-inverse);font-family:var(--font-family-heading);font-size:var(--font-size-sm);cursor:pointer;transform:translateY(3px)}.users-page__tab--active{background-color:var(--color-primary)}.users-page__search{padding:var(--space-sm) var(--space-md);border:3px solid var(--color-border);border-radius:var(--radius-md);background-color:var(--color-surface-cream);color:var(--color-text);font-family:var(--font-family-base);font-size:var(--font-size-sm)}.users-page__empty{margin:0;font-style:italic;opacity:.75}.users-page__scroll{max-height:60vh;overflow-y:auto;padding-right:.25rem;border:3px solid var(--color-border);border-radius:var(--radius-md);background-color:var(--color-textbox-dark)}.users-page__list{list-style:none;margin:0;padding:.5rem;display:flex;flex-direction:column;gap:.5rem}.users-page__item{display:grid;grid-template-columns:1fr auto;gap:.75rem;align-items:center;padding:.5rem .75rem;border:3px solid var(--color-border);border-radius:var(--radius-md);background-color:var(--color-chrome-strong)}.users-page__link{display:grid;grid-template-columns:auto 1fr;gap:.75rem;align-items:center;text-decoration:none;color:inherit;min-width:0}.users-page__link:hover .users-page__link__name,.users-page__link:focus-visible .users-page__link__name{color:var(--color-primary-hover)}.users-page__name{font-family:var(--font-family-base);font-size:var(--font-size-base);font-weight:600;color:var(--color-text-inverse);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.invite-page{max-width:36rem;margin:0 auto;padding:var(--space-xl) clamp(1rem,4vw,3rem);color:var(--color-text-on-chrome);display:flex;flex-direction:column;gap:var(--space-md);align-items:center;text-align:center}.invite-page__title{margin:0;font-family:var(--font-family-heading);font-size:var(--font-size-xl);color:var(--color-text-inverse)}.invite-page__body{margin:0;font-family:var(--font-family-base);font-size:var(--font-size-base);color:var(--color-text-inverse);opacity:.9;line-height:var(--line-height-base)}.invite-page__meta{display:grid;grid-template-columns:auto auto;gap:.4rem 1.2rem;padding:var(--space-sm) var(--space-lg);border:3px solid var(--color-border);border-radius:var(--radius-md);background-color:var(--color-chrome-strong);margin:0}.invite-page__meta dt{font-family:var(--font-family-heading);font-size:var(--font-size-xs);letter-spacing:.05em;text-transform:uppercase;opacity:.75}.invite-page__meta dd{margin:0;font-family:var(--font-family-base);font-size:var(--font-size-base);font-weight:700}.invite-page__actions{display:flex;gap:var(--space-sm)}.info-page{display:flex;flex-direction:column;gap:var(--space-xl);padding:clamp(2rem,6vw,5rem) clamp(2rem,8vw,6rem);color:var(--color-text-on-chrome)}.info-page__header{display:flex;flex-direction:column;gap:var(--space-sm);max-width:60rem;margin:0 auto;width:100%;text-align:center}.info-page__title{font-family:var(--font-family-heading);font-size:clamp(var(--font-size-xl),4vw,3rem);color:var(--color-text-on-chrome);margin:0;letter-spacing:.04em}.info-page__lead{margin:0;font-family:var(--font-family-base);font-size:var(--font-size-lg);color:var(--color-text-on-chrome);opacity:.85;line-height:var(--line-height-base)}.info-page__panel{width:100%;max-width:60rem;margin:0 auto;padding:clamp(var(--space-lg),4vw,var(--space-xl));border:5px solid var(--color-border);border-radius:var(--radius-lg);background-color:var(--color-chrome-strong);color:var(--color-text-inverse);box-shadow:0 6px 16px var(--color-shadow);display:flex;flex-direction:column;gap:var(--space-xl)}.info-page__section{display:flex;flex-direction:column;gap:var(--space-sm)}.info-page__section-title{margin:0;font-family:var(--font-family-heading);font-size:var(--font-size-xl);color:var(--color-text-inverse);letter-spacing:.03em;border-bottom:3px solid var(--color-primary);padding-bottom:var(--space-xs)}.info-page__body{margin:0;font-family:var(--font-family-base);font-size:var(--font-size-base);line-height:var(--line-height-base);color:var(--color-text-inverse);white-space:pre-wrap}.info-page__list{margin:0;padding-left:var(--space-xl);display:flex;flex-direction:column;gap:var(--space-xs);font-family:var(--font-family-base);font-size:var(--font-size-base);line-height:var(--line-height-base);color:var(--color-text-inverse)}.info-page__list li::marker{color:var(--color-primary)}.info-page__form{display:flex;flex-direction:column;gap:var(--space-md)}.info-page__field{display:flex;flex-direction:column;gap:var(--space-xs)}.info-page__field-label{font-family:var(--font-family-heading);font-size:var(--font-size-sm);text-transform:uppercase;letter-spacing:.05em;color:var(--color-text-inverse)}.info-page__field-input{padding:var(--space-sm) var(--space-md);border:3px solid var(--color-border);border-radius:var(--radius-md);background-color:var(--color-surface-cream);color:var(--color-text);font-family:var(--font-family-base);font-size:var(--font-size-base)}.info-page__field-input:focus-visible{outline:3px solid var(--color-focus-ring);outline-offset:2px}.info-page__field-input--textarea{resize:vertical;min-height:7rem}.info-page__form-actions{display:flex;justify-content:flex-end}.info-page__contact-form{border-top:2px dashed var(--color-border);padding-top:var(--space-lg)}.templates-page{display:flex;flex-direction:column;gap:var(--space-xl);padding:var(--space-xl) clamp(2rem,6vw,5rem);color:var(--color-text-on-chrome)}.templates-page__header{display:flex;flex-direction:column;gap:var(--space-sm);max-width:60rem}.templates-page__title{margin:0;font-family:var(--font-family-heading);font-size:clamp(var(--font-size-xl),4vw,3rem);color:var(--color-text-on-chrome)}.templates-page__lead{margin:0;font-family:var(--font-family-base);font-size:var(--font-size-lg);opacity:.85;line-height:var(--line-height-base)}.templates-page__controls{display:flex}.templates-page__search{width:100%;max-width:28rem;padding:.65rem var(--space-lg);border:4px solid var(--color-border);border-radius:var(--radius-pill);background-color:var(--color-surface-cream);color:var(--color-text);font-family:var(--font-family-base);font-size:var(--font-size-base)}.templates-page__search:focus-visible{outline:3px solid var(--color-focus-ring);outline-offset:2px}.templates-page__empty{padding:var(--space-xl);border:4px dashed var(--color-border);border-radius:var(--radius-lg);background-color:var(--color-chrome-strong);color:var(--color-text-inverse);text-align:center;font-family:var(--font-family-base);font-size:var(--font-size-base)}.templates-page__empty p{margin:0 0 var(--space-sm)}.templates-page__empty-hint{opacity:.75;font-size:var(--font-size-sm);font-style:italic}.templates-page__grid{list-style:none;margin:0;padding:0;display:grid;grid-template-columns:repeat(auto-fill,minmax(15rem,1fr));gap:var(--space-xl)}.templates-page__item{display:flex;flex-direction:column;align-items:center;gap:var(--space-sm);padding:var(--space-md);border:4px solid var(--color-border);border-radius:var(--radius-lg);background-color:var(--color-chrome-strong);color:var(--color-text-inverse)}.templates-page__item-info{display:flex;flex-direction:column;align-items:center;gap:.15rem;text-align:center}.templates-page__item-name{font-family:var(--font-family-heading);font-size:var(--font-size-base);color:var(--color-text-inverse)}.templates-page__item-author{font-family:var(--font-family-base);font-size:var(--font-size-sm);color:var(--color-primary-hover)}.templates-page__item-source{font-family:var(--font-family-base);font-size:var(--font-size-xs);color:var(--color-text-inverse);opacity:.7;font-style:italic}.templates-page__item-actions{display:flex;flex-wrap:wrap;gap:var(--space-xs);justify-content:center}.templates-page__login-hint{font-family:var(--font-family-base);font-size:var(--font-size-sm);font-style:italic;opacity:.7}.campaign-view-page{display:flex;flex-direction:column;gap:var(--space-xl);padding:var(--space-xl) clamp(2rem,6vw,5rem);color:var(--color-text-on-chrome)}.campaign-view-page__hero{display:flex;gap:var(--space-xl);align-items:flex-start;flex-wrap:wrap}.campaign-view-page__cover{width:12rem;height:12rem;object-fit:cover;border-radius:var(--radius-lg);border:4px solid var(--color-border);flex-shrink:0}.campaign-view-page__hero-info{display:flex;flex-direction:column;gap:var(--space-sm);min-width:0}.campaign-view-page__badge{display:inline-block;padding:.2rem .6rem;border:2px solid var(--color-border);border-radius:var(--radius-pill);background-color:var(--color-textbox-dark);color:var(--color-text-inverse);font-family:var(--font-family-base);font-size:var(--font-size-xs);font-weight:700;text-transform:uppercase;letter-spacing:.06em;width:fit-content}.campaign-view-page__title{margin:0;font-family:var(--font-family-heading);font-size:clamp(var(--font-size-xl),4vw,2.5rem);color:var(--color-text-on-chrome)}.campaign-view-page__lead{margin:0;font-family:var(--font-family-base);font-size:var(--font-size-lg);opacity:.85}.campaign-view-page__stats{margin:0;font-family:var(--font-family-base);font-size:var(--font-size-base);opacity:.75}.campaign-view-page__body{display:grid;grid-template-columns:repeat(auto-fit,minmax(18rem,1fr));gap:var(--space-xl)}.campaign-view-page__section{display:flex;flex-direction:column;gap:var(--space-md);padding:var(--space-lg);border:4px solid var(--color-border);border-radius:var(--radius-lg);background-color:var(--color-chrome-strong)}.campaign-view-page__section-title{margin:0;font-family:var(--font-family-heading);font-size:var(--font-size-lg);color:var(--color-text-inverse)}.campaign-view-page__list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:var(--space-xs)}.campaign-view-page__member{display:flex;align-items:center;justify-content:space-between;gap:var(--space-sm);padding:var(--space-xs) 0;border-bottom:1px solid rgba(255,255,255,.08)}.campaign-view-page__member:last-child{border-bottom:none}.campaign-view-page__member-name{font-family:var(--font-family-base);font-size:var(--font-size-base);color:var(--color-text-inverse)}.campaign-view-page__member-role{font-family:var(--font-family-base);font-size:var(--font-size-xs);font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--color-primary-hover)}.campaign-view-page__chapter{display:flex;align-items:baseline;gap:var(--space-xs);padding:var(--space-xs) 0;border-bottom:1px solid rgba(255,255,255,.08)}.campaign-view-page__chapter:last-child{border-bottom:none}.campaign-view-page__chapter-num{font-family:var(--font-family-base);font-size:var(--font-size-sm);opacity:.6;flex-shrink:0}.campaign-view-page__chapter-title{font-family:var(--font-family-heading);font-size:var(--font-size-base);color:var(--color-text-inverse)}.campaign-view-page__footer-note{margin:0;font-family:var(--font-family-base);font-size:var(--font-size-sm);opacity:.65}.campaign-view-page__footer-note a{color:var(--color-primary-hover);text-decoration:underline}.user-profile-page{display:flex;flex-direction:column;gap:var(--space-xl);padding:var(--space-xl) clamp(2rem,8vw,6rem);color:var(--color-text-on-chrome)}.user-profile-page__title{margin:0;font-family:var(--font-family-heading);font-size:clamp(var(--font-size-xl),4vw,2.5rem);color:var(--color-text-on-chrome)}.user-profile-page__lead{margin:0;font-family:var(--font-family-base);opacity:.85}.user-profile-page__back{align-self:flex-start;color:var(--color-primary-hover);text-decoration:underline}.user-profile-page__top{display:grid;grid-template-columns:auto 1fr;gap:var(--space-xl);align-items:start}@media (max-width: 40rem){.user-profile-page__top{grid-template-columns:1fr}}.user-profile-page__identity{display:flex;flex-direction:column;align-items:flex-start;gap:var(--space-sm)}.user-profile-page__identity .profile{--profile-size: 9rem}.user-profile-page__description{display:flex;align-items:stretch}.user-profile-page__description>.translucid-text-box{width:100%}.user-profile-page__private{margin:0;padding:var(--space-md) var(--space-lg);border:3px dashed var(--color-border);border-radius:var(--radius-md);background-color:var(--color-chrome-strong);color:var(--color-text-inverse);font-style:italic;text-align:center}.user-profile-page__campaigns{display:flex;flex-direction:column;gap:var(--space-md)}.user-profile-page__section-title{margin:0;font-family:var(--font-family-heading);font-size:var(--font-size-xl);color:var(--color-text-on-chrome)}.user-profile-page__empty{margin:0;font-style:italic;opacity:.7}.user-profile-page__grid{list-style:none;margin:0;padding:0;display:flex;flex-wrap:wrap;gap:var(--space-xl)}.user-profile-page__card{position:relative;display:inline-flex;flex-direction:column;align-items:center;gap:var(--space-xs)}.user-profile-page__card-name{max-width:14rem;font-family:var(--font-family-heading);font-size:var(--font-size-base);color:var(--color-text-on-chrome);text-align:center;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;width:100%}.user-profile-page__card-role{position:absolute;top:-.5rem;left:-.5rem;padding:.15rem .5rem;border:2px solid var(--color-border);border-radius:var(--radius-pill);background-color:var(--color-primary);color:var(--color-text-inverse);font-family:var(--font-family-base);font-size:var(--font-size-xs);font-weight:700;text-transform:uppercase;letter-spacing:.06em}@media (max-width: 768px){.header{padding:var(--space-sm) var(--space-md);flex-wrap:wrap;gap:var(--space-sm)}.header__nav{gap:var(--space-md);flex-wrap:wrap}.header__logo{font-size:var(--font-size-base)}.footer{flex-direction:column;align-items:center;text-align:center;padding:var(--space-md);gap:var(--space-md)}.footer__nav{justify-content:center}.main-page{padding:0 var(--space-md) var(--space-xl);gap:var(--space-xl)}.main-page__hero{min-height:auto;padding:var(--space-xl) 0;padding-left:0}.main-page__taglines{font-size:var(--font-size-base)}.profile-page{padding:var(--space-md)}.profile-page__campaigns{grid-template-columns:repeat(auto-fit,minmax(10rem,1fr))}.chapter-selector{padding:var(--space-md)}.chapter-selector__add-button{min-width:10rem;font-size:var(--font-size-lg)}.chapter-selector__list-wrapper{max-width:100%}.character-selector__grid{gap:var(--space-md);justify-content:center}.chapter-page{padding:var(--space-sm)}.chapter-page__tab{padding:var(--space-xs) var(--space-md);font-size:var(--font-size-base)}.chapter-page__folder{padding:var(--space-sm);border-width:4px}.events-canvas__toolbar{bottom:var(--space-sm);padding:var(--space-xs) var(--space-sm);gap:var(--space-xs);max-width:calc(100% - 2rem);overflow-x:auto}.events-canvas__tool{width:2rem;height:2rem;flex-shrink:0}.map-canvas__controls{padding:var(--space-xs) var(--space-sm);gap:var(--space-sm)}.map-canvas__picker{width:11rem;right:var(--space-sm);top:3.5rem}.map-canvas__stats-popup{width:min(15rem,100vw - 2rem);left:var(--space-sm);top:var(--space-sm);padding:var(--space-sm)}.character-sheet{padding:var(--space-md) var(--space-sm);gap:var(--space-md)}.character-sheet__top{grid-template-columns:1fr}.character-sheet__stats-panel{grid-template-columns:1fr;padding:var(--space-sm) var(--space-md)}.character-sheet__traits{grid-template-columns:repeat(auto-fit,minmax(8rem,1fr));padding:var(--space-sm) var(--space-md)}.character-sheet__lists{grid-template-columns:1fr}.character-sheet__description{min-height:12rem}.auth-modal,.new-campaign-modal,.confirm-modal{width:min(100vw - 1.5rem,24rem);padding:var(--space-md)}.members-panel,.annotation-thread{padding:var(--space-sm)}.campaigns-page{padding:var(--space-md)}.campaigns-page__grid{grid-template-columns:repeat(auto-fit,minmax(10rem,1fr));gap:var(--space-md)}.users-page,.invite-page{padding:var(--space-md)}.campaign-card{--campaign-card-size: 11rem}.creator-selector{padding:var(--space-md);gap:var(--space-md)}.chapter-or-character{padding:var(--space-md)}.chapter-or-character__grid{grid-template-columns:1fr;gap:var(--space-md)}}@media (max-width: 480px){.header__spacer{display:none}.header__link{font-size:var(--font-size-sm)}.footer__nav{gap:var(--space-sm);font-size:var(--font-size-sm)}.footer__link{font-size:var(--font-size-sm)}.character-sheet__stat{grid-template-columns:2.4rem 2.8rem auto}.character-sheet__combat-value{width:3.2rem}.character-sheet__traits{grid-template-columns:1fr}.events-canvas__tool{width:1.85rem;height:1.85rem}.map-canvas__picker{width:calc(100vw - 2rem);right:var(--space-sm);left:var(--space-sm);top:3rem}}@media (max-width: 360px){:root{--space-md: .8rem;--space-lg: 1.1rem;--space-xl: 1.5rem}.header{padding:var(--space-xs) var(--space-sm)}.header__logo{font-size:var(--font-size-sm)}.main-page,.chapter-selector,.chapter-page,.character-selector,.character-sheet,.campaigns-page,.users-page,.invite-page,.profile-page{padding:var(--space-sm)}.campaign-card{--campaign-card-size: 9rem;border-width:3px}.chapter-page__tabs{margin-left:var(--space-sm)}.chapter-page__tab{padding:var(--space-xs) var(--space-sm);font-size:var(--font-size-sm);border-width:4px}.auth-modal,.new-campaign-modal,.confirm-modal{width:calc(100vw - 1rem);padding:var(--space-sm)}.character-sheet__stat{grid-template-columns:2.2rem 2.4rem auto;gap:.25rem}.character-sheet__stat-label{font-size:var(--font-size-sm)}.character-sheet__combat-value{width:2.8rem}.character-sheet__list-items{max-height:7rem}.character-sheet__description{min-height:8rem}.events-canvas__toolbar{gap:.15rem;padding:.2rem var(--space-xs)}.events-canvas__tool{width:1.7rem;height:1.7rem}.map-canvas__stats-popup{width:calc(100vw - 1rem);left:.5rem;top:.5rem}.map-canvas__stats-popup-grid,.map-canvas__stats-popup-abilities{grid-template-columns:1fr 1fr}.main-page__taglines{font-size:var(--font-size-sm)}.main-page__section-title{font-size:var(--font-size-lg)}.main-page__search-input{max-width:100%;width:100%;font-size:var(--font-size-sm);padding:var(--space-xs) var(--space-md)}.main-page__row{flex-direction:column;align-items:center;overflow-x:visible;overflow-y:auto;max-height:26rem}.main-page__section-header{flex-direction:column;align-items:flex-start;gap:var(--space-xs)}.profile-page{text-align:center}.profile-page__top{grid-template-columns:1fr;justify-items:center;gap:var(--space-md)}.profile-page__identity{width:100%;align-items:center;text-align:center}.profile-page__name-row{justify-content:center}.profile-page__description{width:100%;max-width:100%}.profile-page__section-header,.profile-page__campaigns-controls{flex-direction:column;align-items:stretch;gap:var(--space-sm)}.profile-page__campaigns-tabs{justify-content:center;flex-wrap:wrap}.profile-page__see-more{align-self:center;display:inline-block}.profile-page__row{flex-direction:column;align-items:center;overflow-x:visible;overflow-y:auto;max-height:28rem}.chapter-or-character{flex-direction:column;align-items:stretch;justify-content:flex-start;min-height:auto;padding:var(--space-md) var(--space-sm);gap:var(--space-md)}.chapter-or-character__toolbar{position:static;flex-direction:column;align-items:stretch;gap:var(--space-xs);padding:0;width:100%}.chapter-or-character__toolbar-left,.chapter-or-character__toolbar-right{width:100%;justify-content:center;flex-wrap:wrap}.chapter-or-character__campaign-title{text-align:center}.chapter-or-character__cards{flex-direction:column;gap:var(--space-md);width:100%;max-width:100%}.chapter-or-character__card{flex:0 0 auto;width:100%;max-width:100%;aspect-ratio:4/3;min-width:0}.chapter-or-character__delete-campaign{position:static;align-self:center;margin:var(--space-md) auto 0}.users-page{max-width:100%;margin:0 auto;padding:var(--space-sm) var(--space-xs);text-align:center}.users-page__title{font-size:var(--font-size-lg)}.users-page__search{width:100%;max-width:100%;font-size:var(--font-size-sm)}.users-page__scroll{max-width:100%}.users-page__item{max-width:100%;padding:.4rem .5rem;gap:.5rem}.users-page__link{gap:.5rem;min-width:0}.users-page__name{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.chapter-selector__row{gap:var(--space-xs)}.chapter-selector__row-text>.translucid-text-box{font-size:var(--font-size-sm);line-height:1.2}.chapter-selector__delete{width:2rem}.character-sheet{max-width:100%;padding:var(--space-sm) var(--space-xs)}.character-sheet__top{grid-template-columns:1fr}.character-sheet__portrait{max-width:100%;margin:0 auto}.character-sheet__portrait-image{max-width:100%}.character-sheet__stats,.character-sheet__combat{gap:.2rem}.character-sheet__traits{grid-template-columns:1fr;padding:var(--space-sm) var(--space-md);gap:.4rem}.character-sheet__field{min-width:0}.character-sheet__field-label{font-size:var(--font-size-sm)}.character-sheet__field-input{width:100%;max-width:100%;min-width:0;box-sizing:border-box;font-size:var(--font-size-sm)}.character-sheet__homebrew-row{grid-template-columns:1fr auto;min-width:0}.image-crop-modal__panel{max-width:calc(100vw - 1rem);padding:var(--space-md);gap:var(--space-sm)}.image-crop-modal__actions{flex-wrap:wrap;gap:.4rem}.image-crop-modal__cancel,.image-crop-modal__confirm{padding:var(--space-xs) var(--space-sm)}.chapter-page__folder.character-selector__folder{flex:none;max-height:calc(100dvh - 12rem);max-height:calc(100vh - 12rem)}.character-selector__canvas{flex:1;min-height:0}.character-selector__grid{grid-template-columns:minmax(0,14rem);justify-content:center;justify-items:center;padding:var(--space-md) var(--space-sm);overflow-y:auto;overflow-x:hidden}.character-selector__card-wrapper{width:100%;max-width:14rem;justify-content:center}.character-selector__delete{top:-.5rem;right:-.5rem}.character-selector__search{flex-shrink:0}.chapter-page__campaign-nav{flex-wrap:wrap;font-size:var(--font-size-xs)}}
