:root{--color-gold:#b39218;--color-gold-soft:#efe3b4;--color-gold-line:#c8aa3c;--color-text:#707070;--color-heading:#6f6f6f;--color-page:#f6f6f6;--color-beige:#eee9d9;--color-card:#fff;--shadow-card:0 2px 8px #5f4f2a2e;--footer-height:78px;color:var(--color-text);font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:#e9e5df;font-family:Hiragino Kaku Gothic ProN,Hiragino Sans,-apple-system,BlinkMacSystemFont,Yu Gothic,YuGothic,Meiryo,sans-serif;font-size:17px}*{box-sizing:border-box}html,body,#root{min-height:100svh}body{min-width:320px;margin:0}button,input{font:inherit}button{cursor:pointer}a{color:inherit;text-decoration:none}.phone-frame{background:var(--color-page);width:min(100%,430px);min-height:100svh;margin:0 auto;position:relative;overflow-x:hidden;box-shadow:0 0 0 1px #0000000a}.header-logo{z-index:2;background:#fff;place-items:center;height:76px;display:grid;position:relative}.brand-logo{width:45vw;height:auto;display:block}.dashboard-page{padding-bottom:calc(var(--footer-height) + env(safe-area-inset-bottom));background:var(--color-page)}.dashboard-page--state{min-height:calc(100svh - 76px);padding:28px 29px calc(var(--footer-height) + env(safe-area-inset-bottom) + 28px);align-items:center;display:grid}.dashboard-state-card{box-shadow:var(--shadow-card);background:#fff;border:1px solid #cdb5725c;border-radius:16px;padding:24px 20px}.dashboard-state-card h1{color:var(--color-heading);text-align:center;font-size:20px}.dashboard-state-card .button{margin-top:18px}.reservation-area{background:var(--color-beige);z-index:1;padding:18px 29px 16px;position:relative}.reservation-area:after{background:var(--color-beige);content:"";border-radius:0 0 50% 50%/0 0 100% 100%;height:40px;position:absolute;bottom:-16px;left:-12%;right:-12%}.reservation-area>*{z-index:1;position:relative}.content-area{padding:24px 29px 0}.content-area--courses{margin-top:5px;padding-top:34px;padding-bottom:22px;position:relative}.content-area--cards{background:#fff;padding-top:32px;padding-bottom:32px}.section-title{width:fit-content;color:var(--color-heading);letter-spacing:.02em;justify-content:center;align-items:center;margin:0 auto 14px;padding:0 4px;font-size:25px;font-weight:800;line-height:1;display:flex;position:relative}.section-title:after{z-index:0;background:var(--color-gold-line);content:"";height:3px;position:absolute;bottom:1px;left:0;right:0}.section-title>span{z-index:1;position:relative}.section-title__icon{width:30px;height:24px;color:var(--color-gold-line);place-items:center;margin-right:6px;font-size:21px;line-height:1;display:inline-grid}.section-title__icon svg{fill:none;stroke:currentColor;stroke-linecap:round;stroke-linejoin:round;stroke-width:1.8px;width:30px;height:24px}.appointment-card,.course-card,.linked-clinic-card{background:var(--color-card);box-shadow:var(--shadow-card);border:1px solid #cdb5725c;border-radius:8px}.appointment-card{border:0;padding:16px 20px 15px;box-shadow:2px 3px #c8aa3c66,0 2px 8px #c8aa3c33}.appointment-card__date{color:#858585;text-align:center;margin:0;font-size:19px;line-height:1.45}.appointment-card__clinic-row{border-top:2px solid var(--color-gold-line);border-bottom:2px solid var(--color-gold-line);grid-template-columns:1fr auto;align-items:center;min-height:32px;margin-top:4px;display:grid;position:relative}.appointment-card__clinic{color:#666;text-align:center;grid-column:1/-1;margin:0;padding:5px 62px;font-size:19px;font-weight:800;line-height:1.2}.map-pill{color:#b49622;letter-spacing:.02em;background:#f5eab7;border-radius:999px;justify-content:center;align-items:center;min-width:54px;height:23px;font-size:13px;font-weight:800;display:inline-flex;position:absolute;right:0}.appointment-card__items{color:#9a9a9a;gap:3px;margin:11px 0 0;padding:0;font-size:13px;font-weight:500;line-height:1.35;list-style:none;display:grid}.appointment-card__items li{padding-left:15px;position:relative}.appointment-card__items li:before{background:var(--color-gold);content:"";border-radius:1px;width:8px;height:8px;position:absolute;top:.4em;left:0;transform:rotate(45deg)}.appointment-card--empty{place-items:center;min-height:170px;padding:30px 22px 28px;display:grid}.appointment-card--empty p{color:#777;margin:0;font-size:16px;font-weight:800}.web-reserve-button{color:#fff;background:var(--color-gold);border-radius:999px;justify-content:center;align-items:center;width:100%;max-width:310px;min-height:46px;margin-top:18px;font-size:19px;font-weight:800;display:inline-flex}.course-list{gap:12px;display:grid}.course-card{border:0;padding:14px 19px 12px;box-shadow:2px 3px #c8aa3c66,0 2px 8px #c8aa3c33}.course-card__clinic,.course-card__name{margin:0}.course-card__clinic{color:#777;font-size:15px;font-weight:800;line-height:1.35}.course-card__name{color:#8d8d8d;margin-top:2px;padding-left:15px;font-size:14px;font-weight:500;line-height:1.32;position:relative}.course-card__name:before{background:var(--color-gold);content:"";border-radius:1px;width:8px;height:8px;position:absolute;top:.45em;left:0;transform:rotate(45deg)}.course-card__meta{color:#c0a23a;justify-content:space-between;align-items:center;gap:8px;margin-top:7px;padding-left:15px;font-size:14px;font-weight:500;display:flex}.remaining-pill{color:#b79a26;white-space:nowrap;background:#f5eab7;border-radius:999px;justify-content:center;align-items:center;gap:1px;min-width:68px;height:25px;padding:0 10px;display:inline-flex}.remaining-pill__label,.course-card__expires-label{color:#8d8d8d}.course-card__expires{white-space:nowrap}.clinic-card-list{gap:10px;display:grid}.dashboard-empty-text{color:#8d8d8d;box-shadow:var(--shadow-card);text-align:center;background:#fff;border:1px solid #cdb5725c;border-radius:8px;margin:0;padding:18px 12px;font-size:13px;font-weight:800;line-height:1.6}.linked-clinic-card{background:radial-gradient(circle at 0 0,#be981829,#0000 44%),linear-gradient(135deg,#fff9e9 0%,#fff 52%,#fffdf8 100%);min-height:154px;padding:26px 22px 18px}.linked-clinic-card__top{justify-content:space-between;align-items:flex-start;gap:12px;display:flex}.linked-clinic-card__clinic{color:var(--color-gold);font-size:21px;font-weight:800;line-height:1.2}.linked-clinic-card__brand{aspect-ratio:1232/197;transform-origin:100%;background:#8d8d8d;flex:none;width:90px;margin-top:2px;display:block;-webkit-mask:url(/takasu-clinic-logo.svg) 50%/contain no-repeat;mask:url(/takasu-clinic-logo.svg) 50%/contain no-repeat}.linked-clinic-card__number{color:var(--color-gold);text-align:right;letter-spacing:.03em;margin:58px 0 0;font-size:24px;font-weight:600;line-height:1}.add-clinic-button{color:#9b9b9b;background:#fff;border:1px solid #cfcfcf;border-radius:18px;justify-content:center;align-items:center;width:calc(100% - 34px);height:45px;margin:22px auto 0;padding:0 18px;font-size:15px;font-weight:700;display:flex;position:relative;box-shadow:0 1px 4px #0000001a}.add-clinic-button span{color:#b1b1b1;margin:0;font-size:19px;font-weight:400;position:absolute;left:19px}.footer-nav{z-index:10;width:min(100vw,430px);height:calc(var(--footer-height) + env(safe-area-inset-bottom));padding:8px 18px calc(7px + env(safe-area-inset-bottom));background:var(--color-gold);grid-template-columns:repeat(3,1fr);margin:0 auto;display:grid;position:fixed;bottom:0;left:50%;transform:translate(-50%)}.footer-nav__item{color:#fff;text-align:center;background:0 0;border:0;place-items:center;gap:2px;min-width:0;font-size:11px;font-weight:700;line-height:1;display:grid}.footer-nav__icon{color:#fff;place-items:center;width:38px;height:34px;font-size:34px;font-weight:400;line-height:1;display:grid}.footer-nav__icon svg{fill:none;stroke:currentColor;stroke-linecap:round;stroke-linejoin:round;stroke-width:2.1px;width:36px;height:34px}.modal-backdrop{z-index:20;padding:118px 30px calc(var(--footer-height) + env(safe-area-inset-bottom));background:#0000008a;justify-content:center;align-items:flex-start;display:flex;position:fixed;inset:0}.modal-panel{background:#fff;border-radius:8px;width:min(100%,370px);padding:23px 31px;position:relative;box-shadow:0 4px 14px #0003}.modal-close{color:#9d9d9d;background:#fff;border:1px solid #d8d8d8;border-radius:999px;place-items:center;width:38px;height:38px;padding:0;font-size:24px;font-weight:400;line-height:1;display:grid;position:absolute;top:-16px;right:-16px;box-shadow:0 2px 5px #0000001a}.modal-title{color:#777;text-align:center;margin:0 0 18px;font-size:16px;font-weight:800;line-height:1.4}.modal-list{gap:10px;display:grid}.modal-clinic-button{color:#fff;background:var(--color-gold);border-radius:999px;place-items:center;min-height:45px;font-size:17px;font-weight:800;display:grid}.modal-bottom-close{color:#fff;background:0 0;border:0;font-size:17px;font-weight:800;position:absolute;bottom:-37px;right:11px}.miniapp-state{background:#fff;place-items:center;width:min(100%,430px);min-height:100svh;margin:0 auto;padding:24px;display:grid}.miniapp-state--error{align-content:center;gap:16px}.miniapp-state .loading-spinner{margin:0 auto}.miniapp-state .form-error{width:100%;margin:0}.app-shell{background:#fff;width:min(100%,430px);min-height:100svh;margin:0 auto;padding:24px 18px 40px}.phone-frame .app-shell{width:100%;min-height:auto}.phone-frame--connect{background:#fff}.app-shell--connect{padding:28px 28px 42px}.connect-section{display:block}.panel{box-shadow:var(--shadow-card);background:#fffaf2;border:1px solid #cdb5725c;border-radius:22px;padding:22px 18px}.eyebrow{color:var(--color-gold);letter-spacing:.08em;margin:0 0 8px;font-size:12px;font-weight:700}h1,p{margin-top:0}h1{color:#333;margin-bottom:12px;font-size:26px;line-height:1.3}.text-muted{color:var(--color-text);font-size:16px;line-height:1.75}.connect-form{gap:16px;margin-top:24px;display:grid}.form-field{color:#333;gap:8px;font-size:16px;font-weight:700;display:grid}.form-field input{background:#fff;border:1px solid #cdb5725c;border-radius:12px;width:100%;min-height:48px;padding:10px 14px}.button{border:1px solid #0000;border-radius:999px;justify-content:center;align-items:center;min-height:48px;padding:12px 18px;font-weight:700;display:inline-flex}.button--primary{color:#fff;background:var(--color-gold)}.button--full{width:100%}.button:disabled{cursor:not-allowed;opacity:.65}.notice-box{color:var(--color-text);background:#fff;border:1px solid #cdb5725c;border-radius:16px;margin-top:18px;padding:14px;font-size:13px;line-height:1.7}.notice-box strong{color:#333;margin-bottom:6px;display:block}@media (width<=360px){.header-logo{height:58px}.brand-logo{width:45vw}.reservation-area,.content-area{padding-left:16px;padding-right:16px}.section-title{font-size:18px}.appointment-card__date,.appointment-card__clinic{font-size:16px}.linked-clinic-card{min-height:96px}.linked-clinic-card__number{margin-top:32px;font-size:16px}}.clinic-list{gap:12px;margin-top:22px;display:grid}.clinic-option{color:#fff;background:var(--color-gold);min-height:54px;box-shadow:var(--shadow-card);border-radius:999px;gap:2px;padding:11px 16px;font-size:16px;font-weight:800;display:grid}.clinic-option small{opacity:.88;font-size:12px;font-weight:700}.selected-clinic{background:#fff;border:1px solid #cdb5725c;border-radius:14px;gap:4px;padding:13px 14px;display:grid}.selected-clinic span{color:var(--color-gold);font-size:12px;font-weight:700}.selected-clinic strong{color:#333;font-size:17px}.form-error{color:#9b1c1c;background:#fff1f1;border-radius:12px;margin:12px 0 0;padding:10px 12px;font-size:13px;font-weight:700;line-height:1.6}.loading-spinner{color:var(--color-text);justify-items:center;gap:10px;margin:18px auto 0;font-size:13px;font-weight:700;line-height:1.5;display:grid}.loading-spinner--inline{color:inherit;font-size:inherit;align-items:center;gap:8px;margin:0;line-height:1;display:inline-flex}.loading-spinner__icon{place-items:center;width:40px;height:40px;display:inline-grid;position:relative}.loading-spinner--small .loading-spinner__icon{width:18px;height:18px}.loading-spinner__image{width:100%;height:100%;display:block}.loading-spinner__image--dark{display:none}.loading-spinner__label{display:inline-block}@media (prefers-color-scheme:dark){.loading-spinner__image--light{display:none}.loading-spinner__image--dark{display:block}}
