:root{--color-white: #ffffff;--color-bg: #f8faf9;--color-green-dark: #1a5f3a;--color-green: #2d7a4a;--color-green-light: #3d9b5c;--color-green-bright: #4caf70;--color-gray-900: #1a1a1a;--color-gray-600: #5a5a5a;--color-gray-400: #8a8a8a;--color-gray-200: #e8ece9;--radius-sm: 8px;--radius-md: 12px;--radius-lg: 20px;--shadow-sm: 0 2px 8px rgba(26, 95, 58, .08);--shadow-md: 0 4px 16px rgba(26, 95, 58, .12);--font: "Inter", -apple-system, BlinkMacSystemFont, sans-serif}*,*:before,*:after{box-sizing:border-box}html{scroll-behavior:smooth}html,body{scrollbar-width:thin;scrollbar-color:var(--color-green) var(--color-gray-200)}::-webkit-scrollbar{width:10px;height:10px}::-webkit-scrollbar-track{background:var(--color-gray-200);border-radius:5px}::-webkit-scrollbar-thumb{background:var(--color-green);border-radius:5px;border:2px solid var(--color-gray-200)}::-webkit-scrollbar-thumb:hover{background:var(--color-green-light)}::-webkit-scrollbar-corner{background:var(--color-gray-200);border-radius:5px}body{margin:0;min-height:100vh;font-family:var(--font);font-size:16px;line-height:1.5;color:var(--color-gray-900);background:linear-gradient(0deg,var(--color-green-dark) 0%,var(--color-green) 18%,var(--color-green-light) 32%,var(--color-bg) 48%,var(--color-white) 62%,var(--color-white) 100%)}button{cursor:pointer}img{max-width:100%;height:auto;display:block}a{color:var(--color-green);text-decoration:none}a:hover{color:var(--color-green-light)}.container{width:100%;max-width:1200px;margin:0 auto;padding:0 16px}@media(min-width:768px){.container{padding:0 24px}}.app-shell{min-height:100vh;display:flex;flex-direction:column}.app-main{flex:1;padding:24px;max-width:1120px;margin:0 auto;width:100%;display:flex;flex-direction:column;gap:24px}.scenario-main{padding:0;max-width:none;margin:0}.app-header{background:var(--color-white);box-shadow:var(--shadow-sm);border-bottom:3px solid var(--color-green);position:sticky;top:0;z-index:100}.app-header .header__inner{display:flex;align-items:center;justify-content:space-between;min-height:64px;gap:16px;padding:0 16px;max-width:1200px;margin:0 auto}@media(min-width:768px){.app-header .header__inner{padding:0 24px}}.app-brand-link{display:inline-flex;align-items:center;gap:10px;color:var(--color-green-dark);font-weight:700;font-size:1.35rem;text-decoration:none}.app-brand-link:hover{color:var(--color-green)}.header-logo-slot{width:40px;height:40px;border-radius:var(--radius-sm);background:var(--color-green);flex-shrink:0}.app-brand-text{white-space:nowrap}.header-user-slot{display:flex;align-items:center;gap:12px;position:relative}.header-dropdown{position:absolute;top:100%;right:0;margin-top:8px;min-width:180px;background:var(--color-white);border:1px solid var(--color-gray-200);border-radius:var(--radius-md);box-shadow:0 8px 24px #0000001a;z-index:100;padding:6px 0}.header-dropdown__item{display:block;width:100%;padding:10px 16px;text-align:left;font-family:var(--font);font-size:.95rem;font-weight:500;color:var(--color-gray-800);background:none;border:none;cursor:pointer;transition:background .15s}.header-dropdown__item:hover{background:var(--color-gray-100)}.header-dropdown__item--logout{color:var(--color-red, #c00);border-top:1px solid var(--color-gray-200);margin-top:4px;padding-top:10px}.header__btn{color:var(--color-white)}.header-logo-img{display:block;height:40px;width:auto;max-width:160px;object-fit:contain}.header-nav-center{display:flex;align-items:center;justify-content:center;gap:12px;flex:1}.header-nav-btn{padding:8px 16px;font-family:var(--font);font-size:.9rem;font-weight:600;color:var(--color-green-dark);background:transparent;border:2px solid var(--color-green);border-radius:var(--radius-md);cursor:pointer;transition:border-color .2s,color .2s,background .2s}.header-nav-btn:hover{border-color:var(--color-green-light);color:var(--color-green);background:#2d7a4a0f}.header-gems{font-weight:700;color:var(--color-green-dark);font-size:.95rem;white-space:nowrap}@media(max-width:768px){.header-user-btn__text,.header-nav-center{display:none}}.btn{display:inline-flex;align-items:center;justify-content:center;padding:10px 20px;font-family:var(--font);font-size:.95rem;font-weight:600;border:none;border-radius:var(--radius-md);cursor:pointer;transition:background .2s,transform .1s;text-decoration:none}.btn--primary{background:var(--color-green);color:var(--color-white)}.btn--primary:hover{background:var(--color-green-light)}.btn--primary:active{transform:scale(.98)}.btn--lg{padding:14px 28px;font-size:1.05rem}.btn--outline{background:transparent;color:var(--color-green-dark);border:2px solid var(--color-gray-200)}.btn--outline:hover{border-color:var(--color-green);color:var(--color-green)}.primary-btn{background:var(--color-green);color:var(--color-white);padding:10px 18px;border-radius:var(--radius-md);font-weight:600;border:none;font-family:var(--font);transition:background .2s,transform .1s}.primary-btn:hover:not(:disabled){background:var(--color-green-light);transform:scale(.98)}.primary-btn:disabled{opacity:.6;cursor:not-allowed}.secondary-btn{background:transparent;border:2px solid var(--color-gray-200);color:var(--color-gray-900);padding:8px 16px;border-radius:var(--radius-md);font-weight:500;font-family:var(--font)}.secondary-btn:hover{border-color:var(--color-green);color:var(--color-green)}.header-user-btn{display:flex;align-items:center;gap:10px;background:transparent;border:none;color:inherit;padding:8px 12px;border-radius:var(--radius-md);font-family:var(--font)}.header-user-btn:hover{background:var(--color-bg)}.avatar-circle.small{width:40px;height:40px;font-size:1rem}.avatar-circle{width:48px;height:48px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:1.25rem;background:var(--color-green);color:var(--color-white);border:2px solid var(--color-gray-200);flex-shrink:0}.app-footer{padding:40px 24px 24px;background:var(--color-green-dark);color:var(--color-white);font-size:.85rem;line-height:1.5}.app-footer-links{display:flex;justify-content:center;gap:20px;margin-bottom:12px;flex-wrap:wrap}.app-footer-links a{color:#ffffffe6;text-decoration:none}.app-footer-links a:hover{color:var(--color-white)}.app-footer .app-footer-copy{margin:0;padding-top:20px;border-top:1px solid rgba(255,255,255,.2);color:#ffffffbf;text-align:center}.app-footer-hackathon{font-size:.8rem;color:#fff9;text-align:center;max-width:520px;margin:12px auto 0}.app-footer-logo{display:inline-flex;align-items:center;justify-content:center;padding:0;background:none;border:none;cursor:pointer;color:inherit;margin-top:-4px}.app-footer-logo-slot{width:80px;height:40px;border-radius:var(--radius-sm);background:#fff3}.app-footer-logo-img{height:40px;width:auto;max-width:140px;object-fit:contain;display:block}.hero{padding:32px 0 40px;background:linear-gradient(180deg,var(--color-bg) 0%,var(--color-white) 100%)}@media(min-width:768px){.hero{padding:48px 0 64px}}.hero__grid{display:grid;gap:32px}@media(min-width:768px){.hero__grid{grid-template-columns:1fr 1fr;align-items:center;gap:48px}}.hero__title{margin:0 0 24px;font-size:1.75rem;font-weight:700;line-height:1.25;color:var(--color-green-dark)}@media(min-width:768px){.hero__title{font-size:2.25rem;margin-bottom:28px}}@keyframes hero-play-btn-in{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.hero__play-tile{display:block;width:100%;text-decoration:none;text-align:center;padding:32px 24px;background:var(--color-green);color:var(--color-white);border:none;animation:hero-play-btn-in .4s ease forwards;border-radius:var(--radius-lg);box-shadow:var(--shadow-md);transition:box-shadow .2s,transform .1s,background .2s;max-width:320px;margin:0 auto 16px;cursor:pointer;font-family:var(--font)}.hero__play-tile:hover{background:var(--color-green-light);transform:translateY(-2px)}.hero__desc{margin:0;color:var(--color-gray-600);font-size:1rem}.hero .caret{background:var(--color-green-dark);vertical-align:-2px}.hero__desc .caret{background:var(--color-gray-600)}.section-title{margin:0 0 24px;font-size:1.5rem;font-weight:700;color:var(--color-green-dark);text-align:center}.features{padding:48px 0 56px}.features__grid{list-style:none;margin:0;padding:0;display:grid;gap:20px}@media(min-width:600px){.features__grid{grid-template-columns:repeat(2,1fr)}}@media(min-width:900px){.features__grid{grid-template-columns:repeat(3,1fr);gap:24px}}.feature-card{background:var(--color-white);border:2px solid var(--color-green);border-radius:var(--radius-md);padding:24px;transition:box-shadow .2s,border-color .2s;min-width:0;overflow-wrap:break-word}.feature-card:hover{border-color:var(--color-green-bright);box-shadow:var(--shadow-sm)}.feature-card__icon{width:56px;height:56px;margin-bottom:16px;color:var(--color-green)}.feature-card__icon svg{width:100%;height:100%}.feature-card__title{margin:0 0 8px;font-size:1.1rem;font-weight:600;color:var(--color-green-dark);overflow-wrap:break-word;word-break:break-word;min-width:0}.feature-card__text{margin:0;font-size:.95rem;color:var(--color-gray-600);line-height:1.45;overflow-wrap:break-word;word-break:break-word;min-width:0}.how-to{padding:48px 0 56px;background:transparent}.how-to .how-to__section-title,.how-to .section-title.how-to__section-title{color:var(--color-white)}.how-to__list{list-style:none;padding:0;display:grid;gap:24px;max-width:560px;margin:0 auto}@media(min-width:600px){.how-to__list{grid-template-columns:repeat(2,1fr);max-width:none}.how-to__item:nth-child(3){grid-column:1 / -1;justify-self:center;max-width:360px}}.how-to__item{display:flex;align-items:flex-start;gap:16px;background:var(--color-white);border:2px solid var(--color-green);border-radius:var(--radius-md);padding:24px}.how-to__num{flex-shrink:0;width:40px;height:40px;border-radius:50%;background:var(--color-green);color:var(--color-white);display:flex;align-items:center;justify-content:center;font-weight:700;font-size:1.1rem}.how-to__text{margin:0;font-size:1rem;color:var(--color-gray-900);line-height:1.45;overflow-wrap:break-word;word-break:break-word;min-width:0}.how-to--dark{background:var(--color-green-dark);color:var(--color-white)}.how-to--dark .how-to__section-title,.how-to--dark .section-title,.how-to--dark .how-to__text{color:var(--color-white)}.how-to--dark .how-to__num{background:#ffffff40;color:var(--color-white)}.how-to--dark .how-to__item{background:#ffffff1a;border-color:#fff3}.home-page__wrap{display:grid;grid-template-columns:minmax(260px,280px) 1fr;gap:28px 40px;align-items:start;max-width:1280px;margin:0 auto;padding:0 16px 32px}@media(min-width:768px){.home-page__wrap{padding:0 24px 48px}}.home-page__content{min-width:0;max-width:680px;justify-self:start}.home-page__sidebar{position:sticky;top:88px;min-width:0}@media(max-width:900px){.home-page__wrap{grid-template-columns:1fr}.home-page__content{max-width:none;justify-self:stretch}.home-page__sidebar{position:static;max-width:none}}.home-support-chat{position:fixed;right:24px;bottom:24px;z-index:40;display:inline-flex;align-items:center;gap:10px;padding:14px 20px;background:var(--color-green);color:var(--color-white);border-radius:999px;font-weight:600;font-size:.95rem;text-decoration:none;box-shadow:0 4px 20px #2d7a4a66;transition:background .2s,transform .15s,box-shadow .2s}.home-support-chat:hover{background:var(--color-green-light);color:var(--color-white);transform:translateY(-2px);box-shadow:0 6px 24px #2d7a4a73}.home-support-chat__icon{font-size:1.2rem}.home-support-chat__label{white-space:nowrap}@media(max-width:600px){.home-support-chat{right:16px;bottom:max(16px,env(safe-area-inset-bottom));padding:12px 16px;font-size:.9rem}.home-support-chat__label{display:none}}.ai-chat-panel{position:fixed;right:24px;bottom:80px;width:420px;max-width:calc(100vw - 32px);max-height:75vh;min-height:520px;z-index:50;display:flex;flex-direction:column;background:var(--color-white);border:2px solid var(--color-green);border-radius:var(--radius-md);box-shadow:var(--shadow-md);overflow:hidden}.ai-chat-panel__header{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;background:var(--color-green);color:var(--color-white);font-weight:600}.ai-chat-panel__title{display:flex;align-items:center;gap:8px}.ai-chat-panel__title-icon{width:1.4rem;height:1.4rem;object-fit:contain;border-radius:4px}.ai-chat-panel__close{width:32px;height:32px;padding:0;border:none;border-radius:var(--radius-sm);background:#fff3;color:inherit;font-size:1.4rem;line-height:1;cursor:pointer;transition:background .15s}.ai-chat-panel__close:hover{background:#ffffff4d}.ai-chat-panel__messages{flex:1;overflow-y:auto;padding:12px;min-height:280px;max-height:min(480px,55vh);display:flex;flex-direction:column;gap:12px}.ai-chat-msg{display:flex;gap:8px;align-items:flex-start}.ai-chat-msg--user{flex-direction:row-reverse}.ai-chat-msg__avatar{flex-shrink:0;font-size:1.2rem}.ai-chat-msg__avatar-img{width:1.5rem;height:1.5rem;object-fit:contain;border-radius:4px}.ai-chat-msg__bubble{max-width:85%;padding:10px 14px;border-radius:var(--radius-md);background:var(--color-gray-200)}.ai-chat-msg--user .ai-chat-msg__bubble{background:var(--color-green);color:var(--color-white)}.ai-chat-msg__name{display:block;font-size:.75rem;font-weight:600;color:var(--color-green-dark);margin-bottom:4px}.ai-chat-msg__text{margin:0;font-size:.9rem;line-height:1.4;white-space:pre-wrap;word-break:break-word}.ai-chat-panel__form{display:flex;gap:8px;padding:12px;border-top:1px solid var(--color-gray-200);background:var(--color-bg)}.ai-chat-panel__input{flex:1;padding:10px 14px;border:2px solid var(--color-gray-200);border-radius:var(--radius-sm);font-size:.95rem;font-family:inherit;transition:border-color .15s}.ai-chat-panel__input:focus{outline:none;border-color:var(--color-green)}.ai-chat-panel__send{padding:10px 16px;background:var(--color-green);color:var(--color-white);border:none;border-radius:var(--radius-sm);font-weight:600;font-size:.9rem;cursor:pointer;transition:background .15s}.ai-chat-panel__send:hover{background:var(--color-green-light)}@media(max-width:600px){.ai-chat-panel{right:12px;left:12px;width:auto;bottom:72px;max-height:85vh;min-height:400px}.ai-chat-panel__messages{max-height:min(400px,60vh)}}.leaderboard-card{background:var(--color-white);border:2px solid var(--color-green);border-radius:var(--radius-md);padding:24px;box-shadow:var(--shadow-sm);min-width:0;overflow:hidden}.leaderboard-card__title{margin:0 0 16px;font-size:1.1rem;font-weight:700;color:var(--color-green-dark)}.leaderboard-list{list-style:none;margin:0;padding:0}.leaderboard-item{display:flex;align-items:center;gap:12px;padding:10px 0;border-bottom:1px solid var(--color-gray-200);min-width:0}.leaderboard-item:last-child{border-bottom:none}.leaderboard-item__rank{width:28px;font-weight:700;color:var(--color-gray-600);font-size:.9rem}.leaderboard-item__avatar{width:36px;height:36px;border-radius:50%;background:var(--color-green);color:var(--color-white);display:flex;align-items:center;justify-content:center;font-size:.9rem;font-weight:600;overflow:hidden}.leaderboard-item__name{flex:1;min-width:0;font-weight:600;font-size:.95rem;color:var(--color-gray-900);line-height:1.25;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.leaderboard-item__gems{font-weight:700;color:var(--color-green-dark);white-space:nowrap}.leaderboard-item--me{background:var(--color-bg);border-radius:var(--radius-sm);padding-left:8px;padding-right:8px;margin:0 -8px}.leaderboard-card__more{width:100%;margin-top:16px}.leaderboard-page{padding:24px 0 48px;display:flex;justify-content:center;align-items:flex-start;min-height:60vh}.leaderboard-page__inner{width:100%;max-width:560px;margin:0 auto;padding:0 16px}.leaderboard-page__back{margin-bottom:20px}.leaderboard-page__title{margin:0 0 28px;font-size:1.75rem;font-weight:700;color:var(--color-green-dark);text-align:center}.leaderboard-page__loading,.leaderboard-page__empty{text-align:center;padding:24px 0}.leaderboard-page__me{background:linear-gradient(135deg,#22c55e1f,#22c55e0f);border:2px solid var(--color-green);border-radius:var(--radius-md);padding:20px 24px;margin-bottom:24px}.leaderboard-page__me-label{display:block;font-size:.85rem;font-weight:600;color:var(--color-green-dark);text-transform:uppercase;letter-spacing:.04em;margin-bottom:12px}.leaderboard-page__me-row{display:flex;align-items:center;gap:16px;flex-wrap:wrap}.leaderboard-page__me-rank{font-size:1.25rem;font-weight:800;color:var(--color-green-dark);min-width:44px}.leaderboard-page__me-avatar{width:48px;height:48px;border-radius:50%;background:var(--color-green);color:var(--color-white);display:flex;align-items:center;justify-content:center;font-weight:700;font-size:1.25rem;overflow:hidden;flex-shrink:0}.leaderboard-page__me-avatar img{width:100%;height:100%;object-fit:cover}.leaderboard-page__me-name{flex:1;font-weight:700;font-size:1.1rem;color:var(--color-gray-900);min-width:0}.leaderboard-page__me-gems{font-weight:800;font-size:1.15rem;color:var(--color-green-dark);white-space:nowrap}.leaderboard-page__table-wrap{background:var(--color-white);border:1px solid var(--color-gray-200);border-radius:var(--radius-md);box-shadow:var(--shadow-sm);overflow:hidden}.leaderboard-table{width:100%;border-collapse:collapse;font-size:.95rem;table-layout:fixed}.leaderboard-table__th{text-align:left;padding:14px 16px;font-weight:700;color:var(--color-gray-700);background:var(--color-gray-50);border-bottom:2px solid var(--color-gray-200)}.leaderboard-table__th--rank{width:72px;text-align:center}.leaderboard-table__th--user{min-width:0}.leaderboard-table__th--gems{width:100px;text-align:right}.leaderboard-table__td{padding:14px 16px;border-bottom:1px solid var(--color-gray-100);vertical-align:middle}.leaderboard-table__td--rank{font-weight:700;color:var(--color-gray-600);text-align:center}.leaderboard-table__td--user{padding-left:16px;min-width:0}.leaderboard-table__td--gems{font-weight:700;color:var(--color-green-dark);text-align:right}.leaderboard-table__row--me .leaderboard-table__td{background:#22c55e14;border-bottom-color:#22c55e33}.leaderboard-table tbody tr:last-child .leaderboard-table__td{border-bottom:none}.leaderboard-table__user{display:flex;align-items:center;gap:12px;min-width:0}.leaderboard-table__avatar{width:40px;height:40px;border-radius:50%;background:var(--color-gray-200);color:var(--color-gray-700);display:flex;align-items:center;justify-content:center;font-weight:600;font-size:1rem;overflow:hidden;flex-shrink:0}.leaderboard-table__avatar img{width:100%;height:100%;object-fit:cover}.leaderboard-table__name{flex:1;min-width:0;font-weight:600;color:var(--color-gray-900);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.leaderboard-list--full{max-width:480px}.card{background:var(--color-white);border:2px solid var(--color-green);border-radius:var(--radius-md);padding:24px;box-shadow:var(--shadow-sm)}.card-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:20px}.text-muted{color:var(--color-gray-600);font-size:.95rem}.text-danger{color:#c62828}.text-success{color:var(--color-green)}.login-page{min-height:60vh;background:var(--color-bg)}.login-page__main{padding:48px 0 64px}.login-card{max-width:420px;margin:0 auto;background:var(--color-white);border:2px solid var(--color-green);border-radius:var(--radius-lg);padding:32px;box-shadow:var(--shadow-md)}.login-card__title{margin:0 0 8px;font-size:1.5rem;font-weight:700;color:var(--color-green-dark)}.login-card__subtitle{margin:0 0 24px;font-size:.95rem;color:var(--color-gray-600);line-height:1.4}.login-form{display:flex;flex-direction:column;gap:20px}.login-form__label{display:flex;flex-direction:column;gap:8px;font-weight:500;color:var(--color-gray-900)}.login-form__input{padding:12px 16px;font-family:var(--font);font-size:1rem;border:2px solid var(--color-gray-200);border-radius:var(--radius-sm);background:var(--color-white);color:var(--color-gray-900);transition:border-color .2s}.login-form__input:focus{outline:none;border-color:var(--color-green)}.login-form__input::placeholder{color:var(--color-gray-400)}.login-form__row{display:flex;gap:12px;flex-wrap:wrap}.login-card__footer{margin:24px 0 0;padding-top:20px;border-top:1px solid var(--color-gray-200);font-size:.95rem;color:var(--color-gray-600);text-align:center}.login-card__link{font-weight:600;color:var(--color-green)}.profile-page{min-height:60vh;background:var(--color-bg)}.profile-header{background:var(--color-white);box-shadow:var(--shadow-sm);padding:16px 0}.profile-header__inner{display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap;max-width:1200px;margin:0 auto;padding:0 16px}.profile-header__user{display:flex;align-items:center;gap:16px}.profile-header__avatar{width:48px;height:48px;border-radius:50%;background:var(--color-green);color:var(--color-white);display:flex;align-items:center;justify-content:center;overflow:hidden}.profile-header__avatar-inner{font-weight:700;font-size:1.25rem}.profile-header__info{display:flex;flex-direction:column;gap:2px}.profile-header__name{font-weight:600;font-size:1.1rem;color:var(--color-gray-900)}.profile-header__handle{font-size:.9rem;color:var(--color-gray-600)}.profile-header__actions{display:flex;gap:12px}.profile-header__back{font-family:var(--font);font-size:.95rem;font-weight:500;color:var(--color-green);background:none;border:none;cursor:pointer;padding:8px 0}.profile-header__back:hover{text-decoration:underline}.profile-header__single-title{font-size:1.25rem;font-weight:700;color:var(--color-gray-900);margin:0;flex:1;text-align:center}.profile-main{padding:32px 0 48px}.profile-section{background:var(--color-white);border:2px solid var(--color-green);border-radius:var(--radius-md);padding:24px;margin-bottom:24px;box-shadow:var(--shadow-sm)}.profile-section__title{margin:0 0 8px;font-size:1.5rem;font-weight:700;color:var(--color-green-dark)}.profile-section__subtitle{margin:0;font-size:.95rem;color:var(--color-gray-600);line-height:1.4}.profile-tabs{display:flex;gap:0;background:var(--color-gray-200);border-radius:var(--radius-md);padding:4px}.profile-tabs__btn{padding:10px 20px;font-family:var(--font);font-size:.95rem;font-weight:600;border:none;border-radius:calc(var(--radius-md) - 2px);cursor:pointer;background:transparent;color:var(--color-gray-600);transition:background .2s,color .2s}.profile-tabs__btn:hover{color:var(--color-green-dark)}.profile-tabs__btn--active{background:var(--color-green);color:var(--color-white)}.profile-form__row{display:grid;grid-template-columns:1fr 1fr;gap:20px;margin-bottom:20px}@media(max-width:600px){.profile-form__row{grid-template-columns:1fr}}.profile-form__label{display:flex;flex-direction:column;gap:8px;font-weight:500;color:var(--color-gray-900)}.profile-form__music{display:flex;align-items:center;gap:12px;flex-wrap:wrap}.profile-form__music-label{flex-direction:row;align-items:center;cursor:pointer}.music-toggle{position:relative;width:52px;height:28px;padding:0;border:none;background:none;cursor:pointer;border-radius:999px;flex-shrink:0}.music-toggle__track{display:block;width:100%;height:100%;background:var(--color-gray-200);border-radius:999px;transition:background .25s ease,box-shadow .2s ease}.music-toggle:hover .music-toggle__track{box-shadow:0 0 0 2px var(--color-gray-400)}.music-toggle--on .music-toggle__track{background:var(--color-green);box-shadow:0 0 0 2px var(--color-green-light)}.music-toggle__thumb{position:absolute;top:4px;left:4px;width:20px;height:20px;background:var(--color-white);border-radius:50%;box-shadow:0 2px 6px #0003;transition:transform .25s cubic-bezier(.4,0,.2,1)}.music-toggle--on .music-toggle__thumb{transform:translate(24px)}.profile-form__music-label input[type=checkbox]{width:18px;height:18px;cursor:pointer}.profile-form__input{padding:12px 16px;font-family:var(--font);font-size:1rem;border:2px solid var(--color-gray-200);border-radius:var(--radius-sm);background:var(--color-white);color:var(--color-gray-900);transition:border-color .2s}.profile-form__input:focus{outline:none;border-color:var(--color-green)}.profile-form__difficulty{display:flex;flex-wrap:wrap;gap:8px;margin-top:4px}.profile-avatar-upload{display:inline-block;cursor:pointer}.profile-avatar-upload__input{position:absolute;width:.1px;height:.1px;opacity:0;overflow:hidden;z-index:-1}.profile-avatar-upload__btn{display:inline-flex;align-items:center;justify-content:center;padding:12px 20px;font-size:1rem;font-weight:600;font-family:var(--font);color:var(--color-white);background:var(--color-green);border:2px solid var(--color-green);border-radius:var(--radius-sm);cursor:pointer;transition:background .2s,border-color .2s,transform .15s}.profile-avatar-upload:hover .profile-avatar-upload__btn{background:var(--color-green-light);border-color:var(--color-green-light)}.profile-avatar-upload:focus-within .profile-avatar-upload__btn{outline:none;box-shadow:0 0 0 3px #2d7a4a4d}.profile-avatar-upload__input:disabled+.profile-avatar-upload__btn{opacity:.7;cursor:not-allowed}.profile-avatar-row{display:flex;align-items:center;gap:20px;flex-wrap:wrap}.profile-avatar-preview{width:80px;height:80px;border-radius:50%;overflow:hidden;background:var(--color-gray-200);border:2px solid var(--color-green);flex-shrink:0}.profile-avatar-preview img{width:100%;height:100%;object-fit:cover}.profile-avatar-preview__letter{display:flex;align-items:center;justify-content:center;width:100%;height:100%;font-size:2rem;font-weight:700;color:var(--color-green-dark)}.notice{border-radius:var(--radius-md);padding:14px 16px;border:2px solid var(--color-green);background:var(--color-bg)}.notice.warn{border-color:#f59e0b;background:#fffbeb}.play-page{min-height:60vh;background:var(--color-bg)}.play-page__main{display:flex;flex-direction:column;min-height:calc(100vh - 64px);padding:0}@media(min-width:900px){.play-page__main{flex-direction:row}}.play-page__sidebar{flex-shrink:0;padding:24px 20px;background:var(--color-white);border-bottom:1px solid var(--color-gray-200)}@media(min-width:900px){.play-page__sidebar{width:280px;border-right:1px solid var(--color-gray-200);border-bottom:none}}.play-sidebar__title{margin:0 0 4px;font-size:.85rem;font-weight:600;color:var(--color-gray-600)}.play-sidebar__name{margin:0 0 12px;font-size:1.25rem;font-weight:700;color:var(--color-green-dark)}.play-sidebar__desc{margin:0 0 20px;font-size:.95rem;color:var(--color-gray-600);line-height:1.5}.play-page__balance{display:flex;align-items:center;gap:8px;padding:12px 16px;background:var(--color-bg);border-radius:var(--radius-md);border:1px solid var(--color-gray-200);margin-bottom:16px}.play-page__balance-label{font-weight:500;color:var(--color-gray-600)}.play-page__balance-value{font-weight:700;color:var(--color-green-dark);font-variant-numeric:tabular-nums}.play-page__difficulty{display:flex;align-items:center;gap:8px;padding:12px 16px;background:var(--color-bg);border-radius:var(--radius-md);border:1px solid var(--color-gray-200);margin-bottom:16px}.play-page__difficulty-label{font-weight:500;color:var(--color-gray-600)}.play-page__difficulty-value{font-weight:700;color:var(--color-green-dark)}.play-page__map-desc{margin:0;font-size:.9rem;color:var(--color-gray-600);line-height:1.5}.play-page__map-wrap--bg{background-image:url(/map-bg.png);background-size:cover;background-position:center}@media(max-width:768px){.play-page__map-wrap--bg{background-image:url(/map-bg.png)}}.play-page__island-entry{margin-top:24px;width:100%;max-width:320px}@media(min-width:901px){.play-page__island-entry{margin-top:32px}}.play-page__island-btn{width:100%;padding:14px 20px;font-size:1rem}.play-page__map-wrap{flex:1;overflow:auto;padding:32px 24px;display:flex;flex-direction:column;align-items:flex-start;justify-content:center;min-height:400px}.play-map{position:relative;flex-shrink:0}.play-map__lines{position:absolute;left:0;top:0;width:100%;height:100%;pointer-events:none}.play-map__node-wrap{position:absolute;width:56px;height:56px;margin-left:-28px;margin-top:-28px;display:flex;flex-direction:column;align-items:center;z-index:2}.play-map__node{width:56px;height:56px;border-radius:50%;border:3px solid var(--color-green);background:var(--color-white);color:var(--color-green-dark);font-weight:700;font-size:1.1rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .2s,transform .15s,box-shadow .2s}.play-map__node:hover{background:var(--color-bg);transform:scale(1.08)}.play-map__node--active{background:var(--color-green);color:var(--color-white);box-shadow:0 4px 16px #2d7a4a66}.play-map__node--locked{opacity:.7;border-style:dashed}.play-map__node--passed{background:var(--color-green);color:var(--color-white);box-shadow:0 0 0 3px var(--color-green-light)}.play-map__node-num{line-height:1}.scenario-modal-backdrop{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:100;padding:16px}.scenario-modal{width:100%;max-width:440px;background:var(--color-white);border-radius:var(--radius-lg);padding:24px;box-shadow:var(--shadow-md);border:2px solid var(--color-green)}.scenario-modal__title{margin:0 0 8px;font-size:1.35rem;font-weight:700;color:var(--color-green-dark)}.scenario-modal__meta{margin:0 0 16px;font-size:.9rem;color:var(--color-gray-600)}.scenario-modal__desc{margin:0 0 20px;font-size:.95rem;color:var(--color-gray-900);line-height:1.5}.scenario-modal__actions{display:flex;flex-wrap:wrap;gap:12px;justify-content:flex-end}.chips-row{display:flex;flex-wrap:wrap;gap:8px}.chip{padding:6px 12px;border-radius:999px;background:var(--color-bg);border:1px solid var(--color-gray-200);font-size:.85rem;color:var(--color-gray-600)}.pill-option{padding:8px 14px;border-radius:999px;border:2px solid var(--color-green);font-size:.9rem;cursor:pointer;background:var(--color-white);color:var(--color-green-dark);font-family:var(--font);font-weight:500}.pill-option:hover{background:#2d7a4a14;border-color:var(--color-green-light);color:var(--color-green-dark)}.pill-option.selected{background:var(--color-green);border-color:var(--color-green);color:var(--color-white)}.status-bar{display:flex;justify-content:space-between;align-items:center;gap:16px;padding:14px 18px;border-radius:var(--radius-md);border:1px solid var(--color-gray-200);background:var(--color-white);box-shadow:var(--shadow-sm)}.budget-pill{display:inline-flex;align-items:center;gap:8px;padding:8px 14px;border-radius:var(--radius-md);border:1px solid var(--color-gray-200);background:var(--color-bg);font-size:.95rem}.fade-number{transition:transform .15s ease}.fade-number.bump{transform:scale(1.12)}.status-left,.status-right{display:flex;align-items:center;gap:12px}.scenario-stage{position:fixed;inset:0;z-index:50;background:#0a1f14;background-size:cover;background-position:center}.scenario-stage:after{content:"";position:absolute;inset:0;background:radial-gradient(circle at top,#0003,#000000b3);pointer-events:none}.scenario-ui{position:relative;z-index:1;height:100%;display:flex;flex-direction:column}.hud{display:flex;align-items:center;justify-content:space-between;padding:14px 16px}.scenario-stage .hud .secondary-btn,.scenario-ui .hud .secondary-btn{background:#fffffff2;color:var(--color-gray-900);border-color:#ffffffe6}.scenario-stage .hud .secondary-btn:hover,.scenario-ui .hud .secondary-btn:hover{background:var(--color-white);border-color:var(--color-green);color:var(--color-green)}.hud-left{display:flex;align-items:center;gap:10px}.hud-pill{display:inline-flex;align-items:center;gap:8px;padding:8px 12px;border-radius:999px;border:1px solid rgba(255,255,255,.2);background:#1a5f3a66;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);font-variant-numeric:tabular-nums;color:#f9fafb}.hud-label{opacity:.8;font-size:.85rem}.hud-value{font-weight:700}.stage-content{flex:1;min-height:0;position:relative;display:grid;grid-template-columns:1fr;overflow-y:auto;-webkit-overflow-scrolling:touch}.character-layer{position:absolute;inset:0;pointer-events:none}.character-sprite{position:absolute;bottom:0;width:min(520px,46vw);max-height:92vh;object-fit:contain;filter:drop-shadow(0 24px 60px rgba(0,0,0,.65));opacity:0;transform:translateY(14px);animation:spriteIn .42s ease forwards}.character-sprite.left{left:0}.character-sprite.right{right:0}@keyframes spriteIn{to{opacity:1;transform:translateY(0)}}.dialog-area{align-self:end;width:min(980px,calc(100vw - 28px));margin:0 auto 18px;display:flex;flex-direction:column;gap:10px}.dialog-box{border-radius:18px;padding:16px 18px;border:2px solid var(--color-green);background:#1a5f3a59;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);box-shadow:0 22px 55px #0006;color:#f9fafb;animation:dialogIn .26s ease}@keyframes dialogIn{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}.scenario-stage .dialog-box .dialog-choice-intro,.scenario-ui .dialog-box .dialog-choice-intro,.scenario-stage .dialog-box .choices-row>.text-muted:first-child,.scenario-ui .dialog-box .choices-row>.text-muted:first-child{color:#fffffff2}.scenario-stage .choice-btn .choice-delta--plus,.scenario-stage .choice-delta--plus,.scenario-ui .choice-btn .choice-delta--plus,.scenario-ui .choice-delta--plus,.scenario-stage .choices-row .choice-btn .text-success.text-muted,.scenario-ui .choices-row .choice-btn .text-success.text-muted{color:#4caf70!important;font-weight:700!important}.scenario-stage .choice-btn .choice-delta--minus,.scenario-stage .choice-delta--minus,.scenario-ui .choice-btn .choice-delta--minus,.scenario-ui .choice-delta--minus,.scenario-stage .choices-row .choice-btn .text-danger,.scenario-ui .choices-row .choice-btn .text-danger{color:#fecaca!important}.scenario-stage .choice-hint,.scenario-ui .choice-hint{color:#fffffff2!important;font-weight:500}.scenario-stage .dialog-box .secondary-btn{background:#ffffffeb;color:var(--color-gray-900);border:2px solid rgba(255,255,255,.9)}.scenario-stage .dialog-box .secondary-btn:hover{background:var(--color-white);border-color:var(--color-green);color:var(--color-green)}.speaker-row{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px;gap:10px}.speaker-name{font-weight:800;letter-spacing:.01em;color:#f9fafb}.dialog-text{font-size:1.02rem;line-height:1.55;white-space:pre-wrap;color:#e5e7eb}.caret{display:inline-block;width:8px;height:18px;margin-left:4px;background:#ffffffbf;border-radius:2px;animation:blink .9s infinite;vertical-align:-3px}@keyframes blink{0%,45%{opacity:1}50%,to{opacity:.1}}.choices-row{display:flex;flex-direction:column;gap:10px}.choice-ghost{opacity:.65;font-size:.88rem;color:#9ca3af}.event-layout{display:grid;grid-template-columns:minmax(0,260px) minmax(0,1.3fr);gap:20px}.event-dialog{border-radius:18px;padding:16px 18px;background:#1a5f3a4d;border:1px solid rgba(255,255,255,.15);min-height:120px;color:#e5e7eb}.event-dialog-bubble{margin-top:12px;padding:10px 12px;border-radius:14px;background:#00000059;border:1px solid rgba(255,255,255,.15);font-size:.9rem;color:#e5e7eb}.choices-list{display:flex;flex-direction:column;gap:10px}.choice-btn{width:100%;justify-content:space-between;display:flex;align-items:center;padding:12px 16px;border-radius:var(--radius-md);border:1px solid var(--color-gray-200);background:var(--color-white);color:var(--color-gray-900);font-family:var(--font)}.choice-btn:hover{border-color:var(--color-green);background:var(--color-bg)}.quiz-option-btn{width:100%;text-align:left;padding:12px 16px;border-radius:var(--radius-md);border:2px solid var(--color-gray-200);background:var(--color-white);color:var(--color-gray-900);font-family:var(--font);font-weight:500;transition:border-color .2s,background .2s}.quiz-option-btn:hover{border-color:var(--color-green);background:var(--color-bg)}.quiz-option-btn.selected{background:var(--color-green);border-color:var(--color-green);color:var(--color-white)}.quiz-option-btn.correct{border-color:var(--color-green);background:#2d7a4a26}.quiz-option-btn.incorrect{border-color:#c62828;background:#c6282814}.quiz-meta{display:flex;gap:8px;flex-wrap:wrap;align-items:center}.slider-row{display:flex;justify-content:space-between;align-items:center;gap:12px;padding:12px 16px;border-radius:var(--radius-md);background:var(--color-bg);border:1px solid var(--color-gray-200)}.slider-options{display:flex;flex-wrap:wrap;gap:6px}.gift-slider{width:100%;appearance:none;height:6px;border-radius:999px;background:linear-gradient(90deg,var(--color-gray-200),var(--color-green));outline:none}.gift-slider::-webkit-slider-thumb{appearance:none;width:18px;height:18px;border-radius:50%;background:var(--color-green);border:2px solid var(--color-white);box-shadow:var(--shadow-sm);cursor:pointer}.gift-slider::-moz-range-thumb{width:18px;height:18px;border-radius:50%;background:var(--color-green);border:2px solid var(--color-white);cursor:pointer}.gift-slider-labels{display:grid;grid-template-columns:repeat(4,1fr);gap:4px;margin-top:6px}.gift-slider-label{font-size:.85rem;text-align:center;color:var(--color-gray-600)}.gift-slider-label.active{color:var(--color-green-dark);font-weight:600}.unlock-overlay{position:absolute;inset:0;background:#000000b3;display:grid;place-items:center;z-index:5}.unlock-card{width:min(560px,calc(100vw - 28px));border-radius:var(--radius-lg);padding:24px;border:2px solid var(--color-green);background:var(--color-white);box-shadow:var(--shadow-md)}.unlock-item{font-size:64px;margin-bottom:10px;text-align:center}.modal-backdrop{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:60;padding:16px}.modal-card{width:min(420px,calc(100vw - 32px));border-radius:var(--radius-lg);padding:24px;border:2px solid var(--color-green);background:var(--color-white);box-shadow:var(--shadow-md)}.vn-layout{position:relative;min-height:calc(100vh - 72px);border-radius:24px;overflow:hidden;background-size:cover;background-position:center}.vn-overlay{position:relative;inset:0;display:flex;flex-direction:column;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:linear-gradient(to top,#0a1f14f0,#0a1f14bf,#0a1f1499)}.vn-header{display:flex;align-items:center;gap:12px;padding:14px 20px;border-bottom:1px solid rgba(255,255,255,.15);background:#1a5f3a66}.vn-main{flex:1;display:grid;grid-template-columns:minmax(0,260px) minmax(0,1.4fr);gap:18px;padding:16px 20px 20px}.vn-character-column{display:flex;flex-direction:column;gap:16px}.vn-character{display:flex;flex-direction:column;align-items:center;gap:8px}.vn-character-portrait{width:96px;height:96px;border-radius:999px;display:flex;align-items:center;justify-content:center;font-size:46px;background:var(--color-green);border:3px solid rgba(255,255,255,.6)}.vn-character-name{font-weight:600;text-align:center;color:#e5e7eb}.vn-controls{display:flex;flex-direction:column;gap:8px}.vn-dialog-column{display:flex;flex-direction:column;gap:14px}.vn-bg-home{background-image:radial-gradient(circle at top,#1a3d2a,#0a1f14 60%)}.vn-bg-home-evening{background-image:radial-gradient(circle at top,#0a1f14,#0d2818 45%,#000)}.vn-bg-school{background-image:linear-gradient(135deg,#0ea5e9,#0a1f14)}.vn-bg-park{background-image:linear-gradient(135deg,#22c55e,#064e3b,#0a1f14)}.vn-bg-park-evening{background-image:linear-gradient(135deg,#1d4ed8,#4ade80,#0a1f14)}.vn-bg-yard{background-image:linear-gradient(135deg,#f59e0b,#b45309,#0a1f14)}.island-game-shell{position:fixed;inset:0;height:100vh;max-height:100vh;background:linear-gradient(0deg,var(--color-green-dark) 0%,var(--color-green) 18%,var(--color-green-light) 32%,var(--color-bg) 48%,var(--color-white) 62%,var(--color-white) 100%);color:var(--color-gray-900);display:flex;flex-direction:column;z-index:100;overflow:hidden}.island-game-loading,.island-game-menu{margin:auto;text-align:center;padding:32px;max-width:480px;color:var(--color-gray-700)}.island-game-menu h1{font-size:1.5rem;margin-bottom:16px;color:var(--color-gray-900)}.island-game-achievement-notice{margin:16px 0;padding:14px 18px;background:linear-gradient(135deg,#2d7a4a33,#3d9b5c26);border:1px solid var(--color-green-light);border-radius:12px;text-align:left}.island-game-achievement-notice__record,.island-game-achievement-notice__badge{margin:0 0 8px;font-size:.95rem;color:var(--color-gray-900);font-weight:600}.island-game-achievement-notice__badge:last-child,.island-game-achievement-notice__record:last-child{margin-bottom:0}.island-game-header{display:flex;align-items:center;justify-content:space-between;padding:12px 20px;background:var(--color-green);border-bottom:2px solid var(--color-green-dark);flex-shrink:0;color:var(--color-white)}.island-game-header .island-game-back,.island-game-header .island-game-resources,.island-game-header .island-game-day{color:var(--color-white)}.island-game-back{flex-shrink:0}.island-game-header-right{display:flex;align-items:center;gap:10px;flex-wrap:wrap}.island-game-header-desk-only{display:flex}.island-game-header-mobile-only{display:none}.island-game-menu-wrap{position:relative}.island-game-menu-btn{min-height:40px}.island-game-menu-backdrop{position:fixed;inset:0;z-index:90;background:transparent}.island-game-menu-dropdown{position:absolute;top:100%;right:0;margin-top:6px;z-index:95;min-width:220px;background:var(--color-white);border:2px solid var(--color-green);border-radius:var(--radius-md);box-shadow:var(--shadow-md);padding:8px 0;display:flex;flex-direction:column}.island-game-menu-item{display:block;width:100%;padding:12px 16px;text-align:left;border:none;background:none;font-size:.95rem;cursor:pointer;color:var(--color-gray-900);transition:background .1s}.island-game-menu-item:hover{background:var(--color-gray-100)}.island-game-menu-item--primary{background:var(--color-green);color:var(--color-white);font-weight:600;text-align:center}.island-game-menu-item--primary:hover{background:var(--color-green-light);color:var(--color-white)}.island-game-mobile-panel{display:none}.island-game-resources{display:flex;gap:20px;font-size:1rem;font-variant-numeric:tabular-nums}.island-game-resources span{white-space:nowrap}.island-game-day{font-weight:700;font-size:1rem}.island-game-main{flex:1 1 0;min-height:0;display:grid;grid-template-columns:200px 1fr 220px;grid-template-rows:1fr;gap:16px;padding:16px;overflow:auto}.island-game-settlers,.island-game-buildings{background:var(--color-gray-50);border-radius:16px;padding:16px;border:2px solid var(--color-gray-200);border-top:3px solid var(--color-green);border-bottom:3px solid var(--color-white);overflow:auto;box-shadow:0 1px 4px #0000000f}.island-game-settlers--messages-only{width:100%;min-width:0;display:flex;flex-direction:column;flex:1;min-height:0}.island-game-settlers--messages-only .island-game-event-log{flex:1;min-height:0;display:flex;flex-direction:column;width:100%;overflow:hidden}.island-game-settlers--messages-only .island-game-event-log-list{flex:1;min-height:120px;width:100%;max-height:none;overflow-y:auto}.island-game-settlers--messages-only .island-game-event-log-entry{width:100%;min-width:0;box-sizing:border-box}.island-game-settlers-title,.island-game-buildings-title{font-weight:700;margin-bottom:12px;font-size:.95rem;color:var(--color-gray-900)}.island-game-slots{display:flex;flex-direction:column;gap:10px}.island-game-slot{display:flex;justify-content:space-between;align-items:center;padding:8px 10px;background:var(--color-white);border-radius:10px;border:1px solid var(--color-gray-200);color:var(--color-gray-800)}.island-game-slot-label{font-size:.9rem}.island-game-slot-count{display:flex;align-items:center;gap:8px}.island-game-slot-count span{min-width:24px;text-align:center;font-variant-numeric:tabular-nums}.island-game-slot-btn{width:28px;height:28px;border-radius:8px;border:1px solid var(--color-green);background:var(--color-green);color:var(--color-white);font-size:1.1rem;line-height:1;cursor:pointer;display:flex;align-items:center;justify-content:center}.island-game-slot-btn:hover{background:var(--color-green-light)}.island-game-map{min-height:0;display:flex;align-items:stretch;justify-content:stretch}.island-game-map-inner{flex:1;display:grid;grid-template-columns:1fr 1fr;grid-template-rows:1fr 1fr auto;grid-template-areas:"camp food" "wood stone" "market market";gap:12px;padding:12px}.island-game-zone{position:relative;background:var(--color-gray-50);border-radius:14px;border:2px solid var(--color-gray-200);padding:16px;font-size:.95rem;color:var(--color-gray-800);display:flex;flex-direction:column;align-items:center;justify-content:flex-start;min-height:80px}.island-game-zone-layer{position:absolute;inset:0;pointer-events:none;border-radius:14px}.island-game-zone-layer .island-game-placed-free,.island-game-zone-layer .island-game-settler-free{pointer-events:auto}.island-game-placed-free,.island-game-settler-free{position:absolute;transform:translate(-50%,-50%)}.island-game-settler-free{margin:0}.island-game-drop-zone{transition:background .15s ease,border-color .15s ease}.island-game-drop-zone:hover,.island-game-drop-zone.drag-over{background:#22c55e1f;border-color:var(--color-green)}.island-game-zone-title{margin-bottom:8px;font-weight:600;padding:6px 12px;border-radius:8px;background:#ffffffeb;border:1px solid var(--color-gray-200);box-shadow:0 1px 3px #00000014;display:inline-block}.island-game-zone[style*=background-image] .island-game-zone-title{text-shadow:none;color:var(--color-gray-900);background:#fffffff2}.island-game-zone[style*=background-image] .island-game-zone-instruction{background:#ffffffeb}.island-game-zone-instruction{font-size:.8rem;color:var(--color-gray-700);margin-bottom:8px;padding:6px 10px;background:#ffffffd9;border-radius:8px;border:1px solid var(--color-gray-200);line-height:1.35;max-height:2.7em;overflow:hidden;text-overflow:ellipsis;display:-webkit-box;-webkit-line-clamp:2;line-clamp:2;-webkit-box-orient:vertical}.island-game-zone-settlers{display:flex;flex-wrap:wrap;gap:8px;justify-content:center;align-items:center;flex:1}.island-game-settler-avatar{width:44px;height:44px;border-radius:50%;background:var(--color-white);border:2px solid var(--color-green);display:flex;align-items:center;justify-content:center;font-size:1.4rem;cursor:grab;-webkit-user-select:none;user-select:none;flex-shrink:0;overflow:hidden}.island-game-settler-avatar-img{width:100%;height:100%;object-fit:cover;display:block;pointer-events:none}.island-game-settler-avatar:active{cursor:grabbing}.island-game-settler-avatar:hover{border-color:var(--color-green-light)}.island-game-camp{justify-content:flex-start}.island-game-camp-buildings{display:flex;flex-wrap:wrap;gap:6px;margin-top:8px;justify-content:center}.island-game-placed-building{font-size:1.5rem;opacity:.9}@media(min-width:769px){.island-game-placed-building{font-size:2.75rem}}.island-game-novice-hint{font-size:.85rem;color:var(--color-gray-700);margin-top:10px;padding:8px 10px;background:#22c55e1a;border-radius:10px;border:1px solid var(--color-green)}.island-game-building-draggable{cursor:grab;border-color:var(--color-green)}.island-game-building-draggable:active{cursor:grabbing}.island-game-building-drag-icon{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:6px;margin-top:10px;padding:12px;border:2px dashed var(--color-green);border-radius:12px;background:#22c55e14;cursor:grab;transition:background .15s ease,border-color .15s ease}.island-game-building-drag-icon:hover{background:#22c55e26;border-color:var(--color-green-light)}.island-game-building-drag-icon:active{cursor:grabbing}.island-game-building-drag-emoji{font-size:2.5rem;line-height:1;display:block}.island-game-building-drag-label{font-size:.8rem;color:var(--color-green-dark);font-weight:600}.island-game-last-event-msg{font-size:.85rem;color:var(--color-red, #dc2626);max-width:320px}.island-game-building-card{padding:12px;margin-bottom:10px;background:var(--color-white);border-radius:12px;border:1px solid var(--color-gray-200);color:var(--color-gray-800)}.island-game-footer{flex-shrink:0;padding:12px 20px;background:var(--color-white);border-top:2px solid var(--color-green);display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap;z-index:10;color:var(--color-gray-800)}.island-game-modal-backdrop{position:fixed;inset:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:200;padding:24px}.island-game-modal{background:var(--color-white);border-radius:18px;padding:24px;max-width:440px;width:100%;border:2px solid var(--color-green);box-shadow:0 25px 50px #00000026;color:var(--color-gray-800)}.island-game-modal h3{margin-top:0;margin-bottom:12px}.island-game-modal p{margin-bottom:10px}.island-game-choices{display:flex;flex-direction:column;gap:10px;margin-top:16px}.island-game-choices button{text-align:left;padding:12px 14px}.island-game-tip{position:fixed;bottom:80px;left:50%;transform:translate(-50%);max-width:90%;padding:12px 16px;background:var(--color-white);border:2px solid var(--color-green);border-radius:12px;box-shadow:0 8px 24px #0003;display:flex;align-items:center;gap:12px;z-index:150;font-size:.9rem;color:var(--color-gray-800)}.island-game-tip button{flex-shrink:0;width:28px;height:28px;border:none;background:var(--color-green);border-radius:6px;color:var(--color-white);font-size:1.2rem;line-height:1;cursor:pointer}.island-game-rules-btn{min-width:36px;font-weight:700;font-size:1.1rem}.island-game-zones-btn{font-size:.85rem;white-space:nowrap}.island-game-rules-modal{max-width:520px;max-height:85vh;overflow:auto}.island-game-rules-text{white-space:pre-line;font-size:.9rem;line-height:1.5;margin-bottom:16px;color:var(--color-gray-700)}.island-game-zones-modal{max-width:560px;max-height:90vh;overflow:auto}.island-game-zones-error{padding:10px 14px;margin-bottom:12px;background:#dc26261a;border:1px solid var(--color-red, #dc2626);border-radius:var(--radius-sm);color:var(--color-red, #dc2626);font-size:.9rem}.island-game-zones-form-list{display:flex;flex-direction:column;gap:20px;margin-bottom:20px}.island-game-zone-row{padding:14px;border:1px solid var(--color-gray-200);border-radius:var(--radius-md);background:var(--color-bg)}.island-game-zone-row-header{font-weight:600;margin-bottom:10px;font-size:.95rem}.island-game-zone-row-preview{width:100%;max-width:200px;height:100px;border-radius:var(--radius-sm);overflow:hidden;background:var(--color-gray-200);margin-bottom:10px}.island-game-zone-row-img{width:100%;height:100%;object-fit:cover;display:block}.island-game-zone-row-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;font-size:.85rem;color:var(--color-gray-500)}.island-game-zone-row-fields{display:flex;flex-direction:column;gap:8px}.island-game-zone-row-label{display:flex;flex-direction:column;gap:4px;font-size:.9rem;color:var(--color-gray-700)}.island-game-zone-row-textarea{width:100%;padding:8px 10px;border:2px solid var(--color-gray-200);border-radius:var(--radius-sm);font-family:inherit;font-size:.9rem;resize:vertical;min-height:56px}.island-game-zone-row-textarea:focus{outline:none;border-color:var(--color-green)}.island-game-zone-row-save{align-self:flex-start;margin-top:4px}.island-game-warehouse-modal{max-width:560px}.island-game-warehouse-protected{display:flex;flex-wrap:wrap;align-items:center;gap:8px;margin-bottom:16px}.island-game-warehouse-protected>span{margin-right:8px;font-size:.9rem}.island-game-workshop-upgrades{display:flex;flex-direction:column;gap:10px;margin-bottom:16px}.island-game-workshop-row{display:flex;flex-wrap:wrap;align-items:center;gap:8px;padding:8px 0;border-bottom:1px solid var(--color-gray-200)}.island-game-workshop-row:last-child{border-bottom:none}.island-game-event-outro-modal .text-muted{margin-bottom:0}.island-game-warehouse-table{width:100%;border-collapse:collapse;margin-bottom:16px;font-size:.9rem;border:2px solid var(--color-gray-200);border-top:3px solid var(--color-green);border-bottom:3px solid var(--color-white);border-radius:var(--radius-md);overflow:hidden;box-shadow:0 1px 3px #0000000f}.island-game-warehouse-table th,.island-game-warehouse-table td{padding:8px 10px;text-align:left;border-bottom:1px solid var(--color-gray-200)}.island-game-warehouse-table th{color:var(--color-gray-600);font-weight:600;background:var(--color-gray-50)}.island-game-event-log{margin-top:20px;padding-top:12px;border-top:1px solid var(--color-gray-200)}.island-game-settlers--messages-only .island-game-event-log{margin-top:0;padding-top:0;border-top:none}.island-game-event-log-title{font-weight:600;font-size:.9rem;margin-bottom:8px}.island-game-event-log-list{max-height:220px;overflow-y:auto;display:flex;flex-direction:column;gap:6px}.island-game-event-log-entry{font-size:.8rem;padding:6px 8px;background:var(--color-gray-50);border-radius:8px;border-left:1px solid var(--color-gray-200);border-right:1px solid var(--color-gray-200);border-bottom:1px solid var(--color-gray-200);border-top:2px solid var(--color-green);display:flex;flex-direction:column;gap:2px;color:var(--color-gray-700)}.island-game-event-log-entry:last-child{border-bottom:2px solid var(--color-white)}.island-game-event-log-day{color:var(--color-gray-600);font-weight:600}.island-game-event-log-msg{line-height:1.35}.business-popularity{min-width:120px}.popularity-bar-wrap{position:relative;height:18px;width:80px;border-radius:999px;background:#fff3;overflow:hidden}.popularity-bar{position:absolute;left:0;top:0;bottom:0;background:linear-gradient(90deg,#f0b429,#f5d547);border-radius:999px;transition:width .3s ease}.popularity-value{position:absolute;right:6px;top:50%;transform:translateY(-50%);font-size:.75rem;font-weight:700;color:#000000b3;text-shadow:0 0 1px #fff}.investment-scenario{max-width:720px;margin:0 auto;padding:16px}.investment-event-banner{background:#2d7a4a33;border:1px solid rgba(45,122,74,.5);border-radius:10px;padding:10px 14px;margin-bottom:16px;font-size:.95rem;color:#e5e7eb}.investment-chart-wrap{margin-bottom:20px}.investment-chart-label{font-size:.85rem;color:#94a3b8;margin-bottom:6px}.investment-chart{display:flex;align-items:flex-end;gap:2px;background:#0000004d;border-radius:10px;padding:8px}.investment-chart-bar{min-width:4px;background:linear-gradient(180deg,var(--color-green-light),var(--color-green));border-radius:4px;transition:height .2s ease}.investment-assets-table{width:100%;border-collapse:collapse;font-size:.9rem;margin-bottom:16px}.investment-assets-table th,.investment-assets-table td{padding:10px 12px;text-align:left;border-bottom:1px solid rgba(255,255,255,.15)}.investment-assets-table th{color:#94a3b8;font-weight:600}.investment-input{width:64px;padding:6px 8px;margin-right:8px;border-radius:8px;border:1px solid rgba(255,255,255,.3);background:#00000040;color:#e2e8f0;font-variant-numeric:tabular-nums}.investment-actions{display:flex;gap:12px;flex-wrap:wrap}.investment-tip-overlay{position:fixed;inset:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:200;padding:24px}.investment-tip-box{background:linear-gradient(180deg,#1e3d2a,#0f2a1a);border-radius:16px;padding:24px;max-width:400px;border:1px solid rgba(255,255,255,.2);color:#e5e7eb}.investment-tip-box p{margin:0 0 16px;line-height:1.5}.investment-dialog-area{max-width:820px;margin:0 auto 20px;gap:14px}.investment-charts-box .investment-chart-wrap{margin-bottom:16px}.investment-chart-line-wrap{display:block;border-radius:10px;overflow:hidden}.investment-line-chart{width:100%;height:100%;display:block}.investment-asset-charts{margin-top:8px}.investment-asset-charts-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:10px;margin-top:6px}.investment-asset-chart-item{display:flex;align-items:center;gap:8px;padding:6px 8px;border-radius:10px;background:#00000040}.investment-asset-chart-emoji{font-size:1.4rem;flex-shrink:0}.investment-mini-chart{flex:1;min-width:0}.investment-kid-hint{font-size:.95rem;color:#94a3b8;margin:0 0 14px}.investment-asset-cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:14px;min-width:0}.investment-asset-card{padding:14px;border-radius:14px;border:2px solid var(--color-green);background:#00000040;color:#e5e7eb;min-width:0;overflow:hidden}.investment-asset-card-header{display:flex;align-items:center;gap:8px;margin-bottom:8px;min-width:0}.investment-asset-card-emoji{font-size:1.8rem;flex-shrink:0}.investment-asset-card-name{font-size:.9rem;font-weight:700;line-height:1.2;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.investment-asset-card-price,.investment-asset-card-qty{font-size:.9rem;margin-bottom:6px}.investment-asset-card-actions{display:flex;flex-direction:column;gap:8px;margin-top:10px;min-width:0}.investment-asset-row{display:flex;align-items:center;gap:8px;flex-wrap:wrap;min-width:0}.investment-asset-row .investment-amount-control{flex-shrink:0}.investment-asset-row .primary-btn,.investment-asset-row .secondary-btn{min-width:80px}.investment-amount-control{display:flex;align-items:center;gap:4px}.investment-amount-btn{width:32px;height:32px;min-width:32px;min-height:32px;padding:0;border-radius:8px;border:1px solid rgba(255,255,255,.35);background:#ffffff1a;color:inherit;font-size:1.25rem;font-weight:700;line-height:1;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .15s,border-color .15s}.investment-amount-btn:hover:not(:disabled){background:#fff3;border-color:#ffffff80}.investment-amount-btn:disabled{opacity:.4;cursor:not-allowed}.investment-drag-input-wrap{cursor:ns-resize;-webkit-user-select:none;user-select:none;border-radius:8px;padding:2px}.investment-drag-input-wrap:hover{background:#ffffff14}.investment-drag-input-wrap.investment-drag-input-dragging{background:#2d7a4a4d}.investment-input-kid{width:56px;padding:8px 10px;font-size:1rem}.investment-input,.investment-input-kid,.investment-amount-control input[type=number]{-moz-appearance:textfield;appearance:textfield}.investment-amount-control input[type=number]::-webkit-inner-spin-button,.investment-amount-control input[type=number]::-webkit-outer-spin-button,.investment-input::-webkit-inner-spin-button,.investment-input::-webkit-outer-spin-button,.investment-input-kid::-webkit-inner-spin-button,.investment-input-kid::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}.investment-btn-kid{padding:10px 14px;font-size:.95rem}.investment-actions-row{display:flex;flex-wrap:wrap;gap:12px;align-items:center}.investment-btn-next{padding:14px 24px;font-size:1.05rem}.investment-day-report-overlay{position:fixed;inset:0;background:#000000a6;display:flex;align-items:center;justify-content:center;z-index:100;padding:20px}.investment-day-report{max-width:420px;width:100%}.investment-day-report-title{margin:0 0 14px;font-size:1.2rem;color:#e5e7eb}.investment-day-report-section{margin-bottom:14px}.investment-day-report-list{margin:6px 0 0;padding-left:20px;font-size:.95rem;line-height:1.6;color:#e5e7eb}.investment-day-report-portfolio{margin:6px 0 0;font-size:1rem}@media(max-width:560px){.investment-asset-charts-grid{grid-template-columns:repeat(2,1fr)}.investment-asset-cards{grid-template-columns:1fr}.investment-asset-card{padding:12px}.investment-asset-row{gap:6px}.investment-amount-control{gap:2px}.investment-amount-btn{width:28px;height:28px;min-width:28px;min-height:28px;font-size:1.1rem}.investment-input-kid{width:48px;padding:6px 8px;font-size:.95rem}.investment-btn-kid{padding:8px 10px;font-size:.9rem;min-width:72px}}@media(max-width:380px){.investment-asset-card-name,.investment-asset-card-price,.investment-asset-card-qty{font-size:.85rem}}.app-shell{padding-left:env(safe-area-inset-left);padding-right:env(safe-area-inset-right)}.app-header .header__inner{padding-left:max(16px,env(safe-area-inset-left));padding-right:max(16px,env(safe-area-inset-right))}.app-footer{padding-left:max(24px,env(safe-area-inset-left));padding-right:max(24px,env(safe-area-inset-right));padding-bottom:max(24px,env(safe-area-inset-bottom))}@media(max-width:768px){body{font-size:15px}.app-main{padding:16px 12px;gap:16px}.container{padding-left:max(16px,env(safe-area-inset-left));padding-right:max(16px,env(safe-area-inset-right))}.app-brand-text{font-size:1.1rem}.header-logo-slot{width:36px;height:36px}.header-user-btn{padding:6px 8px}.header-user-btn>div:last-child{display:none}.avatar-circle.small{width:44px;height:44px;font-size:1.1rem}.btn--primary.header__btn{min-height:44px;min-width:44px;padding:10px 16px}.home-page__wrap{flex-direction:column;padding:0 12px 24px}.home-page__sidebar{width:100%;margin-top:8px}.leaderboard-card{padding:16px}.leaderboard-card__title{font-size:1rem}.hero{padding:24px 0 32px}.hero__title{font-size:1.5rem;margin-bottom:16px}.hero__play-tile{padding:24px 16px;font-size:1rem}.section-title{font-size:1.35rem;margin-bottom:16px}.features{padding:32px 0 40px}.features__grid{gap:16px}.feature-card{padding:18px}.how-to{padding:32px 0 40px}.how-to__item{padding:18px}.login-page__main{padding:24px 0 40px}.login-card{padding:24px 20px;margin:0 12px}.login-card__title{font-size:1.35rem}.login-form__row{flex-direction:column}.login-form__row .btn{width:100%}.profile-header__inner{padding:12px 16px}.profile-header__user{gap:12px}.profile-header__avatar{width:42px;height:42px}.profile-header__name{font-size:1rem}.profile-header__handle{font-size:.8rem;overflow:hidden;text-overflow:ellipsis;max-width:180px}.profile-header__actions{flex-wrap:wrap;gap:8px}.profile-header__actions .btn{min-height:44px}.profile-main{padding:20px 0 32px}.profile-section{padding:18px}.profile-section__title{font-size:1.25rem}.profile-tabs__btn{padding:8px 14px;font-size:.9rem}.card-grid{grid-template-columns:1fr;gap:12px}.play-page__sidebar{padding:16px}.play-page__map-wrap{padding:16px 12px;min-height:320px;overflow:hidden;align-items:center;justify-content:center}.play-map{transform:scale(.72);transform-origin:center top}.play-map__node-wrap{width:72px;height:72px;margin-left:-36px;margin-top:-36px}.play-map__node{width:72px;height:72px;min-width:72px;min-height:72px;font-size:1.4rem}.scenario-modal-backdrop{padding:12px;align-items:flex-end}.scenario-modal{max-height:85vh;overflow-y:auto;padding:20px}.scenario-modal__title{font-size:1.2rem}.scenario-modal__meta{display:flex;flex-wrap:wrap;gap:6px}.scenario-modal__actions{width:100%}.scenario-modal__actions .primary-btn,.scenario-modal__actions .secondary-btn{flex:1;min-height:44px}.modal-backdrop{padding:12px;align-items:flex-end}.modal-card{max-height:90vh;overflow-y:auto;padding:20px}.modal-card .secondary-btn,.modal-card .primary-btn{min-height:44px}.scenario-stage{padding-top:env(safe-area-inset-top)}.scenario-ui .hud{padding-left:max(14px,env(safe-area-inset-left));padding-right:max(14px,env(safe-area-inset-right));flex-wrap:wrap;gap:8px}.scenario-ui .hud .hud-left{flex:1 1 auto;min-width:0;gap:6px}.scenario-ui .hud .secondary-btn{min-height:44px;flex-shrink:0}.scenario-ui .hud-pill{min-height:36px;padding:6px 10px;font-size:.85rem}.scenario-ui .hud-pill .hud-label{font-size:.75rem}.business-popularity{min-width:0}.business-popularity .popularity-bar-wrap{width:48px;height:14px}.business-popularity .popularity-value{font-size:.8rem}.dialog-area{width:calc(100vw - 24px);margin-left:12px;margin-right:12px;margin-bottom:max(12px,env(safe-area-inset-bottom))}.dialog-box{padding:14px 16px;border-radius:14px}.dialog-text{font-size:.95rem}.choices-row,.choices-list{gap:8px}.choice-btn,.quiz-option-btn{min-height:48px;padding:14px 16px}.vn-main{grid-template-columns:1fr;gap:12px;padding:12px 16px 16px}.vn-character-column{flex-direction:row;flex-wrap:wrap;gap:12px;justify-content:center}.vn-character-portrait{width:72px;height:72px;font-size:36px}.event-layout{grid-template-columns:1fr;gap:16px}.event-dialog{min-height:auto}.island-game-header{padding:10px 12px;flex-wrap:wrap;gap:8px}.island-game-header-desk-only{display:none!important}.island-game-header-mobile-only{display:block!important}.island-game-resources{gap:10px;font-size:.9rem}.island-game-main{grid-template-columns:1fr;grid-template-rows:1fr;gap:0;padding:10px;overflow:hidden;-webkit-overflow-scrolling:touch}.island-game-main>.island-game-settlers.island-game-desk-only,.island-game-main>.island-game-buildings.island-game-desk-only{display:none!important}.island-game-main>.island-game-map{order:0;min-height:0;flex:1 1 0}.island-game-map-inner{grid-template-columns:1fr 1fr;grid-template-rows:1fr 1fr auto;grid-template-areas:"camp food" "wood stone" "market market";gap:8px;padding:8px;min-height:280px}.island-game-zone{min-height:64px;padding:10px;font-size:.8rem}.island-game-zone-title{font-size:.85rem}.island-game-settler-avatar{width:32px;height:32px;font-size:1rem}.island-game-placed-building{font-size:1.2rem}.island-game-footer{padding:12px;flex-wrap:wrap;gap:10px;flex-shrink:0;position:sticky;bottom:0;left:0;right:0;z-index:20;box-shadow:0 -2px 12px #0000001a}.island-game-footer-reset.island-game-desk-only{display:none!important}.island-game-next-day-btn{flex:1;min-width:200px;min-height:48px;font-size:1.05rem}.island-game-footer-actions{display:flex;flex-direction:column;align-items:stretch;gap:8px;width:100%}.island-game-mobile-panel{display:flex!important;flex-direction:column;position:fixed;left:0;right:0;bottom:0;max-height:55vh;background:var(--color-white);border-radius:var(--radius-lg) var(--radius-lg) 0 0;box-shadow:0 -4px 24px #00000026;z-index:100;overflow:hidden}.island-game-mobile-panel-header{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;border-bottom:1px solid var(--color-gray-200);flex-shrink:0;background:var(--color-bg)}.island-game-mobile-panel-title{margin:0;font-size:1rem}.island-game-mobile-panel-close{min-width:44px;min-height:44px}.island-game-mobile-panel-body{flex:1;overflow-y:auto;padding:12px;-webkit-overflow-scrolling:touch}.island-game-mobile-shop .island-game-building-card{margin-bottom:12px}.island-game-modal-backdrop{padding:16px;align-items:flex-end}.island-game-modal{max-height:85vh;overflow-y:auto}.island-game-tip{left:12px;right:12px;bottom:max(80px,env(safe-area-inset-bottom));transform:none;max-width:none}.island-game-warehouse-modal,.island-game-rules-modal{max-height:80vh}.investment-scenario{padding:12px}.investment-dialog-area{margin-left:12px;margin-right:12px}.investment-day-report-overlay,.investment-tip-overlay{padding:12px}}@media(max-width:480px){.app-main{padding:12px 10px}.app-brand-text{font-size:1rem}.header-logo-slot{width:32px;height:32px}.home-page__wrap{padding:0 10px 20px}.hero__title{font-size:1.35rem}.hero__play-tile{max-width:100%}.section-title{font-size:1.2rem}.feature-card__title{font-size:1rem}.feature-card__text{font-size:.9rem}.login-card{margin:0 8px;padding:20px 16px}.profile-section--cabinet .profile-section__head{flex-direction:column;align-items:flex-start}.profile-tabs{width:100%}.profile-tabs__btn{flex:1}.play-page__map-wrap .play-map{transform:scale(.5);transform-origin:center top}.scenario-modal__actions{flex-direction:column}.scenario-modal__actions .primary-btn,.scenario-modal__actions .secondary-btn{width:100%}.status-bar{flex-wrap:wrap;gap:10px}.chips-row{gap:6px}.pill-option{padding:6px 12px;font-size:.85rem}.dialog-area{width:calc(100vw - 20px);margin-left:10px;margin-right:10px}.island-game-map-inner{grid-template-areas:"camp food" "wood stone" "market market";gap:8px}.island-game-building-card{padding:10px}.island-game-building-drag-emoji{font-size:2rem}}@media(hover:none)and (pointer:coarse){.btn,.primary-btn,.secondary-btn,.pill-option{min-height:44px}.play-map__node-wrap{width:68px;height:68px;margin-left:-34px;margin-top:-34px}.play-map__node{width:68px;height:68px;min-width:68px;min-height:68px;font-size:1.3rem}.header-user-btn{min-height:44px;min-width:44px}}
