.app{min-height:100vh;height:100vh;display:flex;flex-direction:column;background:var(--tt-bg-page);position:relative;overflow:hidden;touch-action:pan-y}.main{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:flex-start;padding:0 var(--tt-space-8) 0;overflow:hidden;position:relative}.ticket-stage{width:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;flex:1;position:relative}.template-dots{display:flex;gap:var(--tt-space-3);margin-bottom:var(--tt-space-6);justify-content:center}.template-dot{width:var(--tt-space-3);height:var(--tt-space-3);border-radius:var(--tt-radius-full);background:var(--tt-white-a15);transition:all var(--tt-duration-slow) var(--tt-ease-default)}.template-dot.active{width:20px;border-radius:var(--tt-radius-sm)}.ticket-wrapper{width:100%;max-width:100%;height:100%;min-height:0;display:flex;justify-content:center;align-items:center;box-sizing:border-box}.rotate-hint{display:flex;align-items:center;gap:var(--tt-space-3);margin-top:var(--tt-space-4);padding:var(--tt-space-3) var(--tt-space-7);border-radius:var(--tt-radius-pill);border:none;background:var(--tt-white-a6);color:var(--tt-text-secondary);font-size:var(--tt-text-sm);font-weight:500;font-family:inherit;cursor:pointer;transition:all var(--tt-duration-normal) var(--tt-ease-default);-webkit-backdrop-filter:blur(var(--tt-blur-md));backdrop-filter:blur(var(--tt-blur-md))}.rotate-hint:active{background:var(--tt-white-a10);transform:scale(.97)}.ticket-hint{font-size:var(--tt-text-xs);color:var(--tt-text-secondary);margin-top:var(--tt-space-4);letter-spacing:.02em;opacity:.7;animation:fadeHint 4s var(--tt-ease-default) forwards}@keyframes fadeHint{0%,70%{opacity:.7}to{opacity:0}}@media (orientation: landscape){.header{padding:var(--tt-space-4) var(--tt-space-8) var(--tt-space-2)}.header h1{font-size:var(--tt-text-3xl)}.header p{font-size:var(--tt-text-xl)}.main{padding:0 var(--tt-space-4)}.template-dots{margin-bottom:var(--tt-space-3)}.rotate-hint,.ticket-hint{margin-top:var(--tt-space-2)}.ticket-wrapper{height:calc(100% - 32px);padding:var(--tt-space-8) 0}}.header{padding:var(--tt-space-8) var(--tt-space-10) var(--tt-space-4);flex-shrink:0;z-index:var(--tt-z-header)}.header-content{display:flex;align-items:baseline;gap:var(--tt-space-4)}.header h1{font-size:var(--tt-text-5xl);font-weight:700;letter-spacing:-.02em;color:var(--tt-text-primary);line-height:1.2}.header p{font-size:var(--tt-text-xl);font-weight:400;color:var(--tt-text-secondary);letter-spacing:-.01em}.ticket-scaler{position:relative;flex-shrink:0;overflow:visible}.ticket{--ticket-ref-width: 800px;--ticket-ref-height: 325px;--divider-width: 32px;width:var(--ticket-ref-width);height:var(--ticket-ref-height);background:var(--bg-color);border-radius:var(--border-radius);overflow:hidden;position:absolute;top:0;left:0;box-shadow:var(--tt-shadow-sm),var(--tt-shadow-md),var(--tt-shadow-inset-light),0 16px 48px -12px var(--shadow-color);display:flex;flex-direction:row;transition:box-shadow var(--tt-duration-slow) var(--tt-ease-default);touch-action:none;user-select:none;-webkit-user-select:none}.ticket:active{opacity:.98;box-shadow:0 1px 2px var(--tt-black-a20),0 4px 16px var(--tt-black-a30),var(--tt-shadow-inset-light),0 8px 24px -8px var(--shadow-color)}.ticket-left{width:calc(var(--ticket-ref-width) * (1 - var(--right-width)) - var(--divider-width));height:100%;position:relative;overflow:hidden;flex-shrink:0}.ticket-image-area{width:100%;height:100%;position:relative;overflow:hidden}.ticket-image{width:100%;height:100%;object-fit:cover;transform-origin:center center;display:block;pointer-events:none}.ticket-image-placeholder{width:100%;height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--tt-white-a10),var(--tt-white-a3));color:var(--placeholder-color);gap:var(--tt-space-4);cursor:pointer;transition:background var(--tt-duration-normal) var(--tt-ease-default)}.ticket-image-placeholder svg{opacity:.3}.ticket-divider{width:var(--divider-width);height:100%;position:relative;flex-shrink:0;display:flex;flex-direction:column;align-items:center;justify-content:center;background:var(--bg-color);z-index:2}.divider-notch{width:28px;height:28px;border-radius:var(--tt-radius-full);background:var(--tt-bg-page);position:absolute;left:50%;transform:translate(-50%);z-index:3;box-shadow:0 0 0 1px var(--tt-black-a8) inset}.divider-notch.top{top:-14px}.divider-notch.bottom{bottom:-14px}.divider-line{width:0;height:calc(100% - 28px);border-left:1.5px dashed var(--divider-color)}.ticket-divider.divider-style-straight .divider-notch,.ticket-divider.divider-style-dashed .divider-notch{display:none}.ticket-divider.divider-style-straight .divider-line{border-left-style:solid}.ticket-divider.divider-style-dashed .divider-line{border-left-style:dashed}.ticket-divider.divider-style-straight .divider-line,.ticket-divider.divider-style-dashed .divider-line{height:100%}.ticket-right{width:calc(var(--ticket-ref-width) * var(--right-width));height:100%;padding:14px var(--tt-space-6) var(--tt-space-6) var(--tt-space-3);display:flex;flex-direction:column;color:var(--text-color);flex-shrink:0;position:relative}.ticket-info{display:flex;flex-direction:column;height:100%}.ticket-header{text-align:center;margin-bottom:var(--tt-space-4);padding-bottom:var(--tt-space-3);border-bottom:1px solid var(--divider-color);cursor:pointer;transition:opacity var(--tt-duration-normal) var(--tt-ease-default);position:relative}.ticket-header:active{opacity:.7}.ticket-subtitle{font-size:var(--subtitle-size);letter-spacing:var(--subtitle-letter-spacing);opacity:.45;display:block;margin-bottom:var(--tt-space-1);font-weight:600;color:var(--text-color);text-transform:uppercase}.ticket-title{font-size:var(--title-size);font-weight:700;line-height:1.2;color:var(--text-color);letter-spacing:-.01em;word-break:break-all}.ticket-details{display:flex;flex-direction:column;gap:var(--tt-space-1);margin-bottom:var(--tt-space-2);flex:1;justify-content:center}.detail-row{display:flex;justify-content:space-between;align-items:center;padding:var(--tt-space-1) 0;border-bottom:.5px solid var(--divider-color);cursor:pointer;transition:opacity var(--tt-duration-normal) var(--tt-ease-default)}.detail-row:active{opacity:.7}.detail-label{font-size:var(--subtitle-size);opacity:.35;font-weight:600;color:var(--text-color);text-transform:uppercase;letter-spacing:1px}.detail-value{font-size:var(--detail-size);font-weight:600;color:var(--text-color);text-align:right;word-break:break-all}.detail-value.highlight{color:var(--accent);font-size:var(--price-size);font-weight:700}.ticket-footer{margin-top:auto;text-align:center;padding-top:var(--tt-space-2);cursor:pointer;transition:opacity var(--tt-duration-normal) var(--tt-ease-default)}.ticket-footer:active{opacity:.7}.ticket-extra{font-size:var(--subtitle-size);opacity:.35;display:block;margin-bottom:var(--tt-space-2);letter-spacing:.5px;color:var(--text-color)}.ticket-barcode{padding:var(--tt-space-1) 0 0}.barcode-lines{display:flex;justify-content:center;align-items:flex-end;gap:var(--tt-space-1);height:24px;margin-bottom:var(--tt-space-1);opacity:.45}.barcode-line{width:1px;background:var(--main-color);border-radius:.5px}.barcode-text{font-size:var(--subtitle-size);opacity:.3;letter-spacing:1.5px;font-family:var(--tt-font-mono);color:var(--text-color)}.landscape-view{position:fixed;top:0;right:0;bottom:0;left:0;background:var(--tt-bg-page);z-index:var(--tt-z-landscape);display:flex;align-items:center;justify-content:center;animation:fadeIn var(--tt-duration-slow) var(--tt-ease-default)}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.landscape-ticket-wrapper{padding:var(--tt-space-8);width:100%;height:100%;display:flex;justify-content:center;align-items:center;transition:transform var(--tt-duration-slow) var(--tt-ease-default)}.landscape-view.portrait-device .landscape-ticket-wrapper{transform:rotate(90deg);width:100vh;height:100vw;max-width:none}.landscape-close{position:absolute;top:var(--tt-space-8);right:var(--tt-space-8);width:var(--tt-space-11);height:var(--tt-space-11);border-radius:var(--tt-radius-full);background:var(--tt-white-a10);border:none;color:var(--tt-text-primary);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all var(--tt-duration-normal) var(--tt-ease-default);-webkit-backdrop-filter:blur(var(--tt-blur-md));backdrop-filter:blur(var(--tt-blur-md))}.landscape-close:active{background:var(--tt-white-a20);transform:scale(.95)}@media (min-width: 768px){.landscape-ticket-wrapper{padding:var(--tt-space-10)}}.bottom-actions{display:flex;justify-content:center;gap:var(--tt-space-6);padding:var(--tt-space-8) var(--tt-space-10) var(--tt-space-12);flex-shrink:0;z-index:var(--tt-z-header)}.action-btn{-webkit-user-select:none;user-select:none;display:flex;align-items:center;justify-content:center;gap:var(--tt-space-3);padding:var(--tt-space-6) var(--tt-space-9);border-radius:var(--tt-radius-pill);border:none;background:var(--tt-white-a8);color:var(--tt-text-primary);font-size:var(--tt-text-md);font-weight:600;font-family:inherit;cursor:pointer;transition:all var(--tt-duration-normal) var(--tt-ease-default);-webkit-backdrop-filter:blur(var(--tt-blur-lg));backdrop-filter:blur(var(--tt-blur-lg));letter-spacing:-.01em}.action-btn:active{transform:scale(.95);background:var(--tt-white-a12)}.action-btn.primary{background:var(--tt-bg-primary);color:var(--tt-text-inverse);box-shadow:var(--tt-shadow-primary)}.action-btn.primary:active{background:var(--tt-bg-primary-pressed);transform:scale(.95)}.action-btn svg{opacity:.9}@media (orientation: landscape) and (max-height: 500px){.bottom-actions{padding:var(--tt-space-4) var(--tt-space-10) var(--tt-space-8)}}.sheet-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:var(--tt-black-a60);-webkit-backdrop-filter:blur(var(--tt-blur-sm));backdrop-filter:blur(var(--tt-blur-sm));z-index:var(--tt-z-sheet);display:flex;align-items:flex-end;animation:fadeInOverlay var(--tt-duration-normal) var(--tt-ease-default)}@keyframes fadeInOverlay{0%{opacity:0}to{opacity:1}}.bottom-sheet{width:100%;max-height:75vh;background:var(--tt-bg-surface);border-radius:var(--tt-radius-sheet) var(--tt-radius-sheet) 0 0;padding:var(--tt-space-7) 0 var(--tt-space-12);animation:slideUp var(--tt-duration-enter) var(--tt-ease-enter);display:flex;flex-direction:column;overflow:hidden}@keyframes slideUp{0%{transform:translateY(100%)}to{transform:translateY(0)}}.sheet-handle{display:flex;justify-content:center;padding:var(--tt-space-2) 0 var(--tt-space-6);cursor:pointer}.handle-bar{width:36px;height:4px;border-radius:var(--tt-radius-sm);background:var(--tt-white-a20)}.sheet-tabs{display:flex;padding:0 var(--tt-space-8) var(--tt-space-6);gap:var(--tt-space-4);border-bottom:.5px solid var(--tt-border-default);flex-shrink:0}.sheet-tab{flex:1;padding:var(--tt-space-5) 0;border-radius:var(--tt-radius-lg);border:none;background:transparent;color:var(--tt-text-secondary);font-size:var(--tt-text-md);font-weight:600;font-family:inherit;cursor:pointer;transition:all var(--tt-duration-normal) var(--tt-ease-default);letter-spacing:-.01em}.sheet-tab.active{background:var(--tt-white-a10);color:var(--tt-text-primary)}.sheet-tab:active{opacity:.7}.sheet-content{padding:var(--tt-space-7) var(--tt-space-8) 0;overflow-y:auto;flex:1;-webkit-overflow-scrolling:touch}.sheet-content::-webkit-scrollbar{width:var(--tt-space-2)}.sheet-content::-webkit-scrollbar-track{background:transparent}.sheet-content::-webkit-scrollbar-thumb{background:var(--tt-white-a10);border-radius:var(--tt-radius-sm)}.template-tab{display:flex;flex-direction:column;gap:var(--tt-space-6)}.template-categories{display:flex;gap:var(--tt-space-4);overflow-x:auto;padding-bottom:var(--tt-space-2);-webkit-overflow-scrolling:touch}.template-categories::-webkit-scrollbar{display:none}.category-chip{flex-shrink:0;padding:var(--tt-space-4) var(--tt-space-7);border-radius:var(--tt-radius-pill);border:none;background:var(--tt-white-a6);color:var(--tt-text-secondary);font-size:var(--tt-text-base);font-weight:600;font-family:inherit;cursor:pointer;transition:all var(--tt-duration-normal) var(--tt-ease-default)}.category-chip.active{background:var(--tt-white-a15);color:var(--tt-text-primary)}.category-chip:active{transform:scale(.95)}.template-list{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--tt-space-6)}.template-card{-webkit-user-select:none;user-select:none;display:flex;flex-direction:column;align-items:stretch;gap:var(--tt-space-4);padding:var(--tt-space-6);border-radius:var(--tt-radius-2xl);border:1px solid var(--tt-border-default);background:var(--tt-white-a3);cursor:pointer;transition:all var(--tt-duration-normal) var(--tt-ease-default);font-family:inherit;text-align:left}.template-card:active{transform:scale(.97);background:var(--tt-white-a6)}.template-card.active{border-color:var(--tt-white-a25);background:var(--tt-white-a10);box-shadow:0 0 0 2px var(--tt-white-a10)}.create-card{align-items:center;justify-content:center;min-height:120px}.create-icon{width:56px;height:56px;border-radius:var(--tt-radius-full);background:var(--tt-white-a6);display:flex;align-items:center;justify-content:center;color:var(--tt-text-secondary);margin-bottom:var(--tt-space-2)}.template-preview-mini{width:100%;aspect-ratio:16 / 7;border-radius:var(--tt-radius-md);overflow:hidden;display:flex;flex-direction:row;box-shadow:var(--tt-shadow-card)}.mini-left{height:100%}.mini-right{height:100%;padding:var(--tt-space-5) var(--tt-space-4);display:flex;flex-direction:column;gap:var(--tt-space-1);justify-content:center}.mini-line{height:3px;border-radius:1.5px;opacity:.3;width:80%}.mini-line.short{width:50%}.template-card-meta{display:flex;flex-direction:column;gap:var(--tt-space-2)}.template-name{font-size:var(--tt-text-base);font-weight:500;color:var(--tt-text-primary);letter-spacing:-.01em}.template-actions{display:flex;gap:var(--tt-space-5)}.template-action{font-size:var(--tt-text-2xs);color:var(--tt-text-secondary);cursor:pointer;transition:color var(--tt-duration-normal) var(--tt-ease-default)}.template-action:hover{color:var(--tt-text-primary)}.template-action.delete:hover{color:var(--tt-error)}.template-editor-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:var(--tt-black-a70);-webkit-backdrop-filter:blur(var(--tt-blur-md));backdrop-filter:blur(var(--tt-blur-md));z-index:var(--tt-z-editor);display:flex;align-items:flex-end;animation:fadeInOverlay var(--tt-duration-normal) var(--tt-ease-default)}.template-editor{width:100%;max-height:85vh;background:var(--tt-bg-surface);border-radius:var(--tt-radius-sheet) var(--tt-radius-sheet) 0 0;display:flex;flex-direction:column;overflow:hidden;animation:slideUp var(--tt-duration-enter) var(--tt-ease-enter)}.template-editor-header{display:flex;align-items:center;justify-content:space-between;padding:var(--tt-space-8) var(--tt-space-8) var(--tt-space-7);border-bottom:.5px solid var(--tt-border-default);flex-shrink:0}.template-editor-header h3{font-size:var(--tt-text-2xl);font-weight:700;color:var(--tt-text-primary)}.editor-close{width:var(--tt-space-9);height:var(--tt-space-9);border-radius:var(--tt-radius-full);border:none;background:var(--tt-white-a8);color:var(--tt-text-primary);display:flex;align-items:center;justify-content:center;cursor:pointer}.template-editor-body{padding:var(--tt-space-7) var(--tt-space-8);overflow-y:auto;flex:1;-webkit-overflow-scrolling:touch;display:flex;flex-direction:column;gap:var(--tt-space-10)}.editor-section{display:flex;flex-direction:column;gap:var(--tt-space-6)}.editor-section h4{font-size:var(--tt-text-sm);color:var(--tt-text-secondary);font-weight:600;text-transform:uppercase;letter-spacing:.5px}.editor-field{display:flex;flex-direction:column;gap:var(--tt-space-3)}.editor-field label{font-size:var(--tt-text-base);color:var(--tt-text-primary);font-weight:500}.editor-field input[type=text],.editor-field select{background:var(--tt-white-a6);border:1px solid var(--tt-border-strong);border-radius:var(--tt-radius-lg);padding:var(--tt-space-5) var(--tt-space-6);color:var(--tt-text-primary);font-size:var(--tt-text-md);font-family:inherit;outline:none}.editor-field input[type=range]{width:100%;-webkit-appearance:none;-moz-appearance:none;appearance:none;height:var(--tt-space-2);background:var(--tt-white-a10);border-radius:var(--tt-radius-sm);outline:none}.editor-field input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:var(--tt-space-8);height:var(--tt-space-8);border-radius:var(--tt-radius-full);background:var(--tt-text-primary);cursor:pointer;box-shadow:0 2px 6px var(--tt-black-a30)}.editor-color-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--tt-space-6)}.editor-color{display:flex;flex-direction:column;gap:var(--tt-space-3)}.editor-color label{font-size:var(--tt-text-sm);color:var(--tt-text-secondary)}.color-input-row{display:flex;gap:var(--tt-space-4);align-items:center}.color-input-row input[type=color]{width:var(--tt-space-10);height:var(--tt-space-10);border:none;border-radius:var(--tt-radius-md);background:transparent;cursor:pointer;padding:0}.color-input-row input[type=text]{flex:1;min-width:0;text-transform:uppercase;color:var(--tt-text-primary);background:var(--tt-white-a6);border:1px solid var(--tt-border-strong);border-radius:var(--tt-radius-md);padding:var(--tt-space-4) var(--tt-space-5)}.editor-checks{display:flex;flex-direction:column;gap:var(--tt-space-5)}.editor-check{display:flex;align-items:center;gap:var(--tt-space-4);font-size:var(--tt-text-md);color:var(--tt-text-primary);cursor:pointer}.editor-check input[type=checkbox]{width:var(--tt-space-8);height:var(--tt-space-8);border-radius:var(--tt-radius-sm);accent-color:var(--tt-bg-primary)}.template-editor-footer{display:flex;gap:var(--tt-space-6);padding:var(--tt-space-8) var(--tt-space-8) var(--tt-space-12);border-top:.5px solid var(--tt-border-default);flex-shrink:0}.btn-text,.btn-primary.small{flex:1;padding:var(--tt-space-6);border-radius:var(--tt-radius-xl);border:none;font-size:var(--tt-text-md);font-weight:600;font-family:inherit;cursor:pointer;transition:all var(--tt-duration-normal) var(--tt-ease-default)}.btn-text{background:var(--tt-white-a6);color:var(--tt-text-primary)}.btn-primary.small{background:var(--tt-bg-primary);color:var(--tt-text-inverse)}.edit-list{display:flex;flex-direction:column;gap:var(--tt-space-2)}.edit-tip{font-size:var(--tt-text-sm);color:var(--tt-text-secondary);margin-bottom:var(--tt-space-4);text-align:center;letter-spacing:.01em}.edit-field-btn{-webkit-user-select:none;user-select:none;display:flex;align-items:center;gap:var(--tt-space-8);padding:var(--tt-space-6) var(--tt-space-7);border-radius:var(--tt-radius-xl);border:none;background:var(--tt-white-a4);cursor:pointer;transition:all var(--tt-duration-fast) var(--tt-ease-default);font-family:inherit;text-align:left;width:100%}.edit-field-btn:active{background:var(--tt-white-a8);transform:scale(.99)}.edit-label{font-size:var(--tt-text-sm);color:var(--tt-text-secondary);font-weight:500;min-width:48px;text-transform:uppercase;letter-spacing:.5px}.edit-value{flex:1;font-size:var(--tt-text-md);color:var(--tt-text-primary);font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.edit-field-btn svg{color:var(--tt-text-secondary);opacity:.6;flex-shrink:0}.edit-single{display:flex;flex-direction:column;gap:var(--tt-space-6)}.edit-single label{font-size:var(--tt-text-sm);color:var(--tt-text-secondary);font-weight:600;text-transform:uppercase;letter-spacing:.5px}.edit-single input{background:var(--tt-white-a6);border:1px solid var(--tt-border-strong);border-radius:var(--tt-radius-xl);padding:var(--tt-space-7) var(--tt-space-8);color:var(--tt-text-primary);font-size:var(--tt-text-xl);font-family:inherit;outline:none;transition:all var(--tt-duration-normal) var(--tt-ease-default);-webkit-appearance:none}.edit-single input:focus{border-color:var(--tt-border-focus);background:var(--tt-white-a8)}.edit-single input::placeholder{color:var(--tt-text-tertiary)}.edit-actions{display:flex;gap:var(--tt-space-5);margin-top:var(--tt-space-2)}.btn-text{flex:1;padding:var(--tt-space-6);border-radius:var(--tt-radius-xl);border:none;background:var(--tt-white-a6);color:var(--tt-text-primary);font-size:var(--tt-text-md);font-weight:600;font-family:inherit;cursor:pointer;transition:all var(--tt-duration-normal) var(--tt-ease-default)}.btn-text:active{background:var(--tt-white-a10);transform:scale(.98)}.btn-primary.small{flex:1;padding:var(--tt-space-6);border-radius:var(--tt-radius-xl);border:none;background:var(--tt-bg-primary);color:var(--tt-text-inverse);font-size:var(--tt-text-md);font-weight:600;font-family:inherit;cursor:pointer;transition:all var(--tt-duration-normal) var(--tt-ease-default)}.btn-primary.small:active{background:var(--tt-bg-primary-pressed);transform:scale(.98)}.upload-zone{border:2px dashed var(--tt-white-a12);border-radius:var(--tt-radius-3xl);padding:var(--tt-space-13) var(--tt-space-8);text-align:center;cursor:pointer;transition:all var(--tt-duration-slow) var(--tt-ease-default);background:var(--tt-white-a3);position:relative;overflow:hidden}.upload-zone:active{border-color:var(--tt-bg-primary);background:#0071e30f}.upload-placeholder{color:var(--tt-text-secondary);display:flex;flex-direction:column;align-items:center;gap:var(--tt-space-5)}.upload-placeholder svg{opacity:.5}.upload-placeholder p{font-size:var(--tt-text-md);color:var(--tt-text-secondary);font-weight:500}.photo-editor{display:flex;flex-direction:column;gap:var(--tt-space-6)}.crop-preview{width:100%;aspect-ratio:16 / 9;border-radius:var(--tt-radius-2xl);overflow:hidden;border:1px solid var(--tt-white-a8);background:var(--tt-white-a3);position:relative;cursor:grab;touch-action:none}.crop-preview:active{cursor:grabbing}.crop-preview-img{width:100%;height:100%;object-fit:cover;pointer-events:none;transform-origin:center center;display:block}.crop-controls{display:flex;flex-direction:column;gap:var(--tt-space-4)}.crop-control{display:flex;align-items:center;gap:var(--tt-space-5)}.crop-label{font-size:var(--tt-text-sm);color:var(--tt-text-secondary);font-weight:500;min-width:40px;text-transform:uppercase;letter-spacing:.5px}.crop-control input[type=range]{flex:1;min-width:120px;-webkit-appearance:none;-moz-appearance:none;appearance:none;height:var(--tt-space-2);background:var(--tt-white-a10);border-radius:var(--tt-radius-sm);outline:none}.crop-control input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:var(--tt-space-8);height:var(--tt-space-8);border-radius:var(--tt-radius-full);background:var(--tt-text-primary);cursor:pointer;box-shadow:0 2px 6px var(--tt-black-a30)}.crop-control input[type=range]::-moz-range-thumb{width:var(--tt-space-8);height:var(--tt-space-8);border-radius:var(--tt-radius-full);background:var(--tt-text-primary);cursor:pointer;border:none;box-shadow:0 2px 6px var(--tt-black-a30)}.crop-value{font-size:var(--tt-text-base);color:var(--tt-text-primary);min-width:48px;text-align:right;font-family:var(--tt-font-mono);font-weight:500}.crop-hint{font-size:var(--tt-text-sm);color:var(--tt-text-tertiary);font-style:italic}.btn-secondary.full{width:100%;padding:var(--tt-space-6);border-radius:var(--tt-radius-xl);border:none;background:var(--tt-white-a6);color:var(--tt-text-primary);font-size:var(--tt-text-md);font-weight:600;font-family:inherit;cursor:pointer;transition:all var(--tt-duration-normal) var(--tt-ease-default);margin-top:var(--tt-space-2)}.btn-secondary.full:active{background:var(--tt-white-a10);transform:scale(.98)}.gesture-toast{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);background:var(--tt-white-a15);-webkit-backdrop-filter:blur(var(--tt-blur-lg));backdrop-filter:blur(var(--tt-blur-lg));color:var(--tt-text-inverse);padding:var(--tt-space-7) var(--tt-space-10);border-radius:var(--tt-radius-pill);font-size:var(--tt-text-md);font-weight:600;z-index:var(--tt-z-toast);animation:toastIn var(--tt-duration-normal) var(--tt-ease-default),toastOut var(--tt-duration-normal) var(--tt-ease-default) 1.2s forwards;pointer-events:none;letter-spacing:-.01em;box-shadow:var(--tt-shadow-toast)}@keyframes toastIn{0%{opacity:0;transform:translate(-50%,-50%) scale(.9)}to{opacity:1;transform:translate(-50%,-50%) scale(1)}}@keyframes toastOut{0%{opacity:1;transform:translate(-50%,-50%) scale(1)}to{opacity:0;transform:translate(-50%,-50%) scale(.9)}}:root{--tt-color-black: #000000;--tt-color-white: #ffffff;--tt-color-gray-100: #f5f5f7;--tt-color-gray-200: #86868b;--tt-color-gray-300: #636366;--tt-color-blue: #0071e3;--tt-color-blue-hover: #0077ed;--tt-color-red: #ff453a;--tt-white-a3: rgba(255, 255, 255, .03);--tt-white-a4: rgba(255, 255, 255, .04);--tt-white-a6: rgba(255, 255, 255, .06);--tt-white-a8: rgba(255, 255, 255, .08);--tt-white-a10: rgba(255, 255, 255, .1);--tt-white-a12: rgba(255, 255, 255, .12);--tt-white-a15: rgba(255, 255, 255, .15);--tt-white-a20: rgba(255, 255, 255, .2);--tt-white-a25: rgba(255, 255, 255, .25);--tt-white-a30: rgba(255, 255, 255, .3);--tt-black-a8: rgba(0, 0, 0, .08);--tt-black-a10: rgba(0, 0, 0, .1);--tt-black-a15: rgba(0, 0, 0, .15);--tt-black-a20: rgba(0, 0, 0, .2);--tt-black-a30: rgba(0, 0, 0, .3);--tt-black-a40: rgba(0, 0, 0, .4);--tt-black-a60: rgba(0, 0, 0, .6);--tt-black-a70: rgba(0, 0, 0, .7);--tt-bg-page: var(--tt-color-black);--tt-bg-surface: #1c1c1e;--tt-bg-elevated: var(--tt-white-a8);--tt-bg-primary: var(--tt-color-blue);--tt-bg-primary-pressed: var(--tt-color-blue-hover);--tt-text-primary: var(--tt-color-gray-100);--tt-text-secondary: var(--tt-color-gray-200);--tt-text-tertiary: var(--tt-color-gray-300);--tt-text-inverse: var(--tt-color-white);--tt-border-default: var(--tt-white-a6);--tt-border-strong: var(--tt-white-a10);--tt-border-focus: var(--tt-white-a25);--tt-error: var(--tt-color-red);--tt-ticket-main: #3d2817;--tt-ticket-bg: #f7f3ed;--tt-ticket-accent: #c4956a;--tt-ticket-text: #3d2817;--tt-space-1: 2px;--tt-space-2: 4px;--tt-space-3: 6px;--tt-space-4: 8px;--tt-space-5: 10px;--tt-space-6: 12px;--tt-space-7: 14px;--tt-space-8: 16px;--tt-space-9: 20px;--tt-space-10: 24px;--tt-space-11: 28px;--tt-space-12: 32px;--tt-space-13: 40px;--tt-space-14: 48px;--tt-radius-xs: 2px;--tt-radius-sm: 4px;--tt-radius-md: 8px;--tt-radius-lg: 10px;--tt-radius-xl: 12px;--tt-radius-2xl: 14px;--tt-radius-3xl: 16px;--tt-radius-sheet: 24px;--tt-radius-pill: 100px;--tt-radius-full: 50%;--tt-font-sans: -apple-system, BlinkMacSystemFont, "SF Pro Display", "SF Pro Text", "Helvetica Neue", Helvetica, Arial, sans-serif;--tt-font-mono: "SF Mono", SFMono-Regular, ui-monospace, monospace;--tt-text-2xs: .7rem;--tt-text-xs: .72rem;--tt-text-sm: .75rem;--tt-text-base: .8rem;--tt-text-md: .85rem;--tt-text-lg: .9rem;--tt-text-xl: 1rem;--tt-text-2xl: 1.1rem;--tt-text-3xl: 1.2rem;--tt-text-4xl: 1.4rem;--tt-text-5xl: 1.6rem;--tt-shadow-sm: 0 2px 4px var(--tt-black-a15);--tt-shadow-md: 0 8px 32px var(--tt-black-a40);--tt-shadow-lg: 0 16px 48px -12px var(--tt-shadow-tint, var(--tt-black-a15));--tt-shadow-card: 0 2px 8px var(--tt-black-a20);--tt-shadow-primary: 0 4px 12px rgba(0, 113, 227, .3);--tt-shadow-toast: 0 4px 20px var(--tt-black-a30);--tt-shadow-inset-light: inset 0 0 0 .5px var(--tt-white-a6);--tt-blur-sm: 8px;--tt-blur-md: 10px;--tt-blur-lg: 20px;--tt-duration-fast: .15s;--tt-duration-normal: .2s;--tt-duration-slow: .3s;--tt-duration-enter: .35s;--tt-ease-default: ease;--tt-ease-enter: cubic-bezier(.23, 1, .32, 1);--tt-z-base: 1;--tt-z-header: 10;--tt-z-sheet: 100;--tt-z-editor: 120;--tt-z-landscape: 150;--tt-z-toast: 200}*{margin:0;padding:0;box-sizing:border-box;-webkit-tap-highlight-color:transparent}html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}body{font-family:var(--tt-font-sans);background:var(--tt-bg-page);color:var(--tt-text-primary);min-height:100vh;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;overflow:hidden;overscroll-behavior:none;touch-action:manipulation}#root{min-height:100vh;height:100vh;overflow:hidden}body::-webkit-scrollbar{display:none}body{-ms-overflow-style:none;scrollbar-width:none}::selection{background:#0071e34d;color:var(--tt-text-inverse)}button,input{-webkit-appearance:none;-moz-appearance:none;appearance:none}.tt-btn{-webkit-user-select:none;user-select:none;display:inline-flex;align-items:center;justify-content:center;gap:var(--tt-space-3);padding:var(--tt-space-6) var(--tt-space-9);border-radius:var(--tt-radius-pill);border:none;background:var(--tt-white-a8);color:var(--tt-text-primary);font-size:var(--tt-text-md);font-weight:600;font-family:inherit;cursor:pointer;transition:all var(--tt-duration-normal) var(--tt-ease-default);-webkit-backdrop-filter:blur(var(--tt-blur-lg));backdrop-filter:blur(var(--tt-blur-lg));letter-spacing:-.01em}.tt-btn svg{opacity:.9}.tt-btn:active{transform:scale(.95);background:var(--tt-white-a12)}.tt-btn--primary{background:var(--tt-bg-primary);color:var(--tt-text-inverse);box-shadow:var(--tt-shadow-primary)}.tt-btn--primary:active{background:var(--tt-bg-primary-pressed)}.tt-btn--text{border-radius:var(--tt-radius-xl);background:var(--tt-white-a6)}.tt-btn--text:active{background:var(--tt-white-a10)}.tt-btn--icon{width:var(--tt-space-11);height:var(--tt-space-11);padding:0;border-radius:var(--tt-radius-full);background:var(--tt-white-a10);-webkit-backdrop-filter:blur(var(--tt-blur-md));backdrop-filter:blur(var(--tt-blur-md))}.tt-btn--icon:active{background:var(--tt-white-a20)}.tt-chip{flex-shrink:0;padding:var(--tt-space-4) var(--tt-space-7);border-radius:var(--tt-radius-pill);border:none;background:var(--tt-white-a6);color:var(--tt-text-secondary);font-size:var(--tt-text-base);font-weight:600;font-family:inherit;cursor:pointer;transition:all var(--tt-duration-normal) var(--tt-ease-default)}.tt-chip.active{background:var(--tt-white-a15);color:var(--tt-text-primary)}.tt-chip:active{transform:scale(.95)}.tt-input{background:var(--tt-white-a6);border:1px solid var(--tt-border-strong);border-radius:var(--tt-radius-xl);padding:var(--tt-space-7) var(--tt-space-8);color:var(--tt-text-primary);font-size:var(--tt-text-xl);font-family:inherit;outline:none;transition:all var(--tt-duration-normal) var(--tt-ease-default);-webkit-appearance:none}.tt-input::placeholder{color:var(--tt-text-tertiary)}.tt-input:focus{border-color:var(--tt-border-focus);background:var(--tt-white-a8)}.tt-range{-webkit-appearance:none;-moz-appearance:none;appearance:none;height:var(--tt-space-2);background:var(--tt-white-a10);border-radius:var(--tt-radius-sm);outline:none}.tt-range::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:var(--tt-space-8);height:var(--tt-space-8);border-radius:var(--tt-radius-full);background:var(--tt-text-primary);cursor:pointer;box-shadow:0 2px 6px var(--tt-black-a30)}.tt-range::-moz-range-thumb{width:var(--tt-space-8);height:var(--tt-space-8);border-radius:var(--tt-radius-full);background:var(--tt-text-primary);cursor:pointer;border:none;box-shadow:0 2px 6px var(--tt-black-a30)}.tt-card{-webkit-user-select:none;user-select:none;display:flex;flex-direction:column;gap:var(--tt-space-4);padding:var(--tt-space-6);border-radius:var(--tt-radius-2xl);border:1px solid var(--tt-border-default);background:var(--tt-white-a3);cursor:pointer;transition:all var(--tt-duration-normal) var(--tt-ease-default);font-family:inherit;text-align:left}.tt-card:active{transform:scale(.97);background:var(--tt-white-a6)}.tt-card.active{border-color:var(--tt-white-a25);background:var(--tt-white-a10);box-shadow:0 0 0 2px var(--tt-white-a10)}.tt-list-item{-webkit-user-select:none;user-select:none;display:flex;align-items:center;gap:var(--tt-space-8);padding:var(--tt-space-6) var(--tt-space-7);border-radius:var(--tt-radius-xl);border:none;background:var(--tt-white-a4);cursor:pointer;transition:all var(--tt-duration-fast) var(--tt-ease-default);font-family:inherit;text-align:left;width:100%}.tt-list-item:active{background:var(--tt-white-a8);transform:scale(.99)}.tt-list-item__label{font-size:var(--tt-text-sm);color:var(--tt-text-secondary);font-weight:500;min-width:48px;text-transform:uppercase;letter-spacing:.5px}.tt-list-item__value{flex:1;font-size:var(--tt-text-md);color:var(--tt-text-primary);font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.tt-handle{width:36px;height:4px;border-radius:var(--tt-radius-sm);background:var(--tt-white-a20)}.tt-section-title{font-size:var(--tt-text-sm);color:var(--tt-text-secondary);font-weight:600;text-transform:uppercase;letter-spacing:.5px}.tt-hint{font-size:var(--tt-text-sm);color:var(--tt-text-secondary);letter-spacing:.02em;opacity:.7}.tt-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:var(--tt-black-a60);-webkit-backdrop-filter:blur(var(--tt-blur-sm));backdrop-filter:blur(var(--tt-blur-sm));z-index:var(--tt-z-sheet);display:flex;align-items:flex-end;animation:tt-fade-in var(--tt-duration-normal) var(--tt-ease-default)}.tt-overlay--strong{background:var(--tt-black-a70);-webkit-backdrop-filter:blur(var(--tt-blur-md));backdrop-filter:blur(var(--tt-blur-md))}.tt-sheet{width:100%;max-height:75vh;background:var(--tt-bg-surface);border-radius:var(--tt-radius-sheet) var(--tt-radius-sheet) 0 0;padding:var(--tt-space-7) 0 var(--tt-space-12);animation:tt-slide-up var(--tt-duration-enter) var(--tt-ease-enter);display:flex;flex-direction:column;overflow:hidden}.tt-sheet__handle{display:flex;justify-content:center;padding:var(--tt-space-2) 0 var(--tt-space-6);cursor:pointer}.tt-sheet__tabs{display:flex;padding:0 var(--tt-space-8) var(--tt-space-6);gap:var(--tt-space-4);border-bottom:.5px solid var(--tt-border-default);flex-shrink:0}.tt-sheet__tab{flex:1;padding:var(--tt-space-5) 0;border-radius:var(--tt-radius-lg);border:none;background:transparent;color:var(--tt-text-secondary);font-size:var(--tt-text-md);font-weight:600;font-family:inherit;cursor:pointer;transition:all var(--tt-duration-normal) var(--tt-ease-default);letter-spacing:-.01em}.tt-sheet__tab.active{background:var(--tt-white-a10);color:var(--tt-text-primary)}.tt-sheet__tab:active{opacity:.7}.tt-sheet__content{padding:var(--tt-space-7) var(--tt-space-8) 0;overflow-y:auto;flex:1;-webkit-overflow-scrolling:touch}.tt-sheet__content::-webkit-scrollbar{width:var(--tt-space-2)}.tt-sheet__content::-webkit-scrollbar-track{background:transparent}.tt-sheet__content::-webkit-scrollbar-thumb{background:var(--tt-white-a10);border-radius:var(--tt-radius-sm)}.tt-toast{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);background:var(--tt-white-a15);-webkit-backdrop-filter:blur(var(--tt-blur-lg));backdrop-filter:blur(var(--tt-blur-lg));color:var(--tt-text-inverse);padding:var(--tt-space-7) var(--tt-space-10);border-radius:var(--tt-radius-pill);font-size:var(--tt-text-md);font-weight:600;z-index:var(--tt-z-toast);animation:tt-toast-in var(--tt-duration-normal) var(--tt-ease-default),tt-toast-out var(--tt-duration-normal) var(--tt-ease-default) 1.2s forwards;pointer-events:none;letter-spacing:-.01em;box-shadow:var(--tt-shadow-toast)}.tt-upload-zone{border:2px dashed var(--tt-white-a12);border-radius:var(--tt-radius-3xl);padding:var(--tt-space-13) var(--tt-space-8);text-align:center;cursor:pointer;transition:all var(--tt-duration-slow) var(--tt-ease-default);background:var(--tt-white-a3);position:relative;overflow:hidden}.tt-upload-zone:active{border-color:var(--tt-bg-primary);background:#0071e30f}.tt-upload-zone__placeholder{color:var(--tt-text-secondary);display:flex;flex-direction:column;align-items:center;gap:var(--tt-space-5)}.tt-upload-zone__placeholder svg{opacity:.5}.tt-upload-zone__placeholder p{font-size:var(--tt-text-md);color:var(--tt-text-secondary);font-weight:500}.tt-crop-preview{width:100%;aspect-ratio:16 / 9;border-radius:var(--tt-radius-2xl);overflow:hidden;border:1px solid var(--tt-white-a8);background:var(--tt-white-a3);position:relative;cursor:grab;touch-action:none}.tt-crop-preview:active{cursor:grabbing}.tt-fullscreen-view{position:fixed;top:0;right:0;bottom:0;left:0;background:var(--tt-bg-page);z-index:var(--tt-z-landscape);display:flex;align-items:center;justify-content:center;animation:tt-fade-in var(--tt-duration-slow) var(--tt-ease-default)}@keyframes tt-fade-in{0%{opacity:0}to{opacity:1}}@keyframes tt-slide-up{0%{transform:translateY(100%)}to{transform:translateY(0)}}@keyframes tt-toast-in{0%{opacity:0;transform:translate(-50%,-50%) scale(.9)}to{opacity:1;transform:translate(-50%,-50%) scale(1)}}@keyframes tt-toast-out{0%{opacity:1;transform:translate(-50%,-50%) scale(1)}to{opacity:0;transform:translate(-50%,-50%) scale(.9)}}
