.cmp--taipei{--cmp-accent:var(--coral);--cmp-accent-deep:var(--coral-deep);--cmp-accent-tint:var(--coral-tint)}.cmp--yongheng{--cmp-accent:var(--sage-deep);--cmp-accent-deep:#6B826B;--cmp-accent-tint:var(--sage-tint)}.cmp-hero{position:relative;background:var(--cream);overflow:hidden;padding-block:clamp(34px,4.2vw,60px) clamp(24px,3vw,42px)}.cmp-hero h1{font-size:clamp(30px,3.6vw,44px);letter-spacing:.06em;line-height:1.42;text-wrap:balance}.mama-home .cmp-hero h1,.mama-home .cmp-cta h3{color:var(--wood-title);letter-spacing:.06em}.cmp-hero .eyebrow{margin-bottom:18px}.cmp-hero-lead{margin-top:12px;color:var(--ink-soft);font-size:16px;line-height:1.8;letter-spacing:.02em;max-width:620px}.cmp-hero-addr{margin-top:14px;display:inline-flex;align-items:flex-start;gap:10px;color:var(--ink-soft);font-size:15.5px;line-height:1.7}.cmp-hero-addr svg{width:20px;height:20px;stroke:var(--sage-deep);fill:none;flex-shrink:0;margin-top:3px}.cmp-flag-pill{display:inline-flex;align-items:center;gap:8px;margin-bottom:14px;font-family:var(--f-display);font-weight:700;font-size:14px;color:#fff;padding:7px 18px;border-radius:var(--r-pill);background:var(--cmp-accent,var(--sage));box-shadow:var(--sh-xs)}.cmp-flag-pill .dot{width:7px;height:7px;border-radius:50%;background:#ffffffd9}.cmp-tabs{display:flex;flex-wrap:wrap;justify-content:center;gap:16px;align-items:center;width:min(100%,920px);margin:0 auto clamp(34px,4.4vw,54px)}.cmp-tab{display:inline-flex;align-items:center;justify-content:center;min-height:56px;min-width:118px;padding:13px 24px;font-family:var(--f-display);font-weight:700;font-size:17px;letter-spacing:.04em;color:var(--sage-deep);background:#fff;border:var(--pencil-w) solid var(--pencil);border-radius:15px 24px 14px 22px/22px 14px 26px 16px;filter:url(#wobble-lite);transition:transform .28s cubic-bezier(.34,1.4,.64,1),background .2s,color .2s,border-color .2s,box-shadow .25s}.cmp-tab:nth-of-type(2n){border-radius:24px 14px 22px 15px/15px 24px 14px 26px}.cmp-tab:hover{transform:translateY(-3px) rotate(-1deg);border-color:var(--sage);box-shadow:var(--sh-sm)}.cmp-tab.is-active{background:var(--sage);border-color:var(--sage);color:#fff;box-shadow:0 8px 18px -8px #7e947e80}.cmp-tab.is-active:hover{transform:none}.cmp-route{position:relative;max-width:720px;margin:-10px auto clamp(34px,4vw,52px)}.cmp-route svg{width:100%;height:auto;display:block}.cmp-route text{font-family:var(--f-display);font-weight:700;font-size:16px;fill:var(--ink-soft)}.cmp-route .cmp-route-note{font-size:13px;fill:var(--ink-faint);font-weight:500}.cmp-honor-note{margin-top:20px;display:flex;gap:11px;align-items:flex-start;background:var(--butter-paper);border:1.6px dashed #E2CD96;border-radius:14px 20px 12px 18px/18px 12px 22px 14px;padding:13px 16px;font-size:13.5px;line-height:1.85;color:var(--wood-deep)}.cmp-honor-note svg{width:22px;height:22px;flex-shrink:0;stroke:#c7a14e;fill:none;margin-top:2px}.cmp-honor-note strong{font-family:var(--f-display);font-weight:700}.cmp-actions{margin-top:24px;display:flex;flex-wrap:wrap;gap:10px}.cmp-actions .btn{padding:11px 20px;font-size:15px;min-height:46px}.cmp-foot-note{text-align:center;max-width:560px;margin-inline:auto;position:relative}.cmp-foot-note .eyebrow{display:inline-block;margin-bottom:8px}.cmp-foot-note p{color:var(--ink-soft);font-size:16.5px;line-height:2;letter-spacing:.02em}.cmp-duo{display:grid;grid-template-columns:1.04fr .96fr;gap:36px;align-items:start}.cmp-card{position:relative;background:#fff;box-shadow:var(--sh-sm);border-radius:26px 36px 24px 32px/32px 24px 38px 26px;padding:30px 30px 32px;transition:transform .35s cubic-bezier(.34,1.4,.64,1),box-shadow .35s}.cmp-card--a{transform:rotate(-1.1deg)}.cmp-card--b{transform:rotate(1deg);margin-top:30px;border-radius:36px 26px 32px 24px/24px 36px 26px 38px}.cmp-card:hover{transform:translateY(-5px) rotate(0);box-shadow:var(--sh-md);z-index:3}.cmp-card-head{display:flex;align-items:center;gap:13px;margin-bottom:20px}.cmp-card-head h3{font-size:21px;color:var(--ink)}.cmp-card-ico{position:relative;width:46px;height:46px;flex-shrink:0;display:flex;align-items:center;justify-content:center}.cmp-card-ico:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;z-index:0;filter:url(#wobble-lite);background:var(--sage-tint);border-radius:46% 54% 52% 48%/54% 46%}.cmp-card-ico svg{position:relative;z-index:1;width:26px;height:26px;stroke:var(--sage-deep);fill:none}.cmp-card .campus-info li{font-size:15px;line-height:1.85}.cmp-card .campus-info .cmp-k{font-family:var(--f-display);font-weight:700;color:var(--ink);margin-right:8px;white-space:nowrap}.cmp-honor{position:relative;max-width:660px;margin:46px auto 0;background:var(--butter-paper);border-radius:20px 30px 18px 26px/26px 18px 32px 20px;padding:28px 32px 26px;box-shadow:var(--sh-sm);transform:rotate(-.9deg)}.cmp-honor:before{content:"";position:absolute;top:-11px;left:50%;width:92px;height:26px;z-index:2;transform:translate(-50%) rotate(-3deg);filter:url(#wobble-lite);background:repeating-linear-gradient(45deg,#e78c9966 0,#e78c9966 6px,#e78c993d 6px,#e78c993d 12px);box-shadow:0 2px 6px -2px #78684c40}.cmp-honor h4{display:flex;align-items:center;gap:10px;font-size:18px;color:var(--wood-deep);margin-bottom:10px}.cmp-honor h4 svg{width:26px;height:26px;stroke:#c7a14e;fill:none;flex-shrink:0}.cmp-honor p{font-size:15px;line-height:1.95;color:var(--ink-soft);letter-spacing:.02em}.cmp-fp{margin:0;position:relative;background:#fff;box-shadow:var(--sh-sm);border-radius:26px 36px 24px 32px/32px 24px 38px 26px;padding:24px 24px 20px}.cmp-fp-cap{display:flex;align-items:baseline;flex-wrap:wrap;gap:6px 16px;margin-bottom:16px}.cmp-fp-en{font-family:var(--f-hand-en);font-weight:700;font-size:23px;color:var(--sage-deep);display:inline-block;transform:rotate(-2.5deg);line-height:1}.cmp-fp-title{font-family:var(--f-display);font-weight:700;font-size:18px;color:var(--ink)}.cmp-fp-canvas svg{width:100%;height:auto;display:block}.cmp-fp-room rect{stroke-width:2;filter:url(#wobble-lite)}.cmp-fp-room text{font-family:var(--f-display);font-weight:700;fill:var(--ink-soft)}.cmp-fp--classroom rect{fill:#edf0e6;stroke:#a8baaa}.cmp-fp--classroom text{fill:var(--sage-deep)}.cmp-fp--activity rect{fill:#fbedc4;stroke:#d9b96a}.cmp-fp--activity text{fill:var(--wood-deep)}.cmp-fp--outdoor rect{fill:#eaf4f7;stroke:#9cc3cf}.cmp-fp--outdoor text{fill:#5e8794}.cmp-fp--utility rect{fill:#f6f3ec;stroke:#d8d2c4}.cmp-fp--entry rect{fill:#faf1f3;stroke:#e78c99;stroke-dasharray:5 4}.cmp-fp--entry text{fill:var(--coral-deep)}.cmp-fp-legend{display:flex;flex-wrap:wrap;gap:8px 18px;margin-top:16px}.cmp-fp-key{display:inline-flex;align-items:center;gap:7px;font-size:13px;font-weight:500;color:var(--ink-soft)}.cmp-fp-key i{width:14px;height:14px;display:inline-block;flex-shrink:0;border-radius:5px 7px 4px 6px;border:1.6px solid}.cmp-fp-key--classroom i{background:#edf0e6;border-color:#a8baaa}.cmp-fp-key--activity i{background:#fbedc4;border-color:#d9b96a}.cmp-fp-key--outdoor i{background:#eaf4f7;border-color:#9cc3cf}.cmp-fp-key--utility i{background:#f6f3ec;border-color:#d8d2c4}.cmp-fp-key--entry i{background:#faf1f3;border-color:#e78c99;border-style:dashed}.cmp-map{position:relative;background:#fff;box-shadow:var(--sh-sm);border-radius:26px 34px 24px 32px/32px 24px 36px 26px;padding:20px 20px 18px;margin-top:38px;transform:rotate(.5deg)}.cmp-map-head{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:8px 14px;margin-bottom:14px}.cmp-map-head h3{font-size:19px;color:var(--ink)}.cmp-map-open{display:inline-flex;align-items:center;gap:6px;min-height:44px;padding:4px 8px;font-family:var(--f-display);font-weight:700;font-size:14.5px;color:var(--sage-deep);white-space:nowrap;transition:color .2s,transform .2s}.cmp-map-open svg{width:17px;height:17px;flex:none}.cmp-map-open:hover{color:var(--coral-deep);transform:translate(3px)}.cmp-map iframe{display:block;width:100%;height:340px;border:0;border-radius:16px 24px 14px 22px/22px 14px 26px 16px;filter:saturate(.85) contrast(.97)}.cmp-class-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:30px 22px;margin-top:8px}.cmp-class-grid--centered{grid-template-columns:repeat(3,minmax(0,270px));justify-content:center}.cmp-class{position:relative;background:#fff;box-shadow:var(--sh-sm);text-align:center;border-radius:22px 30px 20px 28px/28px 20px 32px 22px;padding:28px 16px 24px;transition:transform .35s cubic-bezier(.34,1.4,.64,1),box-shadow .35s}.cmp-class:nth-child(2n){border-radius:30px 22px 28px 20px/20px 30px 22px 32px}.cmp-class:nth-child(1){transform:rotate(-2.2deg);margin-top:8px}.cmp-class:nth-child(2){transform:rotate(1.6deg);margin-top:-6px}.cmp-class:nth-child(3){transform:rotate(-1.2deg);margin-top:14px}.cmp-class:nth-child(4){transform:rotate(2.2deg);margin-top:-2px}.cmp-class:hover{transform:translateY(-7px) rotate(0);box-shadow:var(--sh-md);z-index:3}.cmp-animal{position:relative;width:88px;height:88px;margin:0 auto 14px;display:flex;align-items:center;justify-content:center}.cmp-animal:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;z-index:0;filter:url(#wobble-lite);background:var(--sage-tint);border-radius:46% 54% 52% 48%/54% 46%;transition:transform .4s cubic-bezier(.34,1.4,.64,1)}.cmp-class:nth-child(2n) .cmp-animal:before{border-radius:54% 46% 48% 52%/46% 54%}.cmp-class:hover .cmp-animal:before{transform:scale(1.08) rotate(-5deg)}.cmp-animal svg{position:relative;z-index:1;width:56px;height:56px}.cmp-animal img{position:relative;z-index:1;width:62px;height:62px;object-fit:contain}.cmp-animal span{position:relative;z-index:1;font-family:var(--f-display);font-size:32px;font-weight:700;color:var(--sage-deep)}.cmp-class h3{font-size:21px;color:var(--ink);margin-bottom:8px}.cmp-level{display:inline-block;font-family:var(--f-display);font-weight:700;font-size:12.5px;color:var(--sage-deep);background:var(--sage-tint);padding:4px 14px;border-radius:var(--r-pill)}.cmp-cta{position:relative;background:#fff;box-shadow:var(--sh-sm);margin-top:clamp(44px,5vw,64px);border-radius:28px 38px 26px 34px/34px 26px 40px 28px;padding:32px 34px;display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:18px 24px;transform:rotate(-.5deg)}.cmp-cta h3{font-size:22px;margin-bottom:6px}.cmp-cta p{color:var(--ink-soft);font-size:15px;line-height:1.85}.cmp-cta-btns{display:flex;flex-wrap:wrap;gap:12px}.cmp-empty{max-width:560px;margin-inline:auto;text-align:center;background:#fff;box-shadow:var(--sh-xs);color:var(--ink-faint);font-size:15.5px;border-radius:24px 32px 22px 30px/30px 22px 34px 24px;padding:48px 28px;transform:rotate(-.4deg)}@media(max-width:1000px){.cmp-duo{grid-template-columns:1fr;gap:28px}.cmp-card--b{margin-top:0}.cmp-class-grid{grid-template-columns:repeat(2,1fr);gap:26px 18px}.cmp-class-grid--centered{grid-template-columns:repeat(2,1fr);justify-content:stretch}.cmp-class-grid--centered .cmp-class:nth-child(3){grid-column:1/-1;width:calc((100% - 18px)/2);justify-self:center}}@media(max-width:760px){.cmp-hero{padding-block:34px 22px}.cmp-hero h1{font-size:clamp(28px,7.4vw,36px)}.cmp-tabs{gap:10px;width:100%}.cmp-tab{flex:1 1 calc(50% - 10px);min-width:0;min-height:50px;padding:10px 12px;font-size:15px}.cmp-tab:nth-of-type(n){margin-top:0}.cmp-route{margin-bottom:26px}.cmp-actions .btn{flex:1 1 calc(50% - 10px);padding:11px 12px;font-size:14.5px}.cmp-card--a,.cmp-card--b{transform:none}.cmp-card{padding:24px 22px 26px}.cmp-honor{transform:none;padding:24px 22px 22px}.cmp-class-grid{gap:20px 14px}.cmp-class-grid--centered .cmp-class:nth-child(3){width:calc((100% - 14px)/2)}.cmp-class:nth-child(n){transform:none;margin-top:0}.cmp-class{padding:22px 12px 20px}.cmp-animal{width:74px;height:74px}.cmp-animal svg{width:46px;height:46px}.cmp-cta{flex-direction:column;align-items:flex-start;padding:26px 24px;transform:none}.cmp-cta-btns{width:100%}.cmp-cta-btns .btn{flex:1}.cmp-map iframe{height:280px}}@media(prefers-reduced-motion:reduce){.cmp-tab,.cmp-card,.cmp-class,.cmp-map-open{transition-duration:.01ms!important}}
