.app-shell{width:min(1160px,94vw);margin:0 auto;padding:3rem 0 4rem;color:#3b2f2f}.hero{display:flex;justify-content:space-between;align-items:center;gap:2rem;background:#fff7ef;border-radius:24px;padding:2.5rem;box-shadow:0 20px 60px #c27f4726}.hero__subtitle{color:#b96518;margin-bottom:.4rem;font-size:.95rem}.hero h1{font-size:clamp(2rem,4vw,3rem);margin:.2rem 0}.hero__intro{margin:.5rem 0 0;color:#82532a;line-height:1.6}.hero__meta{color:#8e6b3b;margin-top:.3rem}.hero__today{text-align:right;font-size:.95rem;color:#a57038}.hero__today strong{display:block;font-size:1.15rem;color:#623c1b}.language-toggle{border:none;background:#f0d7c3;color:#723a15;border-radius:999px;padding:.35rem .9rem;font-size:.85rem;cursor:pointer;transition:background .2s ease}.language-toggle:hover{background:#e2c1a5}.app-footer{margin-top:2rem;display:flex;justify-content:center}.calendar-shell{margin-top:1.8rem;display:grid;grid-template-columns:2fr 1fr;grid-template-areas:"calendar detail";gap:1.5rem}.panel{background:#fffdf9;border-radius:20px;padding:1.8rem;box-shadow:0 12px 40px #0000000d}.calendar{grid-area:calendar}.detail{grid-area:detail}.calendar__header{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;margin-bottom:1.2rem;gap:.75rem}.calendar__nav-btn,.calendar__today-btn{border:none;background:#f0d7c3;color:#723a15;cursor:pointer;transition:background .2s ease}.calendar__nav-btn:hover,.calendar__today-btn:hover{background:#e2c1a5}.calendar__nav-btn{border-radius:999px;width:40px;height:40px;font-size:1.5rem;display:inline-flex;align-items:center;justify-content:center}.calendar__today-btn{border-radius:999px;height:40px;padding:0 1.2rem;font-size:.95rem;font-weight:600}.calendar__weekdays{display:grid;grid-template-columns:repeat(7,1fr);text-align:center;font-weight:600;color:#a26f43;gap:.4rem;margin-bottom:.5rem}.calendar__grid{display:grid;grid-template-columns:repeat(7,1fr);gap:.4rem}.calendar__day{border:none;background:#fff;border-radius:16px;padding:.8rem 0;text-align:center;font-size:1rem;color:#5c4a34;cursor:pointer;box-shadow:inset 0 0 0 1px #b75c1c14;transition:transform .15s ease,box-shadow .15s ease}.calendar__day span{font-weight:600}.calendar__day--faded{color:#b9a89a;background:#fbf3eb}.calendar__day--selected{background:linear-gradient(130deg,#f5c686,#eda26a);color:#432a18;box-shadow:inset 0 0 0 2px #fff9}.calendar__day--today{box-shadow:inset 0 0 0 2px #87400e99}.calendar__day:hover{transform:translateY(-2px);box-shadow:0 8px 18px #00000014}.detail__date{margin:0;color:#b8541c;font-size:1.2rem;margin-bottom:1.2rem}.detail__block+.detail__block{margin-top:1.2rem}.detail__block h4{margin:0 0 .4rem;color:#824b1a}.detail__block ul{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:.35rem}.detail__block li{background:#fff4e6;color:#5e3514;padding:.45rem .9rem;border-radius:999px;font-size:.95rem;display:inline-flex;align-items:center;min-height:2.2rem}.skill-trigger{margin-top:1.8rem;display:flex;flex-direction:column;align-items:stretch;gap:1rem;background:#fffaf3;padding:1rem 1.5rem;border-radius:18px;box-shadow:0 10px 24px #0000000d}.skill-button{border:none;background:linear-gradient(120deg,#f9d7a5,#f2a972);color:#5c2f11;border-radius:16px;padding:1.05rem 2rem;font-size:1rem;font-weight:600;cursor:pointer;transition:transform .15s ease,box-shadow .2s ease;box-shadow:0 10px 20px #f2a97259;width:100%}.skill-button:hover{transform:translateY(-1px);box-shadow:0 14px 28px #f2a97273}.skill-button:disabled{cursor:not-allowed;opacity:.6;box-shadow:none;transform:none}.skill-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#1a0f04a6;display:flex;align-items:center;justify-content:center;padding:1.5rem;z-index:50}.skill-overlay__panel{background:#fffaf3;border-radius:28px;width:min(960px,100%);max-height:min(640px,90vh);box-shadow:0 30px 60px #00000040;padding:clamp(1.5rem,4vw,2.4rem);display:flex;flex-direction:column;gap:1.5rem}.skill-overlay__header{display:flex;justify-content:space-between;align-items:center;gap:1rem}.skill-overlay__header h4{margin:0;font-size:1.35rem;color:#7e3f16}.skill-overlay__close{border:none;background:transparent;color:#a45c19;font-size:.95rem;font-weight:600;cursor:pointer;padding:.4rem .8rem;border-radius:999px;transition:background .2s ease}.skill-overlay__close:hover{background:#a45c191a}.skill-overlay__cards{display:flex;gap:1rem}.skill-overlay__cards--solo button:not(.skill-card--active){display:none}.skill-card{flex:1;min-height:80px;border-radius:18px;background:#fffaf3;border:1px solid rgba(185,133,75,.25);padding:.9rem;display:flex;align-items:center;gap:.75rem;position:relative;cursor:pointer;text-align:left}.skill-card--active{border-color:#d28c3c;box-shadow:0 0 0 2px #eb974c73}.skill-card:focus-visible{outline:2px solid #de9d52}.skill-card:after{content:attr(data-tooltip);position:absolute;inset:auto auto calc(100% + 10px) 0;background:#3d2d1a;color:#fff;padding:.45rem .6rem;border-radius:8px;font-size:.8rem;line-height:1.2;opacity:0;pointer-events:none;transform:translateY(5px);transition:opacity .15s ease,transform .15s ease;width:max-content;max-width:220px;box-shadow:0 6px 20px #00000026}.skill-card:hover:after{opacity:1;transform:translateY(0)}.skill-card__logo{width:44px;height:44px;flex:0 0 44px;border-radius:50%;background:#f6c283;color:#5c2f11;display:inline-flex;align-items:center;justify-content:center;font-weight:700}.skill-card__content{display:flex;flex-direction:column;gap:.3rem}.skill-card__title{font-weight:600;color:#5b3216}.skill-card__description{display:none;color:#8d6b4c;font-size:.85rem;line-height:1.4}.skill-feedback{margin:0 0 1rem;color:#a2391f;font-size:.95rem}.skill-action{margin-top:1.4rem;background:#fff3e4;border-radius:20px;padding:1rem 1.2rem;display:flex;flex-direction:column;gap:.9rem;font-size:1rem}.skill-action__lists{display:flex;gap:1.5rem}.skill-entry-list{display:flex;flex-wrap:wrap;gap:.6rem;margin-top:.5rem}.skill-entry-btn,.skill-option-btn{border:none;background:#fff;border-radius:999px;padding:.4rem .9rem;font-size:.9rem;color:#6a3a1f;cursor:pointer;box-shadow:0 0 0 1px #b9854b4d;transition:transform .15s ease,box-shadow .15s ease}.skill-entry-btn:hover,.skill-option-btn:hover{transform:translateY(-1px);box-shadow:0 6px 14px #00000014}.skill-entry-empty{color:#b18d74;font-size:.85rem}.skill-options{display:flex;flex-wrap:wrap;gap:.75rem}.skill-action--lang-en{font-size:.9rem}.detail__note{margin-top:2rem;font-size:.85rem;color:#9a7a5b}@media (max-width: 900px){.calendar-shell{grid-template-columns:1fr;grid-template-areas:"detail" "calendar"}}@media (max-width: 720px){.skill-overlay__panel{padding:1.2rem;max-height:none}.skill-overlay__cards{flex-direction:column}.skill-card:after{display:none}.skill-card__description{display:block}.skill-action__lists{flex-direction:column}.hero{flex-direction:column;text-align:left}.hero__today{text-align:left}}:root{font-family:"Noto Serif SC",PingFang SC,system-ui,-apple-system,BlinkMacSystemFont,Helvetica Neue,sans-serif;color:#1f1f1f;background-color:#f5f1eb;line-height:1.5;font-weight:400;color-scheme:light}*{box-sizing:border-box}body{margin:0;min-height:100vh;background:radial-gradient(circle at top,#fff7e6,#f5f1eb 45%,#efe6da)}a{color:inherit}#root{min-height:100vh}
