:root{--lightningcss-light:initial;--lightningcss-dark: ;color-scheme:light;color:#142133;--ink:#142133;--ink-soft:#556476;--line:#2a486a24;--line-strong:#2a486a38;--panel:#ffffffb8;--panel-strong:#ffffffe0;--paper:#fbf7f0f5;--paper-deep:#f8f3eaf5;--bg-start:#f7f2ea;--bg-end:#eef4fb;--font-body:"Gowun Dodum", sans-serif;--font-display:"Jua", sans-serif;--accent:#6d92be;--accent-deep:#35567d;--accent-soft:#6d92be29;--rose:#e7c5b4;--gold:#c9a474;--shadow:#1422331f;--heart-size:18px;font-family:Gowun Dodum,sans-serif;font-weight:500;line-height:1.5}*{box-sizing:border-box}html,body,#root{min-height:100%}body{color:var(--ink);background:var(--bg-end);font-family:var(--font-body);margin:0}body::selection{background:color-mix(in srgb, var(--accent) 18%, transparent)}button,input,textarea,select{font:inherit}button{cursor:pointer}a{color:inherit;text-decoration:none}.studio-shell,.public-shell{isolation:isolate;background:radial-gradient(circle at 12% 14%, color-mix(in srgb, var(--rose) 42%, transparent), transparent 28%), radial-gradient(circle at 86% 10%, color-mix(in srgb, var(--accent) 28%, white 50%), transparent 26%), radial-gradient(circle at 78% 82%, color-mix(in srgb, var(--gold) 22%, white 72%), transparent 24%), linear-gradient(180deg, var(--bg-start) 0%, var(--bg-end) 100%);min-height:100vh;padding:32px;position:relative;overflow:hidden}.studio-shell>:not(.studio-ambient),.public-shell>:not(.studio-ambient){z-index:1;position:relative}.studio-shell{flex-direction:column;gap:24px;display:flex}.public-shell{place-items:center;display:grid}.studio-ambient{pointer-events:none;z-index:0;position:absolute;inset:0;overflow:hidden}.studio-ambient__orb{filter:blur(18px);opacity:.72;border-radius:999px;animation:14s ease-in-out infinite alternate ambientDrift;position:absolute}.studio-ambient__orb--one{background:radial-gradient(circle, color-mix(in srgb, var(--rose) 70%, white 20%), transparent 70%);width:260px;height:260px;top:-80px;left:-40px}.studio-ambient__orb--two{background:radial-gradient(circle, color-mix(in srgb, var(--accent) 40%, white 48%), transparent 70%);width:320px;height:320px;animation-duration:18s;top:18%;right:-90px}.studio-ambient__orb--three{background:radial-gradient(circle, color-mix(in srgb, var(--gold) 24%, white 72%), transparent 72%);width:280px;height:280px;animation-duration:16s;bottom:-120px;left:24%}.studio-ambient--public .studio-ambient__orb{opacity:.58}.hero-banner{border:1px solid color-mix(in srgb, var(--accent) 16%, transparent);-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px);background:linear-gradient(135deg,#fffcf7eb,#f2f8ffeb),#ffffff85;border-radius:34px;grid-template-columns:minmax(0,1.2fr) minmax(280px,360px);gap:28px;padding:34px 36px;display:grid;position:relative;overflow:hidden;box-shadow:0 26px 60px #1a334914,inset 0 1px #ffffffb3}.hero-banner:before{content:"";background:linear-gradient(90deg, transparent, #ffffff57, transparent), radial-gradient(circle at 82% 30%, color-mix(in srgb, var(--accent) 14%, transparent), transparent 34%);pointer-events:none;background-size:200% 100%,auto;animation:10s linear infinite bannerSweep;position:absolute;inset:0}.hero-banner__copy,.hero-banner__meta{z-index:1;position:relative}.hero-banner__eyebrow,.dashboard-panel__eyebrow,.expired-card__eyebrow,.profile-card__eyebrow{color:var(--accent-deep);text-transform:uppercase;letter-spacing:.22em;margin:0 0 10px;font-size:.72rem;font-weight:800}.hero-banner h1,.dashboard-panel h2,.expired-card h1{line-height:1.03;font-family:var(--font-display);margin:0;font-weight:400}.hero-banner h1{letter-spacing:-.04em;font-size:clamp(2.3rem,4.5vw,4rem)}.hero-banner__body{max-width:760px;color:var(--ink-soft);margin:14px 0 0;font-size:1rem}.hero-banner__chips{flex-wrap:wrap;gap:10px;margin-top:20px;display:flex}.hero-banner__chips span,.hero-banner__meta>span{border:1px solid color-mix(in srgb, var(--accent) 16%, transparent);color:var(--accent-deep);background:#ffffffbd;border-radius:999px;align-items:center;gap:8px;padding:10px 14px;display:inline-flex;box-shadow:inset 0 1px #ffffffa6}.hero-banner__chips span:nth-child(2){animation:6s ease-in-out infinite chipLift}.hero-banner__chips span:nth-child(3){animation:7.4s ease-in-out infinite chipLift}.hero-banner__meta{flex-direction:column;align-items:stretch;gap:14px;display:flex}.hero-banner__spotlight{border:1px solid color-mix(in srgb, var(--accent) 18%, transparent);background:linear-gradient(155deg,#ffffffeb,#f5faffd1),#ffffffbd;border-radius:26px;padding:18px 18px 20px;box-shadow:0 16px 32px #1c314914}.hero-banner__spotlight-label{color:var(--ink-soft);letter-spacing:.12em;text-transform:uppercase;font-size:.78rem;font-weight:700;display:inline-block}.hero-banner__spotlight strong{color:var(--accent-deep);margin-top:8px;font-size:clamp(2rem,4vw,3rem);line-height:1;display:block}.hero-banner__spotlight p{color:var(--ink-soft);margin:10px 0 0;font-size:.92rem}.studio-grid{grid-template-columns:minmax(300px,360px) minmax(0,1fr) minmax(320px,380px);align-items:start;gap:22px;display:grid}.studio-side{flex-direction:column;gap:18px;display:flex}.dashboard-panel{border:1px solid color-mix(in srgb, var(--accent) 16%, transparent);-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px);background:linear-gradient(#ffffffd1,#f9fbffc2),#ffffffc2;border-radius:30px;position:relative;overflow:hidden;box-shadow:0 24px 54px #1b2b3d14,inset 0 1px #ffffffb8}.dashboard-panel:before{content:"";pointer-events:none;background:linear-gradient(#ffffff42,#0000 30%);position:absolute;inset:0}.dashboard-panel--list,.dashboard-panel--editor,.dashboard-panel--share,.dashboard-panel--theme{padding:24px}.dashboard-panel__header{justify-content:space-between;align-items:flex-start;gap:16px;margin-bottom:18px;display:flex}.dashboard-panel__header h2{font-size:1.25rem}.dashboard-panel__blurb{color:var(--ink-soft);margin:10px 0 0;font-size:.94rem}.dashboard-counter{background:linear-gradient(135deg, color-mix(in srgb, var(--accent) 16%, transparent), color-mix(in srgb, var(--rose) 18%, transparent));min-width:64px;color:var(--accent-deep);border-radius:999px;justify-content:center;align-items:center;padding:9px 14px;font-weight:800;display:inline-flex}.search-box{border:1px solid color-mix(in srgb, var(--accent) 16%, transparent);background:#ffffffe6;border-radius:18px;align-items:center;gap:10px;padding:14px 16px;display:flex;box-shadow:inset 0 1px #ffffffd1}.search-box input{width:100%;color:var(--ink);background:0 0;border:0;outline:none}.profile-list{flex-direction:column;gap:12px;max-height:calc(100vh - 278px);margin-top:18px;padding-right:6px;display:flex;overflow:auto}.profile-list-item{text-align:left;background:linear-gradient(#fffffffa,#f7faffe0),#ffffffe0;border:1px solid #0000;border-radius:22px;width:100%;padding:16px 16px 14px;transition:transform .18s,border-color .18s,box-shadow .18s,background .18s;box-shadow:0 10px 24px #1b2b3d0a}.profile-list-item:hover,.profile-list-item.is-active{background:linear-gradient(#fffffffc,#f1f8ffeb),#fffffff0;border-color:#35567d38;box-shadow:0 16px 34px #1d30471a}.profile-list-item__topline{justify-content:space-between;align-items:center;gap:12px;display:flex}.profile-list-item__identity{flex-wrap:wrap;align-items:center;gap:10px;display:inline-flex}.profile-list-item__topline strong{font-size:1rem}.profile-list-item__topline span{color:var(--accent-deep);font-size:.85rem;font-weight:800}.profile-list-item p{color:var(--ink-soft);margin:8px 0 0;font-size:.94rem}.profile-list-item--female{background:linear-gradient(#fffffffa,#fff5f9e6),#ffffffe6}.profile-list-item--female:hover,.profile-list-item--female.is-active{background:linear-gradient(#fffffffc,#ffeff5f0),#fffffff2}.profile-gender-chip{letter-spacing:.02em;border-radius:999px;justify-content:center;align-items:center;min-height:24px;padding:0 10px;font-size:.72rem;font-weight:800;display:inline-flex}.profile-gender-chip--male{color:#4f78a6;background:#a2c2e82e}.profile-gender-chip--female{color:#b06f8b;background:#e7b6c738}.profile-list-item__progress{background:color-mix(in srgb, var(--accent) 9%, transparent);border-radius:999px;height:8px;margin-top:14px;position:relative;overflow:hidden}.profile-list-item__progress span{border-radius:inherit;background:linear-gradient(90deg, color-mix(in srgb, var(--rose) 90%, white 10%), color-mix(in srgb, var(--gold) 38%, var(--rose) 62%), var(--accent));height:100%;display:block}.profile-list-item__tags{flex-wrap:wrap;gap:8px;margin-top:12px;display:flex}.profile-list-item__tags span{color:var(--accent-deep);background:#eff6fff2;border-radius:999px;align-items:center;gap:6px;padding:7px 10px;font-size:.8rem;font-weight:700;display:inline-flex}.studio-main{justify-content:center;display:flex}.studio-main__stack{flex-direction:column;gap:18px;width:min(100%,900px);display:flex}.public-stack{flex-direction:column;gap:20px;width:min(100%,920px);display:flex}.profile-card-shell{width:100%;position:relative}.profile-card__badge-strip{z-index:4;pointer-events:none;flex-direction:column;align-items:flex-start;gap:clamp(4px,.55vw,8px);display:inline-flex;position:absolute;top:clamp(18px,2.3vw,26px);left:clamp(14px,1.8vw,22px)}.profile-card__badge{filter:drop-shadow(0 14px 24px #82682333);pointer-events:none;width:clamp(41px,4.32vw,55px)}.profile-card__badge--draggable{pointer-events:auto;cursor:grab;touch-action:none;z-index:5;position:relative}.profile-card__badge--draggable:active{cursor:grabbing}.profile-card__badge img{pointer-events:none;-webkit-user-select:none;user-select:none;-webkit-user-drag:none;width:100%;height:auto;display:block}.profile-card{border:1px solid color-mix(in srgb, var(--accent) 14%, transparent);background:linear-gradient(180deg, #ffffffe0, #f8f3eaf5), var(--paper);border-radius:38px;width:100%;padding:44px 48px 34px;position:relative;overflow:hidden;box-shadow:0 30px 78px #18293f24,inset 0 1px #fffc}.profile-card__grain{opacity:.16;background-image:radial-gradient(circle at 20% 20%, color-mix(in srgb, var(--rose) 18%, transparent) 0 2px, transparent 3px), radial-gradient(circle at 70% 36%, color-mix(in srgb, var(--accent) 14%, transparent) 0 2px, transparent 3px), linear-gradient(135deg, #ffffff14, transparent 40%);pointer-events:none;background-size:120px 120px,140px 140px,auto;position:absolute;inset:0;-webkit-mask-image:radial-gradient(circle,#000,#0000 92%);mask-image:radial-gradient(circle,#000,#0000 92%)}.profile-card__wash,.profile-card__glow{filter:blur(18px);pointer-events:none;border-radius:999px;position:absolute}.profile-card__wash{display:none}.profile-card__glow--one{background:radial-gradient(circle, color-mix(in srgb, var(--rose) 28%, white 16%), transparent 70%);width:220px;height:220px;animation:9s ease-in-out infinite alternate glowDrift;top:18%;left:-80px}.profile-card__glow--two{display:none}.profile-card__ornaments{pointer-events:none;position:absolute;inset:0}.profile-card__ornament{color:#e5d7eb;opacity:.84;position:absolute}.profile-card__ornament--petal{color:#ffdbe8;opacity:.96;filter:drop-shadow(0 8px 16px #ffcde057)}.profile-card__ornament--sparkle{color:#ece9ce;opacity:.82}.profile-card__petal-shape{background:linear-gradient(#ffe6ef 0%,#ffd7e6 46%,#f7c8da 100%);border-radius:68% 32% 66% 34%/34% 66% 36% 64%;display:block;position:relative;transform:rotate(22deg);box-shadow:inset 0 1px #ffffffb3,inset -4px -6px 8px #f5bad04d}.profile-card__petal-shape:before{content:"";filter:blur(1px);background:#ffffff47;border-radius:999px;width:42%;height:34%;position:absolute;top:8%;left:18%}.profile-card__petal-shape:after{content:"";transform-origin:top;background:linear-gradient(#ebc6d1b8,#0000);width:2px;height:20%;position:absolute;bottom:-12%;left:48%;transform:rotate(-8deg)}.profile-card__header{text-align:center;flex-direction:column;align-items:center;display:flex;position:relative}.profile-card__recipient{border:1px solid color-mix(in srgb, var(--rose) 18%, var(--accent) 10%);color:color-mix(in srgb, var(--rose) 58%, var(--accent-deep) 42%);background:#fffc;border-radius:999px;align-items:center;gap:8px;margin-bottom:8px;padding:8px 14px;font-size:.82rem;font-weight:800;display:inline-flex}.profile-card__title-row{align-items:center;gap:10px;display:inline-flex}.profile-card__title{font-family:var(--font-display);letter-spacing:-.05em;margin:0;font-size:clamp(4rem,7vw,6.7rem);font-weight:400}.profile-card__title-mark{color:#e8a8bc;filter:drop-shadow(0 4px 10px #a6838e47);transform-origin:50% 60%;flex:none;justify-content:center;align-items:center;width:36px;height:36px;animation:4.3s ease-in-out infinite softBeat;display:inline-flex}.profile-card__photos{grid-template-columns:repeat(2,minmax(0,1fr));gap:26px;margin-top:30px;display:grid}.profile-card__photo-frame{aspect-ratio:.79;border:1px solid color-mix(in srgb, var(--accent) 20%, white 34%);background:linear-gradient(180deg, color-mix(in srgb, var(--accent) 18%, white 68%), color-mix(in srgb, var(--rose) 16%, white 72%));border-radius:30px;position:relative;overflow:hidden;box-shadow:0 20px 40px #5b687e1f,inset 0 1px #fff9}.profile-card__photo-frame:after{content:"";pointer-events:none;border:1px solid #ffffff6b;border-radius:22px;position:absolute;inset:12px}.profile-card__photo-sheen{z-index:1;pointer-events:none;background:linear-gradient(120deg,#0000 18%,#ffffff47 42%,#0000 66%);animation:7.5s ease-in-out infinite sheenSweep;position:absolute;inset:0;transform:translate(-130%)}.profile-card__photo{object-fit:cover;width:100%;height:100%;display:block}.profile-card__photo-fallback{width:100%;height:100%;color:var(--ink-soft);background:linear-gradient(135deg, color-mix(in srgb, var(--accent) 12%, transparent), #fff9), #ffffffbd;place-items:center;display:grid}.profile-card__summary-wrap{flex-direction:column;align-items:center;gap:12px;margin-top:30px;display:flex}.profile-card__summary{text-align:center;letter-spacing:-.035em;margin:0;font-size:clamp(1.5rem,2vw,2.15rem);font-weight:800}.profile-card__summary-flourish{background:radial-gradient(circle at center, color-mix(in srgb, var(--gold) 82%, transparent) 0 16%, transparent 17%), linear-gradient(90deg, transparent, color-mix(in srgb, var(--rose) 78%, transparent), transparent);border-radius:999px;width:128px;height:14px}.profile-card__keyword{border:1px solid color-mix(in srgb, var(--accent) 18%, white 30%);border-radius:18px;grid-template-columns:204px 1fr;width:min(100%,640px);margin:28px auto 0;display:grid;position:relative;overflow:hidden;box-shadow:0 18px 30px #5c698014}.profile-card__keyword:after{content:"";pointer-events:none;background:linear-gradient(120deg,#0000 30%,#ffffff38,#0000 70%);animation:6.8s ease-in-out infinite sheenSweep;position:absolute;inset:0;transform:translate(-140%)}.profile-card--male{--point:#9fbfe4;--point-glow:#9fbfe438}.profile-card--female{--point:#f0a8bc;--point-glow:#f0a8bc38}.profile-card__keyword-label{background:var(--point,#9fbfe4);color:#fff;justify-content:center;align-items:center;gap:8px;min-height:66px;font-size:clamp(1.05rem,1.5vw,1.32rem);font-weight:800;display:inline-flex}.profile-card__keyword-value{background:#ffffffe6;place-items:center;min-height:66px;padding:16px 20px;font-size:clamp(1.18rem,1.8vw,1.62rem);font-weight:800;display:grid}.profile-card__facts{grid-template-columns:repeat(2,minmax(0,1fr));gap:40px;margin-top:34px;display:grid}.profile-card__facts-column{flex-direction:column;gap:14px;display:flex}.profile-card__facts-full{margin-top:16px}.fact-row{border-bottom:1px dashed color-mix(in srgb, var(--accent) 10%, transparent);grid-template-columns:minmax(132px,182px) 1fr;align-items:center;gap:18px;padding:10px 0;transition:background-color .16s;display:grid}.fact-row:hover{background:#ffffff38}.fact-row__label,.fact-row__value{min-height:40px}.fact-row__label{align-items:center;gap:10px;font-size:clamp(.98rem,1.45vw,1.34rem);font-weight:800;display:inline-flex}.fact-row__dot{background:var(--point,#9fbfe4);width:18px;height:18px;box-shadow:0 0 0 4px var(--point-glow,#9fbfe438);border-radius:5px;flex:none;animation:2.8s ease-in-out infinite dotPulse}.fact-row__value{color:#1e2d41;word-break:keep-all;border-left:1px solid #1c385a1f;align-items:center;padding-left:20px;font-size:clamp(.98rem,1.42vw,1.3rem);font-weight:700;display:flex}.profile-card__footer{text-align:center;color:#99adc4;border-top:1px solid color-mix(in srgb, var(--accent) 12%, transparent);margin-top:42px;padding-top:18px;font-size:.92rem;font-weight:500}.profile-card.is-public{max-width:920px;margin:0 auto}.emotional-sheet{background:linear-gradient(#f7efe5f5,#f3ebe0f5),#f3ebe0;border:1px solid #d0c6b46b;border-radius:34px;width:100%;padding:38px 24px 28px;position:relative;overflow:hidden;box-shadow:0 28px 64px #3e312814,inset 0 1px #ffffffb3}.emotional-sheet__texture{opacity:.22;pointer-events:none;background-image:radial-gradient(circle at 16% 12%,#ffffff5c 0 1px,#0000 2px),radial-gradient(circle at 72% 24%,#d6bdab3d 0 1px,#0000 2px),radial-gradient(circle at 38% 76%,#ffffff47 0 1px,#0000 2px);background-size:22px 22px,30px 30px,34px 34px;position:absolute;inset:0}.emotional-sheet__ornament{opacity:.12;filter:blur(2px);pointer-events:none;background:radial-gradient(circle,#e9b5bf52,#0000 58%),url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='180' height='180' viewBox='0 0 180 180'%3E%3Cg fill='none' stroke='%23d9aeb8' stroke-width='3' stroke-opacity='.6'%3E%3Cpath d='M51 66c0-12 10-22 22-22 9 0 16 4 20 11 4-7 12-11 20-11 12 0 22 10 22 22 0 24-42 53-42 53S51 90 51 66Z'/%3E%3C/g%3E%3C/svg%3E") 50%/160px 160px no-repeat;border-radius:999px;width:220px;height:220px;position:absolute}.emotional-sheet__ornament--left{top:86px;left:-48px}.emotional-sheet__ornament--right{bottom:42px;right:-42px}.emotional-sheet__paper-plane{z-index:3;cursor:grab;touch-action:none;-webkit-user-select:none;user-select:none;filter:drop-shadow(0 6px 18px #3c5a962e);position:absolute;top:clamp(14px,2.2vw,28px);right:clamp(18px,3vw,40px)}.emotional-sheet__paper-plane:active{cursor:grabbing}.emotional-sheet__paper-plane-img{pointer-events:none;-webkit-user-drag:none;width:clamp(108px,12vw,168px);height:auto;display:block}.emotional-sheet__paper-plane-hint{text-align:center;color:#646e8c8c;letter-spacing:.02em;pointer-events:none;-webkit-user-select:none;user-select:none;margin-top:4px;font-size:.6rem;display:block}.emotional-sheet__header{z-index:1;text-align:center;margin-bottom:26px;position:relative}.emotional-sheet__eyebrow{color:#8f7f70;letter-spacing:.22em;text-transform:uppercase;margin:0 0 10px;font-size:.72rem;font-weight:700}.emotional-sheet__header h2{font-family:var(--font-display);color:#2b241e;letter-spacing:-.04em;margin:0;font-size:clamp(2.6rem,5vw,3.8rem);font-weight:400}.emotional-sheet__subcopy{color:#6f6256;max-width:540px;margin:10px auto 0;font-size:.95rem}.emotional-sheet__grid{z-index:1;grid-template-columns:repeat(2,minmax(0,1fr));gap:18px;display:grid;position:relative}.emotion-card{flex-direction:column;gap:10px;display:flex}.emotion-card__question{align-items:flex-start;gap:10px;min-height:46px;display:flex}.emotion-card__emoji{background:linear-gradient(135deg,#759dd42e,#dfc5cd57);border-radius:999px;flex:none;place-items:center;width:28px;height:28px;margin-top:1px;font-size:.95rem;display:inline-grid;box-shadow:inset 0 1px #ffffffb3}.emotion-card__question h3{color:#2d2b29;word-break:keep-all;margin:0;font-size:1rem;font-weight:800;line-height:1.5}.emotion-card__answer{background:#ffffffeb;border:1px solid #e3dacfeb;border-radius:0;min-height:132px;padding:18px 18px 16px;box-shadow:inset 0 1px #ffffffd1}.emotion-card__answer p{color:#302d2a;white-space:pre-wrap;word-break:keep-all;margin:0;font-size:.98rem;line-height:1.75}.editor-grid{gap:14px;display:grid}.editor-field{flex-direction:column;gap:8px;display:flex}.editor-field span{color:var(--ink-soft);font-size:.88rem;font-weight:700}.editor-field input,.editor-field textarea{width:100%;color:var(--ink);resize:vertical;background:#ffffffeb;border:1px solid #35567d24;border-radius:16px;outline:none;padding:14px 15px;transition:border-color .14s,box-shadow .14s,transform .14s}.editor-field input:focus,.editor-field textarea:focus{border-color:#35567d6b;transform:translateY(-1px);box-shadow:0 0 0 4px #6d92be1f}.share-controls{grid-template-columns:1.2fr .8fr;gap:14px;display:grid}.share-preview{border:1px solid color-mix(in srgb, var(--accent) 18%, white 30%);background:linear-gradient(135deg, #fafcfff5, color-mix(in srgb, var(--rose) 12%, white 88%)), #ffffffd6;border-radius:20px;margin-top:18px;padding:16px;position:relative;overflow:hidden}.share-preview:before{content:"";background:radial-gradient(circle, color-mix(in srgb, var(--rose) 18%, transparent), transparent 68%);border-radius:999px;width:220px;height:220px;position:absolute;inset:auto -20% -140px auto}.share-preview__label{color:var(--accent-deep);align-items:center;gap:8px;font-size:.85rem;font-weight:800;display:inline-flex}.share-preview code{z-index:1;color:#38506e;white-space:pre-wrap;word-break:break-all;margin-top:10px;font-size:.82rem;line-height:1.6;display:block;position:relative}.share-actions{flex-wrap:wrap;gap:12px;margin-top:16px;display:flex}.share-note{background:color-mix(in srgb, var(--rose) 14%, white 86%);color:color-mix(in srgb, var(--rose) 52%, var(--accent-deep) 48%);border-radius:18px;align-items:flex-start;gap:10px;margin-top:16px;padding:14px 16px;display:flex}.share-note p{margin:0;font-size:.9rem}.primary-button,.secondary-button,.ghost-button{border:1px solid #0000;border-radius:16px;justify-content:center;align-items:center;gap:8px;min-height:48px;padding:0 16px;font-weight:800;transition:transform .14s,box-shadow .14s,border-color .14s,background .14s;display:inline-flex}.primary-button{color:#fff;background:linear-gradient(135deg, color-mix(in srgb, var(--rose) 76%, white 10%), var(--accent));box-shadow:0 12px 24px color-mix(in srgb, var(--accent) 22%, transparent)}.secondary-button{color:var(--ink);border-color:color-mix(in srgb, var(--accent) 18%, white 30%);background:#ffffffd1;box-shadow:0 10px 20px #4d5d740d}.ghost-button{color:var(--accent-deep);border-color:color-mix(in srgb, var(--accent) 16%, white 34%);background:#ffffff57}.primary-button:hover,.secondary-button:hover,.ghost-button:hover{transform:translateY(-2px)}.primary-button:hover{box-shadow:0 16px 28px color-mix(in srgb, var(--accent) 28%, transparent)}.loading-state,.empty-state,.expired-card,.error-banner{-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);background:#ffffffd6;border:1px solid #35567d24;border-radius:26px;box-shadow:0 20px 52px #18293f14}.loading-state{text-align:center;place-items:center;gap:16px;min-height:260px;display:grid}.loading-state__stage{width:92px;height:92px;position:relative}.loading-state__orb,.loading-state__echo{border-radius:999px;position:absolute;inset:0}.loading-state__orb{background:radial-gradient(circle at 30% 30%,#ffffffbd,#0000 32%),linear-gradient(135deg,#7ca9e2,#f1cfc0);box-shadow:0 18px 36px #466c993d}.loading-state__echo{filter:blur(6px);background:radial-gradient(circle,#6d92be2e,#0000 68%)}.empty-state{min-height:180px;color:var(--ink-soft);text-align:center;place-items:center;padding:26px;display:grid}.expired-card{text-align:center;max-width:760px;padding:42px}.expired-card h1{font-size:clamp(2rem,4vw,3.2rem)}.expired-card p{max-width:560px;color:var(--ink-soft);margin:14px auto 0}.error-banner{color:#7b1e2f;background:#fff2f4eb;padding:16px 18px}.theme-preset-grid{grid-template-columns:repeat(3,minmax(0,1fr));gap:10px;margin-top:8px;display:grid}.theme-preset-button{border:1px solid color-mix(in srgb, var(--accent) 16%, white 30%);min-height:44px;color:var(--accent-deep);background:#ffffffd1;border-radius:14px;justify-content:center;align-items:center;gap:8px;padding:0 12px;font-weight:700;transition:transform .14s,box-shadow .14s,border-color .14s;display:inline-flex}.theme-preset-button:hover,.theme-preset-button.is-active{border-color:color-mix(in srgb, var(--accent) 28%, white 16%);box-shadow:0 10px 18px color-mix(in srgb, var(--accent) 10%, transparent);transform:translateY(-1px)}.theme-preset-button.is-active{background:linear-gradient(135deg, color-mix(in srgb, var(--rose) 24%, white 76%), color-mix(in srgb, var(--accent) 16%, white 84%))}.theme-color-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:14px;margin-top:18px;display:grid}.theme-color-field code{color:var(--accent-deep);font-size:.84rem;font-weight:700}.theme-color-input{border:1px solid color-mix(in srgb, var(--accent) 14%, white 36%);background:#ffffffe6;border-radius:16px;align-items:center;gap:12px;padding:10px 12px;display:flex}.theme-color-input input[type=color]{background:0 0;border:0;width:44px;height:36px;padding:0}.theme-slider-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:14px;margin-top:18px;display:grid}.theme-range{width:100%;accent-color:var(--accent)}.theme-ornament-controls{grid-template-columns:1fr auto;align-items:end;gap:14px;margin-top:18px;display:grid}.theme-select{border:1px solid color-mix(in srgb, var(--accent) 14%, white 34%);width:100%;min-height:48px;color:var(--ink);cursor:pointer;background:#ffffffeb;border-radius:16px;outline:none;padding:0 14px}.theme-toggle{border:1px solid color-mix(in srgb, var(--accent) 14%, white 34%);min-height:48px;color:var(--ink);background:#ffffffdb;border-radius:16px;align-items:center;gap:10px;padding:0 14px;font-weight:700;display:inline-flex}.theme-toggle input{width:16px;height:16px;accent-color:var(--accent)}.theme-panel__actions{flex-direction:column;flex-shrink:0;align-items:flex-end;gap:8px;display:flex}.theme-panel__save-btn{justify-content:center;gap:6px;min-width:82px;transition:background .25s,color .25s}.theme-panel__save-btn--saved{color:#fff!important;background:#4a9e6e!important;border-color:#4a9e6e!important}.theme-panel__divider{background:color-mix(in srgb, var(--accent) 18%, transparent);width:100%;height:1px;margin:14px 0 6px}@keyframes ambientDrift{0%{transform:translate(0,0)scale(1)}50%{transform:translate(18px,-24px)scale(1.08)}to{transform:translate(-16px,14px)scale(.96)}}@keyframes bannerSweep{0%{background-position:160% 0,50%}to{background-position:-60% 0,50%}}@keyframes chipLift{0%,to{transform:translateY(0)}50%{transform:translateY(-3px)}}@keyframes glowDrift{0%{transform:translate(0,0)scale(1)}50%{transform:translate(18px,-18px)scale(1.08)}to{transform:translate(-10px,12px)scale(.94)}}@keyframes sheenSweep{0%{transform:translate(-140%)}45%,to{transform:translate(150%)}}@keyframes dotPulse{0%,to{box-shadow:0 0 0 4px color-mix(in srgb, var(--rose) 16%, transparent)}50%{box-shadow:0 0 0 7px color-mix(in srgb, var(--rose) 8%, transparent)}}@keyframes softBeat{0%,to{transform:translateY(0)scale(1)rotate(0)}14%{transform:translateY(-2px)scale(1.16)rotate(-5deg)}26%{transform:translateY(0)scale(.95)rotate(2deg)}40%{transform:translateY(-2px)scale(1.12)rotate(-4deg)}56%{transform:translateY(0)scale(1)rotate(0)}74%{transform:translateY(-1px)scale(1.06)rotate(1deg)}}@media (width<=1280px){.studio-grid{grid-template-columns:320px minmax(0,1fr)}.studio-side{grid-column:1/-1}}@media (width<=980px){.studio-shell,.public-shell{padding:20px}.hero-banner{grid-template-columns:1fr;padding:28px 24px}.studio-grid,.share-controls,.theme-color-grid,.theme-slider-grid,.theme-preset-grid,.theme-ornament-controls,.emotional-sheet__grid,.profile-card__photos,.profile-card__facts,.profile-card__keyword{grid-template-columns:1fr}.profile-card{padding:30px 22px 24px}.profile-card__badge-strip{gap:6px;top:18px;left:12px}.profile-card__title{font-size:clamp(3.3rem,18vw,5.2rem)}.profile-card__summary{font-size:1.36rem}.fact-row{grid-template-columns:1fr;gap:8px}.fact-row__value{border-left:0;padding-left:28px}.profile-list{max-height:none}.emotional-sheet{padding:30px 18px 22px}.emotion-card__answer{min-height:112px}}@media (width<=680px){.hero-banner__chips,.share-actions{flex-direction:column}.hero-banner__chips span,.hero-banner__meta>span,.theme-preset-button,.primary-button,.secondary-button,.ghost-button{width:100%}.dashboard-panel__header{flex-direction:column}.profile-card__title-row{gap:10px}.profile-card__title-mark{width:18px;height:18px}}@media (prefers-reduced-motion:reduce){*,:before,:after{scroll-behavior:auto!important;transition:none!important;animation:none!important}}
