.canvas-container{position:relative;margin:0 auto;background:white;border-radius:12px;box-shadow:0 4px 20px #00000026;overflow:hidden}.edit-canvas{display:block;width:100%;height:100%;touch-action:none;cursor:crosshair;background:white}.canvas-placeholder{position:absolute;top:0;left:0;right:0;bottom:0;display:flex;flex-direction:column;align-items:center;justify-content:center;color:#aaa;pointer-events:none}.placeholder-icon{font-size:48px;margin-bottom:16px;opacity:.5}.canvas-placeholder p{font-size:16px;margin:0}@media (max-width: 480px){.canvas-container{border-radius:8px;margin:0 auto}}.font-selector-wrapper{display:flex;align-items:center;gap:8px}.font-selector-label{font-size:14px;color:#555;white-space:nowrap}.font-selector-container{position:relative;flex:1;min-width:120px}.font-selector{width:100%;padding:10px 32px 10px 12px;font-size:14px;border:1px solid #ddd;border-radius:8px;background:white;color:#333;cursor:pointer;-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%23666' d='M6 8L1 3h10z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center;transition:border-color .2s,box-shadow .2s}.font-selector:focus{outline:none;border-color:#4caf50;box-shadow:0 0 0 3px #4caf501a}.font-selector:disabled{background-color:#f5f5f5;cursor:wait}.font-loading-indicator{position:absolute;top:50%;right:40px;transform:translateY(-50%);display:flex;align-items:center;gap:6px;font-size:12px;color:#4caf50}.loading-spinner{width:14px;height:14px;border:2px solid #e0e0e0;border-top-color:#4caf50;border-radius:50%;animation:spin .8s linear infinite}.loading-text{display:none}@keyframes spin{to{transform:rotate(360deg)}}@media (max-width: 480px){.font-selector{padding:12px;font-size:16px}.font-selector-label{font-size:13px}}.text-controls-panel{background:white;border-radius:12px;padding:16px;margin-bottom:12px;box-shadow:0 2px 8px #00000014;border:2px solid transparent;transition:border-color .2s,box-shadow .2s}.text-controls-panel.selected{border-color:#4caf50;box-shadow:0 4px 12px #4caf5026}.panel-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px;padding-bottom:12px;border-bottom:1px solid #eee}.panel-title{font-size:16px;font-weight:600;color:#333}.panel-actions{display:flex;gap:8px}.copy-btn{padding:6px 12px;background:#2196F3;color:#fff;border:none;border-radius:6px;font-size:13px;cursor:pointer;transition:background .2s}.copy-btn:hover{background:#1976D2}.copy-btn:active{transform:scale(.95)}.delete-btn{padding:6px 12px;background:#ff5252;color:#fff;border:none;border-radius:6px;font-size:13px;cursor:pointer;transition:background .2s}.delete-btn:hover{background:#ff1744}.delete-btn:active{transform:scale(.95)}.control-row{display:flex;align-items:center;margin-bottom:12px;gap:12px}.control-row:last-child{margin-bottom:0}.control-label{min-width:40px;font-size:14px;color:#666}.text-input{flex:1;padding:10px 12px;border:1px solid #ddd;border-radius:8px;font-size:15px;transition:border-color .2s,box-shadow .2s}.text-input:focus{outline:none;border-color:#4caf50;box-shadow:0 0 0 3px #4caf501a}.direction-buttons{display:flex;gap:8px}.direction-btn{padding:8px 16px;border:1px solid #ddd;border-radius:6px;background:white;font-size:14px;cursor:pointer;transition:all .2s}.direction-btn.active{background:#4CAF50;color:#fff;border-color:#4caf50}.direction-btn:not(.active):hover{background:#f5f5f5}.size-control{display:flex;align-items:center;gap:8px}.size-btn{width:36px;height:36px;display:flex;align-items:center;justify-content:center;border:1px solid #ddd;border-radius:8px;background:white;font-size:18px;cursor:pointer;transition:all .2s;color:#333}.size-btn:hover{background:#f5f5f5}.size-btn:active{background:#e0e0e0;transform:scale(.95)}.size-input{width:60px;padding:8px;border:1px solid #ddd;border-radius:8px;font-size:15px;text-align:center}.size-input:focus{outline:none;border-color:#4caf50}.color-picker-wrapper{position:relative}.color-trigger{width:44px;height:44px;border:2px solid #ddd;border-radius:8px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:border-color .2s}.color-trigger:hover{border-color:#4caf50}.color-indicator{font-size:18px;font-weight:700}.color-picker-dropdown{position:absolute;top:50px;left:0;z-index:100;background:white;border-radius:12px;box-shadow:0 4px 20px #00000026;padding:12px;min-width:220px}.color-preset-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:6px;margin-bottom:10px}.color-preset-btn{width:36px;height:36px;border-radius:6px;border:2px solid transparent;cursor:pointer;transition:all .2s}.color-preset-btn:hover{transform:scale(1.1)}.color-preset-btn.active{border-color:#4caf50;box-shadow:0 0 0 2px #4caf504d}.custom-color-row{display:flex;align-items:center;gap:10px;padding-top:10px;border-top:1px solid #eee;font-size:13px;color:#666}.custom-color-row input[type=color]{width:40px;height:30px;border:1px solid #ddd;border-radius:4px;cursor:pointer;padding:0}.color-value{font-size:13px;color:#888;font-family:monospace}.font-row{flex-direction:column;align-items:stretch}.font-row .font-selector-wrapper{width:100%}@media (max-width: 480px){.text-controls-panel{padding:14px;margin-bottom:10px}.control-row{flex-wrap:wrap}.control-label{min-width:45px;font-size:13px}.text-input,.size-input{font-size:16px}.direction-btn{flex:1;padding:10px 12px}}.toolbar-wrapper{width:100%;max-width:400px;margin:0 auto}.toolbar-toggle{width:100%;padding:12px 20px;background:linear-gradient(135deg,#4CAF50 0%,#45a049 100%);color:#fff;border:none;border-radius:10px;font-size:15px;font-weight:500;cursor:pointer;transition:all .2s;box-shadow:0 2px 8px #4caf504d}.toolbar-toggle:hover{transform:translateY(-1px);box-shadow:0 4px 12px #4caf5066}.toolbar-toggle:active{transform:translateY(0)}.toolbar-container{background:#f8f9fa;border-radius:16px;margin-top:12px;padding:16px;box-shadow:0 4px 20px #00000014}.quick-actions{display:flex;gap:10px;margin-bottom:16px}.action-btn{flex:1;display:flex;flex-direction:column;align-items:center;gap:4px;padding:12px 8px;background:white;border:1px solid #e0e0e0;border-radius:12px;cursor:pointer;transition:all .2s}.action-btn:hover{background:#f5f5f5;border-color:#ccc}.action-btn:active{transform:scale(.98)}.upload-btn{cursor:pointer}.clear-btn:hover{border-color:#ff5252;color:#ff5252}.btn-icon{font-size:20px}.btn-text{font-size:12px;color:#666}.tab-bar{display:flex;background:#e8e8e8;border-radius:10px;padding:4px;margin-bottom:16px}.tab-btn{flex:1;padding:10px 16px;border:none;background:transparent;border-radius:8px;font-size:14px;font-weight:500;color:#666;cursor:pointer;transition:all .2s}.tab-btn.active{background:white;color:#333;box-shadow:0 2px 4px #0000001a}.tab-content{max-height:50vh;overflow-y:auto;padding-right:4px}.tab-content::-webkit-scrollbar{width:6px}.tab-content::-webkit-scrollbar-track{background:transparent}.tab-content::-webkit-scrollbar-thumb{background:#ccc;border-radius:3px}.empty-state{text-align:center;padding:40px 20px;color:#999}.empty-state p{margin:0}.empty-state .hint{font-size:13px;margin-top:8px}.export-panel{background:white;border-radius:12px;padding:16px}.export-option{margin-bottom:16px}.export-option>label{display:block;font-size:14px;font-weight:500;color:#333;margin-bottom:10px}.format-buttons{display:flex;gap:10px}.format-btn{flex:1;padding:12px 20px;border:2px solid #e0e0e0;border-radius:8px;background:white;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s}.format-btn.active{border-color:#4caf50;background:rgba(76,175,80,.05);color:#4caf50}.format-btn:not(.active):hover{border-color:#ccc}.checkbox-label{display:flex;align-items:center;gap:10px;cursor:pointer}.checkbox-label input[type=checkbox]{width:20px;height:20px;cursor:pointer;accent-color:#4CAF50}.checkbox-text{font-size:14px;color:#555}.export-btn{width:100%;padding:14px 20px;background:linear-gradient(135deg,#2196F3 0%,#1976D2 100%);color:#fff;border:none;border-radius:10px;font-size:16px;font-weight:500;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:8px;transition:all .2s;box-shadow:0 2px 8px #2196f34d}.export-btn:hover{transform:translateY(-1px);box-shadow:0 4px 12px #2196f366}.export-btn:active{transform:translateY(0)}.export-info{text-align:center;margin-bottom:12px;color:#666}.export-info small{font-size:13px}.ratio-buttons{display:flex;flex-wrap:wrap;gap:8px}.ratio-btn{padding:8px 12px;border:2px solid #e0e0e0;border-radius:8px;background:white;font-size:12px;font-weight:500;cursor:pointer;transition:all .2s;white-space:nowrap}.ratio-btn.active{border-color:#4caf50;background:rgba(76,175,80,.1);color:#4caf50}.ratio-btn:not(.active):hover{border-color:#ccc;background:#f9f9f9}.color-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:6px;margin-bottom:12px;max-height:200px;overflow-y:auto;padding:4px}.color-btn{width:40px;height:40px;border-radius:8px;border:2px solid transparent;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center;position:relative}.color-btn:hover{transform:scale(1.1)}.color-btn.active{border-color:#4caf50;box-shadow:0 0 0 2px #4caf504d}.color-btn .check-mark{color:#4caf50;font-size:16px;font-weight:700;text-shadow:0 0 2px white,0 0 2px white}.color-name{font-size:13px;color:#666;display:block}@media (max-width: 480px){.toolbar-wrapper{max-width:100%;padding:0 12px}.toolbar-container{padding:12px;border-radius:12px}.quick-actions{gap:8px}.action-btn{padding:10px 6px}.btn-icon{font-size:18px}.btn-text{font-size:11px}.tab-content{max-height:40vh}}*,*:before,*:after{margin:0;padding:0;box-sizing:border-box}html{font-size:16px;-webkit-text-size-adjust:100%}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);min-height:100vh;min-height:100dvh;overflow-x:hidden;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.app{display:flex;flex-direction:column;min-height:100vh;min-height:100dvh;padding:16px;gap:16px}.app-header{text-align:center;padding:8px 0}.app-title{font-size:24px;font-weight:600;color:#fff;text-shadow:0 2px 4px rgba(0,0,0,.2);margin:0}.font-error{margin-top:8px;padding:8px 16px;background:rgba(255,82,82,.9);color:#fff;border-radius:20px;font-size:13px;display:inline-block}.app-main{flex:0 0 auto}.app-footer{flex:1 1 auto;display:flex;flex-direction:column;padding-bottom:env(safe-area-inset-bottom,16px)}@media (max-width: 480px){body{background:linear-gradient(180deg,#667eea 0%,#764ba2 100%)}.app{padding:12px 0;gap:12px}.app-header{padding:4px 0}.app-title{font-size:20px}}@media (hover: none) and (pointer: coarse){button,input,select,label{min-height:44px}}@supports (-webkit-touch-callout: none){body{height:-webkit-fill-available}.app{min-height:-webkit-fill-available}}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:rgba(255,255,255,.3);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:rgba(255,255,255,.5)}::selection{background:rgba(76,175,80,.3)}input:focus,select:focus,button:focus{outline:none}*{touch-action:manipulation}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.app-main,.app-footer{animation:fadeIn .3s ease-out}:root{--color-primary: #4CAF50;--color-primary-dark: #388E3C;--color-primary-light: rgba(76, 175, 80, .1);--color-secondary: #2196F3;--color-secondary-dark: #1976D2;--color-danger: #ff5252;--color-danger-dark: #ff1744;--color-text: #333333;--color-text-secondary: #666666;--color-text-muted: #999999;--color-bg: #f8f9fa;--color-bg-white: #ffffff;--color-border: #e0e0e0;--color-border-light: #eeeeee;--spacing-xs: 4px;--spacing-sm: 8px;--spacing-md: 12px;--spacing-lg: 16px;--spacing-xl: 24px;--radius-sm: 6px;--radius-md: 8px;--radius-lg: 12px;--radius-xl: 16px;--shadow-sm: 0 1px 3px rgba(0, 0, 0, .08);--shadow-md: 0 4px 12px rgba(0, 0, 0, .1);--shadow-lg: 0 8px 24px rgba(0, 0, 0, .12);--transition-fast: .15s ease;--transition-normal: .2s ease;--transition-slow: .3s ease;--font-size-xs: 12px;--font-size-sm: 13px;--font-size-md: 14px;--font-size-lg: 16px;--font-size-xl: 18px;--font-size-2xl: 24px}
