*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,'Segoe UI','PingFang SC','Hiragino Sans GB','Microsoft YaHei',sans-serif;background:linear-gradient(135deg,#667eea 0,#764ba2 100%);min-height:100vh;color:#333}.container{max-width:1200px;margin:0 auto;padding:20px}header{text-align:center;padding:40px 20px;color:#fff}header h1{font-size:2.5rem;margin-bottom:10px;text-shadow:2px 2px 4px rgba(0,0,0,.2)}header p{font-size:1.1rem;opacity:.9}.upload-section{background:#fff;border-radius:16px;padding:40px;box-shadow:0 10px 40px rgba(0,0,0,.1);margin-bottom:30px}.upload-area{border:3px dashed #ddd;border-radius:12px;padding:60px 40px;text-align:center;cursor:pointer;transition:all .3s ease;background:#fafafa}.upload-area:hover{border-color:#667eea;background:#f0f4ff}.upload-area.dragover{border-color:#667eea;background:#e8edff;transform:scale(1.02)}.upload-icon{font-size:4rem;margin-bottom:20px}.upload-area p{font-size:1.2rem;color:#555;margin-bottom:10px}.upload-hint{font-size:.9rem!important;color:#999!important}.canvas-section{background:#fff;border-radius:16px;padding:30px;box-shadow:0 10px 40px rgba(0,0,0,.1)}.toolbar{display:flex;gap:12px;margin-bottom:20px;flex-wrap:wrap;justify-content:center}.btn{padding:10px 20px;border:2px solid #e0e0e0;background:#fff;border-radius:8px;cursor:pointer;font-size:14px;transition:all .3s ease;color:#555}.btn:hover{border-color:#667eea;color:#667eea}.btn.active{background:#667eea;border-color:#667eea;color:#fff}.btn-primary{background:#48bb78;border-color:#48bb78;color:#fff}.btn-primary:hover{background:#38a169;border-color:#38a169}.canvas-container{display:flex;justify-content:center;margin-bottom:30px;overflow:auto;max-height:70vh;background:#f5f5f5;border-radius:12px;padding:20px}#mainCanvas{max-width:100%;box-shadow:0 4px 20px rgba(0,0,0,.1);border-radius:8px}.legend{border-top:1px solid #eee;padding-top:30px}.legend h3{text-align:center;margin-bottom:20px;color:#555;font-size:1.2rem}.bagua-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:15px;max-width:600px;margin:0 auto}.bagua-item{display:flex;flex-direction:column;align-items:center;padding:15px 10px;border-radius:10px;background:#f8f9fa;transition:all .3s ease;cursor:pointer}.bagua-item:hover{transform:translateY(-3px);box-shadow:0 5px 15px rgba(0,0,0,.1)}.bagua-item.center{background:linear-gradient(135deg,#667eea20,#764ba220);border:2px solid #667eea}.bagua-name{font-size:1.5rem;font-weight:700;color:#333;margin-bottom:5px}.bagua-direction{font-size:.85rem;color:#666;margin-bottom:3px}.bagua-element{font-size:.75rem;padding:2px 8px;border-radius:10px;color:#fff;font-weight:500}.bagua-item[data-direction="东"] .bagua-element,.bagua-item[data-direction="东南"] .bagua-element{background:#228b22}.bagua-item[data-direction="南"] .bagua-element{background:#ff4500}.bagua-item[data-direction="东北"] .bagua-element,.bagua-item[data-direction="中"] .bagua-element,.bagua-item[data-direction="西南"] .bagua-element{background:#8b4513}.bagua-item[data-direction="西"] .bagua-element,.bagua-item[data-direction="西北"] .bagua-element{background:gold;color:#333}.bagua-item[data-direction="北"] .bagua-element{background:#1e90ff}@media (max-width:768px){header h1{font-size:1.8rem}.upload-section{padding:20px}.upload-area{padding:40px 20px}.canvas-section{padding:20px}.bagua-grid{grid-template-columns:repeat(3,1fr);gap:10px}.bagua-item{padding:10px 5px}.bagua-name{font-size:1.2rem}}.canvas-container::-webkit-scrollbar{width:8px;height:8px}.canvas-container::-webkit-scrollbar-track{background:#f1f1f1;border-radius:4px}.canvas-container::-webkit-scrollbar-thumb{background:#c1c1c1;border-radius:4px}.canvas-container::-webkit-scrollbar-thumb:hover{background:#a1a1a1}.modal{display:none;position:fixed;top:0;left:0;width:100%;height:100%;background:rgba(0,0,0,.6);z-index:1000;justify-content:center;align-items:center;backdrop-filter:blur(4px)}.modal-content{background:#fff;border-radius:16px;width:90%;max-width:500px;max-height:80vh;overflow-y:auto;position:relative;animation:modalSlideIn .3s ease;box-shadow:0 20px 60px rgba(0,0,0,.3)}@keyframes modalSlideIn{from{opacity:0;transform:translateY(-50px)}to{opacity:1;transform:translateY(0)}}.modal-close{position:absolute;top:15px;right:20px;font-size:28px;cursor:pointer;color:#999;transition:color .3s;z-index:10}.modal-close:hover{color:#333}.modal-header{padding:25px 25px 15px;border-bottom:1px solid #eee;display:flex;align-items:center;gap:15px}.modal-header h2{font-size:1.8rem;color:#333;margin:0}.element-badge{padding:5px 15px;border-radius:20px;color:#fff;font-size:.9rem;font-weight:700}.modal-body{padding:25px}.modal-info{display:grid;grid-template-columns:repeat(3,1fr);gap:15px;margin-bottom:20px;padding:15px;background:#f8f9fa;border-radius:10px}.modal-info p{margin:0;font-size:.95rem;text-align:center}.modal-info strong{display:block;color:#888;font-size:.8rem;margin-bottom:5px;text-transform:uppercase}.modal-description{margin-bottom:25px;padding:20px;background:linear-gradient(135deg,#667eea10,#764ba210);border-radius:10px;border-left:4px solid #667eea}.modal-description p{margin:0;font-size:1rem;line-height:1.6;color:#555}.modal-suggestions h4{margin-bottom:15px;color:#333;font-size:1.1rem}.modal-suggestions ul{list-style:none;padding:0}.modal-suggestions li{padding:10px 0;padding-left:25px;position:relative;border-bottom:1px solid #f0f0f0;color:#555;line-height:1.5}.modal-suggestions li:last-child{border-bottom:none}.modal-suggestions li::before{content:'✓';position:absolute;left:0;color:#48bb78;font-weight:700}.canvas-container{position:relative}.canvas-container::after{content:'💡 点击预览效果图';position:absolute;bottom:10px;left:50%;transform:translateX(-50%);background:rgba(0,0,0,.7);color:#fff;padding:8px 16px;border-radius:20px;font-size:.85rem;opacity:0;transition:opacity .3s;pointer-events:none}.canvas-section:hover .canvas-container::after{opacity:1}#mainCanvas{cursor:pointer}.canvas-section.fullscreen-mode{position:fixed;top:0;left:0;width:100vw;height:100vh;z-index:9999;border-radius:0;display:flex;flex-direction:column;padding:20px}.canvas-section.fullscreen-mode .toolbar{flex-shrink:0;margin-bottom:15px}.canvas-section.fullscreen-mode .canvas-container{flex:1;max-height:calc(100vh - 200px);margin-bottom:15px}.canvas-section.fullscreen-mode .legend{flex-shrink:0;border-top:1px solid #eee;padding-top:15px}.canvas-section.fullscreen-mode .legend h3{display:none}.canvas-section.fullscreen-mode .bagua-grid{grid-template-columns:repeat(9,1fr);gap:8px}.canvas-section.fullscreen-mode .bagua-item{padding:8px 4px}.canvas-section.fullscreen-mode .bagua-name{font-size:1rem}.canvas-section.fullscreen-mode .bagua-direction,.canvas-section.fullscreen-mode .bagua-element{font-size:.7rem}.grid-adjust-panel{background:linear-gradient(135deg,#f8f9fa,#e9ecef);border-radius:12px;padding:20px;margin-bottom:20px;border:1px solid #dee2e6;animation:slideDown .3s ease}@keyframes slideDown{from{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.adjust-row{display:flex;align-items:center;margin-bottom:15px;gap:15px}.adjust-row:last-of-type{margin-bottom:20px}.adjust-row label{width:100px;font-weight:500;color:#555;font-size:.95rem}.adjust-row input[type=range]{flex:1;height:8px;-webkit-appearance:none;appearance:none;background:#ddd;border-radius:4px;outline:0}.adjust-row input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:20px;height:20px;background:#667eea;border-radius:50%;cursor:pointer;transition:background .3s}.adjust-row input[type=range]::-webkit-slider-thumb:hover{background:#5a6fd6}.adjust-row span{width:50px;text-align:right;font-weight:600;color:#667eea;font-size:.9rem}.adjust-actions{display:flex;gap:10px;justify-content:flex-end}.adjust-actions .btn{padding:8px 20px;font-size:.9rem}.fullscreen-hint{position:fixed;top:20px;right:20px;background:rgba(0,0,0,.7);color:#fff;padding:10px 20px;border-radius:8px;font-size:.9rem;z-index:10000;animation:fadeInOut 3s ease forwards}@keyframes fadeInOut{0%,100%{opacity:0}10%,90%{opacity:1}}.gesture-hint{position:fixed;bottom:100px;left:50%;transform:translateX(-50%);background:rgba(0,0,0,.8);color:#fff;padding:12px 24px;border-radius:25px;font-size:.9rem;z-index:1000;display:none;align-items:center;gap:10px;white-space:nowrap}.gesture-hint.show{display:flex;animation:fadeInOut 4s ease forwards}.gesture-hint .icon{font-size:1.2rem}@media (max-width:768px){.canvas-container{touch-action:none;-webkit-touch-callout:none;-webkit-user-select:none;user-select:none}#mainCanvas{touch-action:none}.grid-adjust-panel{padding:15px}.adjust-row{gap:10px}.adjust-row label{width:80px;font-size:.85rem}.adjust-row input[type=range]{height:6px}.adjust-row input[type=range]::-webkit-slider-thumb{width:18px;height:18px}.adjust-row span{width:40px;font-size:.85rem}.toolbar{gap:8px}.btn{padding:8px 12px;font-size:.85rem}}@media (pointer:coarse){#mainCanvas{cursor:pointer}}.image-preview-modal{display:none;position:fixed;top:0;left:0;width:100%;height:100%;background:rgba(0,0,0,.95);z-index:10000;justify-content:center;align-items:center;animation:fadeIn .3s ease}@keyframes fadeIn{from{opacity:0}to{opacity:1}}.image-preview-content{position:relative;max-width:95%;max-height:95%;display:flex;flex-direction:column;align-items:center}.image-preview-content img{max-width:100%;max-height:85vh;object-fit:contain;border-radius:8px;box-shadow:0 10px 40px rgba(0,0,0,.5)}.preview-close{position:absolute;top:-40px;right:0;font-size:36px;color:#fff;cursor:pointer;z-index:10001;width:40px;height:40px;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:background .3s}.preview-close:hover{background:rgba(255,255,255,.2)}.preview-hint{margin-top:15px;color:rgba(255,255,255,.7);font-size:.9rem;text-align:center}.bagua-item{cursor:pointer;position:relative}.bagua-item::after{content:'👆 点击查看';position:absolute;bottom:-20px;left:50%;transform:translateX(-50%);font-size:.7rem;color:#667eea;opacity:0;transition:opacity .3s;white-space:nowrap}.bagua-item:hover::after{opacity:1}@media (max-width:768px){.bagua-item::after{display:none}}