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