:root{--bg:#fff8f3;--surface:#ffffffbd;--border:#a0616f29;--ink:#34252d;--muted:#7f6a72;--muted-strong:#66545b;--accent:#b94c64;--accent-strong:#8f233d;--accent-soft:#fff1ea;--shadow-soft:0 24px 60px #9b565f24, 0 8px 18px #8a495214;--font-body:"Avenir Next", "PingFang SC", "Hiragino Sans GB", "Microsoft YaHei", sans-serif;--font-display:"Iowan Old Style", "Palatino Linotype", "Book Antiqua", Georgia, serif;font-family:var(--font-body);color:var(--ink);background:var(--bg);font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-weight:400;line-height:1.5}*,:before,:after{box-sizing:border-box}html{scroll-behavior:smooth}body{min-width:320px;color:var(--ink);background:radial-gradient(circle at top,#ffcfbab3,#0000 38%),radial-gradient(circle at 90% 20%,#e79c521f,#0000 28%),linear-gradient(#fff7f1 0%,#fffdfa 48%,#fef1e6 100%);margin:0}button,input,textarea{font:inherit}button{cursor:pointer}img{max-width:100%;display:block}a{color:inherit}h1,h2,h3,p,ul,dl,dd{margin:0}#root{min-height:100svh}.app-shell{min-height:100svh;padding:28px 20px 56px;position:relative;overflow:hidden}.ambient{filter:blur(24px);opacity:.78;pointer-events:none;border-radius:999px;position:absolute}.ambient-one{background:#ffc29e8c;width:18rem;height:18rem;top:-6rem;left:-3rem}.ambient-two{background:#e4889852;width:22rem;height:22rem;top:18rem;right:-8rem}.ambient-three{background:#ffe2b285;width:18rem;height:18rem;bottom:-5rem;left:25%}.app-container{z-index:1;flex-direction:column;gap:24px;width:min(1160px,100%);margin:0 auto;display:flex;position:relative}.panel{-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px);border:1px solid var(--border);box-shadow:var(--shadow-soft);background:linear-gradient(160deg,#ffffffe0,#fff8f3b8);border-radius:30px;position:relative;overflow:hidden}.panel:before{content:"";pointer-events:none;background:radial-gradient(circle at 100% 0,#ffe4d9b3,#0000 30%),radial-gradient(circle at 0 100%,#ffefcf8c,#0000 28%);position:absolute;inset:0}.panel>*{z-index:1;position:relative}.eyebrow{color:var(--accent-strong);letter-spacing:.24em;text-transform:uppercase;margin:0 0 12px;font-size:.82rem;font-weight:700}.panel-head{justify-content:space-between;align-items:flex-start;gap:16px;display:flex}.panel-title h2,.panel-title p{margin:0}.panel-title h2{font-family:var(--font-display);font-size:clamp(1.8rem,3vw,2.4rem);line-height:1.05}.panel-title p{max-width:34rem;margin-top:10px}.hero-panel{grid-template-columns:minmax(0,1.3fr) minmax(290px,.8fr);gap:24px;padding:clamp(28px,5vw,52px);animation:.85s both fade-up;display:grid}.hero-panel:after{content:"";pointer-events:none;background:radial-gradient(circle,#f2889938,#0000 64%);border-radius:999px;width:18rem;height:18rem;position:absolute;inset:auto -9% -18% auto}.hero-copy h1{max-width:11ch;font-family:var(--font-display);letter-spacing:-.05em;margin:0;font-size:clamp(3rem,8vw,5.3rem);line-height:.94}.hero-text{max-width:38rem;margin-top:18px;font-size:1.05rem;line-height:1.75}.hero-actions{flex-wrap:wrap;align-items:center;gap:16px;margin-top:24px;display:flex}.hero-note{max-width:22rem;color:var(--muted-strong);font-size:.95rem}.hero-aside{align-content:end;gap:16px;display:grid}.hero-card{background:linear-gradient(#ffffffb8,#fff0ebd6);border:1px solid #ab5a6b29;border-radius:26px;padding:24px;box-shadow:inset 0 1px #fffc}.hero-card strong{font-family:var(--font-display);color:var(--ink);margin-top:12px;font-size:3.4rem;line-height:.92;display:block}.hero-card span{color:var(--muted-strong);margin-top:10px;display:inline-block}.hero-card p{margin:0}.hero-tag-list{grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;margin:0;padding:0;list-style:none;display:grid}.hero-tag{color:var(--muted-strong);background:#ffffffad;border:1px solid #ab5a6b24;border-radius:18px;padding:14px 16px}.hero-tag strong{color:var(--ink);margin-bottom:4px;display:block}.app-main{flex-direction:column;gap:24px;display:flex}.main-grid{grid-template-columns:minmax(0,1.15fr) minmax(310px,.85fr);align-items:start;gap:24px;display:grid}.wheel-panel,.result-panel,.editor-panel{animation:.9s both fade-up}.wheel-panel{padding:28px}.sound-toggle,.ghost-button,.secondary-button,.primary-button,.danger-button{border:none;transition:transform .22s,box-shadow .22s,background-color .22s,color .22s}.sound-toggle:hover,.ghost-button:hover,.secondary-button:hover,.primary-button:hover,.danger-button:hover{transform:translateY(-1px)}.sound-toggle:focus-visible,.ghost-button:focus-visible,.secondary-button:focus-visible,.primary-button:focus-visible,.danger-button:focus-visible,.field input:focus-visible,.field textarea:focus-visible{outline-offset:2px;outline:2px solid #8f233d59}.sound-toggle{color:var(--muted-strong);background:#fff4f0e6;border-radius:999px;flex-shrink:0;padding:10px 16px;box-shadow:inset 0 0 0 1px #8f233d14}.sound-toggle.is-active{color:#fffdf8;background:linear-gradient(135deg,#f7c6ae,#df7b85);box-shadow:0 12px 24px #b94c6438}.wheel-layout{grid-template-columns:minmax(0,1fr) 250px;align-items:center;gap:20px;margin-top:26px;display:grid}.wheel-stage{place-items:center;min-height:32rem;display:grid;position:relative}.wheel-stage:before{content:"";filter:blur(6px);background:radial-gradient(circle,#ffe3be61,#0000 65%);border-radius:50%;position:absolute;inset:2rem}.wheel-pointer{border-left:18px solid #0000;border-right:18px solid #0000;border-top:34px solid var(--accent-strong);filter:drop-shadow(0 10px 14px #8f233d33);z-index:4;width:0;height:0;position:absolute;top:.5rem;left:50%;transform:translate(-50%)}.wheel-face{aspect-ratio:1;width:min(100%,30rem);transform:rotate(var(--rotation-offset,0deg));position:relative}.wheel-face.is-spinning{animation:live-spin var(--spin-cycle,.8s) linear infinite}.wheel-face.is-stopping{transition:transform var(--stop-duration,2.6s) cubic-bezier(.15, .82, .2, 1)}.wheel{aspect-ratio:1;border:14px solid #ffffffd6;border-radius:50%;width:100%;animation:7s ease-in-out infinite wheel-breath;position:relative;overflow:hidden;box-shadow:0 25px 70px #9c4f5f2e,inset 0 1px #ffffffd9}.wheel-label-layer{pointer-events:none;position:absolute;inset:0;overflow:visible}.wheel:before,.wheel:after{content:"";border-radius:inherit;pointer-events:none;position:absolute;inset:0}.wheel:before{background:radial-gradient(circle at 28% 28%,#ffffff57,#0000 24%),radial-gradient(circle,#ffffff0f,#0000 60%)}.wheel:after{border:1px solid #ffffff42;inset:16px}.wheel.is-empty{background:radial-gradient(circle,#fff4ece6,#f8e4dad6)}.wheel-label{z-index:2;text-align:center;pointer-events:none;color:#3e1c25e6;text-shadow:0 1px #ffffffa6,0 0 12px #ffffff73;width:3.8rem;min-height:2.8rem;transform:translate(-50%, -50%) rotate(var(--label-angle)) translateY(-8.35rem) rotate(var(--reverse-angle));flex-direction:column;justify-content:center;align-items:center;gap:.08rem;font-size:.78rem;font-weight:700;line-height:1.05;display:flex;position:absolute;top:50%;left:50%}.wheel-label-line{text-overflow:clip;max-width:100%;display:block;overflow:hidden}.wheel-core{aspect-ratio:1;z-index:3;background:#fffbf7f0;border:12px solid #ffffffd1;border-radius:50%;width:9.7rem;position:absolute;inset:50% auto auto 50%;transform:translate(-50%,-50%);box-shadow:0 16px 36px #96475833,inset 0 1px #ffffffe6}.spin-button{color:#fffbf8;background:radial-gradient(circle at 30% 30%,#ffd9cc 0%,#da7d83 36%,#8f233d 100%);border:none;border-radius:50%;place-content:center;gap:4px;width:100%;height:100%;display:grid;box-shadow:inset 0 1px #fff6}.spin-button strong{letter-spacing:.08em;font-size:1.38rem}.spin-button span{letter-spacing:.16em;text-transform:uppercase;opacity:.82;font-size:.82rem}.spin-button:disabled{cursor:not-allowed;color:#fffcf9d6;box-shadow:none;background:linear-gradient(#edd0c9e6,#bf9a96f2)}.wheel-meta{gap:14px;display:grid}.chip-row{flex-wrap:wrap;gap:10px;display:flex}.chip{color:var(--muted-strong);background:#ffffffb8;border:1px solid #ab5a6b21;border-radius:999px;align-items:center;padding:8px 12px;font-size:.92rem;display:inline-flex}.status-banner,.wheel-hit,.helper-card,.task-card,.confirmed-note{background:#ffffffb3;border:1px solid #ab5a6b21;border-radius:22px;padding:16px 18px}.status-banner{line-height:1.7}.status-banner strong,.wheel-hit strong{color:var(--ink)}.wheel-hit strong{font-family:var(--font-display);margin-bottom:6px;font-size:1.55rem;display:block}.wheel-hit p,.helper-card p,.confirmed-note p,.footer-note p{margin:0}.helper-card{color:var(--muted-strong)}.result-panel{padding:28px}.result-shell{flex-direction:column;gap:18px;display:flex}.result-header h2,.result-header p,.editor-copy h2,.editor-copy p,.result-copy h3,.result-copy p{margin:0}.result-header h2{font-family:var(--font-display);font-size:clamp(2rem,3vw,2.6rem);line-height:.98}.result-subtitle{color:var(--muted-strong);margin-top:10px}.result-copy{gap:14px;display:grid}.result-copy h3{color:var(--accent-strong);font-size:1rem}.pill-row{flex-wrap:wrap;gap:10px;display:flex}.pill{color:var(--accent-strong);background:#f5d7cda8;border-radius:999px;padding:8px 12px;font-size:.9rem;font-weight:700;display:inline-flex}.task-card{background:linear-gradient(#fff6f0eb,#ffecddc7)}.task-card strong{color:var(--ink);margin-bottom:8px;display:block}.action-row{flex-wrap:wrap;gap:12px;display:flex}.primary-button,.secondary-button,.ghost-button,.danger-button{border-radius:999px;justify-content:center;align-items:center;min-height:48px;padding:0 18px;font-weight:700;display:inline-flex}.primary-button{color:#fffdf9;background:linear-gradient(135deg,#f0b799,#d56a79);box-shadow:0 14px 28px #d56a793d}.secondary-button{color:var(--accent-strong);background:#fff7f2eb;box-shadow:inset 0 0 0 1px #8f233d14}.ghost-button{color:var(--muted-strong);background:#fff9;box-shadow:inset 0 0 0 1px #8f233d14}.danger-button{color:var(--accent-strong);background:#a43c5514;box-shadow:inset 0 0 0 1px #8f233d14}.primary-button:disabled,.secondary-button:disabled,.ghost-button:disabled,.danger-button:disabled{cursor:not-allowed;opacity:.56;box-shadow:none;transform:none}.placeholder-copy{color:var(--muted-strong);line-height:1.7}.editor-panel{padding:30px}.editor-layout{grid-template-columns:minmax(0,1.05fr) minmax(0,.95fr);align-items:start;gap:24px;margin-top:24px;display:grid}.editor-copy p{max-width:34rem;margin-top:10px}.form-card,.list-card{background:#ffffffa3;border:1px solid #ab5a6b1f;border-radius:26px;padding:24px}.editor-form{gap:14px;display:grid}.field-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:14px;display:grid}.field{gap:8px;display:grid}.field-wide{grid-column:1/-1}.field span{color:var(--muted-strong);font-size:.92rem;font-weight:700}.field input,.field textarea{width:100%;color:var(--ink);resize:vertical;background:#ffffffdb;border:1px solid #96596529;border-radius:18px;padding:13px 14px}.field textarea{min-height:108px}.field input[type=color]{min-height:54px;padding:6px}.form-error,.form-note{margin:0;font-size:.92rem}.form-error{color:#a8334f}.form-note{color:var(--muted-strong)}.destination-list{gap:14px;display:grid}.destination-item{background:#fffbf7db;border:1px solid #ab5a6b1f;border-radius:20px;padding:18px}.destination-top{justify-content:space-between;align-items:flex-start;gap:16px;display:flex}.destination-title{align-items:flex-start;gap:12px;display:flex}.swatch{border-radius:999px;flex-shrink:0;width:16px;height:16px;margin-top:4px;box-shadow:0 0 0 4px #ffffff9e}.destination-item h3,.destination-item p{margin:0}.destination-item h3{font-size:1.12rem}.destination-tagline{color:var(--muted-strong);margin-top:4px}.destination-copy{gap:10px;margin-top:14px;display:grid}.destination-copy strong{color:var(--accent-strong)}.destination-actions{flex-wrap:wrap;gap:10px;margin-top:16px;display:flex}.empty-list{color:var(--muted-strong);background:#ffffffb3;border:1px dashed #8f233d2e;border-radius:20px;padding:20px}.footer-note{text-align:center;color:var(--muted);padding:0 8px;font-size:.92rem}@keyframes wheel-breath{0%,to{box-shadow:0 25px 70px #9c4f5f2e,inset 0 1px #ffffffd9}50%{box-shadow:0 30px 80px #9c4f5f3d,inset 0 1px #ffffffe0}}@keyframes live-spin{0%{transform:rotate(var(--rotation-offset,0deg))}to{transform:rotate(calc(var(--rotation-offset,0deg) + 360deg))}}@keyframes fade-up{0%{opacity:0;transform:translateY(24px)}to{opacity:1;transform:translateY(0)}}@media (width<=1040px){.main-grid,.editor-layout,.hero-panel,.wheel-layout{grid-template-columns:1fr}.hero-copy h1{max-width:100%}.wheel-meta{order:-1}.wheel-stage{min-height:28rem}}@media (width<=720px){.app-shell{padding-inline:14px;padding-bottom:40px}.hero-panel,.wheel-panel,.result-panel,.editor-panel{border-radius:24px;padding:20px}.panel-head,.hero-actions,.destination-top{flex-direction:column}.hero-tag-list,.field-grid{grid-template-columns:1fr}.wheel-face{width:min(100%,21.5rem)}.wheel{border-width:10px}.wheel-label{width:3.2rem;min-height:2.3rem;transform:translate(-50%, -50%) rotate(var(--label-angle)) translateY(-6.05rem) rotate(var(--reverse-angle));font-size:.66rem}.wheel-core{border-width:8px;width:7.7rem}.spin-button strong{font-size:1.1rem}.wheel-stage{min-height:23rem}.form-card,.list-card,.status-banner,.wheel-hit,.helper-card,.task-card,.confirmed-note{border-radius:18px}.destination-item{padding:16px}}
