:root{--color-bg-primary: #fdfbf7;--color-bg-secondary: #f4f0e6;--color-text-primary: #2d2a26;--color-text-secondary: #6e6b66;--color-block-gratitude: #81c784;--color-block-awe: #fff59d;--color-block-challenge: #aed581;--color-block-memory: #ba68c8;--color-block-activity: #4dd0e1;--color-depth-gratitude: #4caf50;--color-depth-awe: #fbc02d;--color-depth-challenge: #7cb342;--color-depth-memory: #8e24aa;--color-depth-activity: #00acc1;--spacing-xs: .5rem;--spacing-sm: 1rem;--spacing-md: 1.5rem;--spacing-lg: 2rem;--spacing-xl: 3rem;--font-family-base: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;--font-family-display: "Outfit", var(--font-family-base);--shadow-sm: 0 2px 8px rgba(0, 0, 0, .04);--shadow-md: 0 8px 24px rgba(0, 0, 0, .08);--shadow-lg: 0 16px 48px rgba(0, 0, 0, .12);--radius-sm: 8px;--radius-md: 16px;--radius-lg: 24px;--radius-pill: 9999px;--transition-fast: .15s ease-out;--transition-normal: .3s cubic-bezier(.2, .8, .2, 1);--transition-bounce: .5s cubic-bezier(.34, 1.56, .64, 1)}*{box-sizing:border-box;margin:0;padding:0}body{font-family:var(--font-family-base);background-color:var(--color-bg-primary);color:var(--color-text-primary);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;line-height:1.5;min-height:100vh;display:flex;flex-direction:column}h1,h2,h3,h4,h5,h6{font-family:var(--font-family-display);font-weight:600;line-height:1.2}button{cursor:pointer;border:none;background:none;font-family:inherit;transition:all var(--transition-fast)}a{color:inherit;text-decoration:none}.text-display-lg{font-size:3rem;letter-spacing:-.02em}.text-display-md{font-size:2.25rem;letter-spacing:-.02em}.text-body-lg{font-size:1.125rem}.text-body-md{font-size:1rem}.text-body-sm{font-size:.875rem}.text-muted{color:var(--color-text-secondary)}.container{max-width:1200px;margin:0 auto;padding:0 var(--spacing-sm)}.flex-center{display:flex;align-items:center;justify-content:center}.flex-between{display:flex;align-items:center;justify-content:space-between}.btn-primary{background:var(--color-text-primary);color:var(--color-bg-primary);padding:.75rem 1.5rem;border-radius:var(--radius-pill);font-weight:500;box-shadow:var(--shadow-sm)}.btn-primary:hover{transform:translateY(-2px);box-shadow:var(--shadow-md)}.btn-secondary{background:var(--color-bg-secondary);color:var(--color-text-primary);padding:.75rem 1.5rem;border-radius:var(--radius-pill);font-weight:500}.btn-secondary:hover{background:#e8e3d5}#root{display:flex;flex-direction:column;min-height:100vh}.drawer-overlay{position:absolute;inset:0;background:#0006;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:1000;display:flex;align-items:flex-end;justify-content:center}.drawer-content{background:var(--color-bg-primary);width:100%;max-width:500px;border-top-left-radius:var(--radius-lg);border-top-right-radius:var(--radius-lg);padding:var(--spacing-lg);box-shadow:0 -10px 40px #0000001a;transform:translateY(0);animation:slideUp var(--transition-bounce)}@keyframes slideUp{0%{transform:translateY(100%)}to{transform:translateY(0)}}.drawer-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-md)}.drawer-header h2{font-size:var(--text-display-sm);color:var(--color-text-primary);margin:0}.close-btn{font-size:1.5rem;color:var(--color-text-secondary);border-radius:var(--radius-pill);width:40px;height:40px;display:flex;align-items:center;justify-content:center}.close-btn:hover{background:var(--color-bg-secondary)}.type-gratitude{--type-bg: var(--color-block-gratitude);--type-color: #276980}.type-awe{--type-bg: var(--color-block-awe);--type-color: #9d5a00}.type-challenge{--type-bg: var(--color-block-challenge);--type-color: #3b7431}.type-memory{--type-bg: var(--color-block-memory);--type-color: #5d348a}.type-activity{--type-bg: var(--color-block-activity);--type-color: #ad2b3e}.type-selector{display:flex;flex-wrap:wrap;gap:var(--spacing-xs);margin-bottom:var(--spacing-md)}.type-btn{padding:.5rem 1rem;border-radius:var(--radius-pill);font-size:var(--text-body-sm);font-weight:500;border:2px solid transparent;background:var(--color-bg-secondary);color:var(--color-text-secondary)}.type-btn.active{background:var(--type-bg);color:var(--type-color);border-color:#0000000d}.prompt-box{background:#fffc;padding:var(--spacing-sm);border-radius:var(--radius-sm);font-style:italic;color:var(--color-text-secondary);margin-bottom:var(--spacing-md);border-left:4px solid var(--type-bg, var(--color-bg-secondary))}.block-textarea{width:100%;height:120px;padding:var(--spacing-sm);border-radius:var(--radius-sm);border:1px solid rgba(0,0,0,.1);font-family:inherit;font-size:var(--text-body-md);resize:none;background:#fff;transition:all var(--transition-fast)}.block-textarea:focus{outline:none;border-color:var(--color-text-primary);box-shadow:0 0 0 3px #0000000d}.drawer-footer{margin-top:var(--spacing-md);display:flex;justify-content:flex-end}.place-btn{width:100%}.place-btn:disabled{opacity:.5;cursor:not-allowed}.modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:2000;animation:fadeIn var(--transition-fast) forwards}.modal-content.castle-modal{background:#fff;width:90%;max-width:400px;border-radius:16px;box-shadow:0 20px 40px #0003;display:flex;flex-direction:column;overflow:hidden;animation:slideUp var(--transition-bounce) forwards}.modal-header{padding:20px 24px;border-bottom:2px dashed #eee;display:flex;align-items:center;justify-content:space-between}.modal-header h2{margin:0;color:var(--color-primary);font-size:1.5rem}.modal-body{padding:24px;background:#fafafa}.stat-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px}.stat-card{background:#fff;padding:16px;border-radius:12px;text-align:center;box-shadow:0 4px 10px #00000008;border:1px solid #eaeaea}.stat-value{display:block;font-size:1.6rem;font-weight:700;color:#333;margin-bottom:4px}.stat-label{font-size:.8rem;font-weight:600;text-transform:uppercase;color:#888;letter-spacing:.5px}.type-breakdown{display:flex;flex-direction:column;gap:8px}.type-row{display:flex;justify-content:space-between;padding:10px 16px;border-radius:8px;background:#fff;border-left:4px solid var(--block-color);box-shadow:0 2px 5px #00000005}.type-row.type-gratitude{--block-color: var(--color-block-gratitude)}.type-row.type-awe{--block-color: var(--color-block-awe)}.type-row.type-challenge{--block-color: var(--color-block-challenge)}.type-row.type-memory{--block-color: var(--color-block-memory)}.type-row.type-activity{--block-color: var(--color-block-activity)}.type-row.type-question{--block-color: var(--color-block-question)}.type-name{font-weight:600;color:#444}.type-count{font-weight:700;color:#888}#root{max-width:1280px;margin:0 auto;text-align:center;position:relative;overflow:hidden;height:100vh}.app-container{display:flex;flex-direction:column;height:100vh;z-index:1;position:relative;background-size:cover;background-position:center bottom;background-repeat:no-repeat;transition:background-image .5s ease-in-out,background-position 1s cubic-bezier(.34,1.56,.64,1)}.theme-lush_fields{background-image:url(../lush_fields_bg.png);background-size:cover;background-repeat:no-repeat}.app-container.theme-lush_fields .bg-blob{display:none}.app-header{padding:var(--spacing-lg);display:flex;flex-direction:column;align-items:center;gap:var(--spacing-xs);z-index:2}.app-header h1{font-size:3rem;font-weight:900;text-transform:uppercase;letter-spacing:2px;line-height:1.1;margin:0;background-image:linear-gradient(135deg,#1b5e20,#4caf50,#81c784);background-size:200%;-webkit-background-clip:text;background-clip:text;color:transparent;-webkit-text-stroke:1px rgba(27,94,32,.4);filter:drop-shadow(0px 4px 4px rgba(0,0,0,.15))}.main-content{flex:1;position:relative;display:flex;justify-content:center;align-items:center;z-index:2;overflow:hidden;perspective:2000px}.bg-blob{position:absolute;border-radius:50%;filter:blur(80px);z-index:0;opacity:.6}.blob-1{width:400px;height:400px;background:var(--color-block-memory);top:-100px;left:-100px}.blob-2{width:500px;height:500px;background:var(--color-block-gratitude);bottom:-150px;right:-100px}.page-container{min-height:100vh;padding:var(--spacing-md);position:relative;z-index:2}.card{background:#ffffffb3;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);padding:var(--spacing-xl);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);border:1px solid rgba(255,255,255,.5);max-width:400px;width:100%;text-align:center}.card .title{color:var(--color-block-awe);margin-bottom:var(--spacing-xs);filter:brightness(.85)}.card .subtitle{color:var(--color-text-secondary);margin-bottom:var(--spacing-lg)}.actions{display:flex;flex-direction:column;gap:var(--spacing-md)}.action-form{display:flex;flex-direction:column;gap:var(--spacing-sm)}.action-form h3{font-size:var(--text-body-md);color:var(--color-text-primary);opacity:.8}.input-field{padding:.75rem 1rem;border-radius:var(--radius-sm);border:1px solid rgba(0,0,0,.1);font-family:var(--font-family-base);font-size:var(--text-body-md);background:#ffffffe6;transition:all var(--transition-fast)}.input-field:focus{outline:none;border-color:var(--color-text-primary);box-shadow:0 0 0 3px #0000000d}.divider{display:flex;align-items:center;text-align:center;color:var(--color-text-secondary);font-size:var(--text-body-sm)}.divider:before,.divider:after{content:"";flex:1;border-bottom:1px solid rgba(0,0,0,.1)}.divider span{padding:0 var(--spacing-sm)}.turn-banner{background:#fffc;padding:var(--spacing-xs) var(--spacing-md);border-radius:var(--radius-pill);font-size:var(--text-body-sm);font-weight:500;box-shadow:var(--shadow-sm);border:1px solid rgba(0,0,0,.05);transition:all var(--transition-normal)}.turn-banner.my-turn{background:var(--color-block-awe);border-color:#ffcc8080;color:var(--color-text-primary)}.floating-action-btn{position:fixed;bottom:var(--spacing-xl);left:50%;transform:translate(-50%);z-index:100;padding:1rem 2rem;font-size:var(--text-body-lg);box-shadow:var(--shadow-lg)}.floating-action-btn:hover{transform:translate(-50%,-2px);box-shadow:0 12px 28px #00000026}.block-detail-toast{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);z-index:200;background:var(--color-bg-primary);border-radius:var(--radius-md);padding:var(--spacing-lg);width:90%;max-width:400px;box-shadow:0 20px 40px #00000026;border:1px solid rgba(0,0,0,.05);animation:popIn var(--transition-bounce)}@keyframes popIn{0%{opacity:0;transform:translate(-50%,-40%) scale(.9)}to{opacity:1;transform:translate(-50%,-50%) scale(1)}}.toast-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-md)}.type-badge{padding:4px 12px;border-radius:var(--radius-pill);font-size:var(--text-body-xs);font-weight:700;text-transform:uppercase;letter-spacing:.05em;background:var(--color-bg-secondary)}.type-badge.type-gratitude{background:var(--color-block-gratitude);color:#276980}.type-badge.type-awe{background:var(--color-block-awe);color:#9d5a00}.type-badge.type-challenge{background:var(--color-block-challenge);color:#3b7431}.type-badge.type-memory{background:var(--color-block-memory);color:#5d348a}.type-badge.type-activity{background:var(--color-block-activity);color:#ad2b3e}.toast-author{font-size:var(--text-body-sm);color:var(--color-text-secondary);font-weight:500}.toast-text{font-size:var(--text-body-lg);color:var(--color-text-primary);line-height:1.5;margin-bottom:var(--spacing-md)}.toast-date{display:block;font-size:var(--text-body-xs);color:var(--color-text-secondary);text-align:right}
