.shell{width:min(1080px,calc(100vw - 32px));margin:0 auto;padding:20px 0 36px}.app-shell{display:grid;gap:16px}.app-header{display:flex;justify-content:center;align-items:center;padding:4px 2px 2px}.eyebrow{margin:0;color:#7a6f5f;font-size:.8rem;font-weight:700;letter-spacing:.16em;text-transform:uppercase}.direction-bar,.status-strip,.workspace,.actions{display:grid;gap:12px}.direction-bar{grid-template-columns:minmax(0,1fr) auto minmax(0,1fr);align-items:center;gap:10px;padding:4px;border-radius:18px;background:#fffcf7b8;border:1px solid rgba(18,60,61,.07)}.direction-tab,.swap-button,.ghost-chip,.actions button,.ghost-button{font:inherit;border:1px solid rgba(18,60,61,.14);cursor:pointer;transition:background-color .14s ease,border-color .14s ease,transform .14s ease}.direction-tab{min-height:48px;padding:0 16px;border-radius:14px;background:#fffdf8e6;color:#36514f;font-weight:700}.direction-tab-active{background:#1a4a4a;color:#f8f3eb;border-color:#1a4a4a}.swap-button,.ghost-button{min-height:48px;padding:0 16px;border-radius:14px;background:#fffdf8f2;color:#143d3e}.status-strip{grid-template-columns:1fr auto;align-items:center;gap:10px;padding:0 4px}.status-cluster{display:flex;align-items:center;gap:8px;min-height:32px}.status-saved{display:flex;align-items:center;gap:8px;flex-wrap:wrap;justify-content:flex-start}.cache-list{display:flex;gap:8px;flex-wrap:wrap;justify-content:flex-end}.cache-chip{display:inline-flex;align-items:center;min-height:28px;padding:0 10px;border-radius:999px;border:1px solid rgba(18,60,61,.08);color:#6d6659;font-size:.78rem;font-weight:700}.cache-chip-ready{background:#2e7d5b24;color:#1d5b3e}.cache-chip-idle{background:#efe8dc;border-color:#123c3d1a;color:#7d7568}.cache-chip-current{box-shadow:0 0 0 2px #143d3e14}.manage-button{min-height:36px;padding:0 14px;border-radius:999px;box-shadow:none;font-size:.86rem}.inline-status,.progress-block,.error-banner{padding:14px 16px;border-radius:16px}.inline-status{color:#4e5c5a;background:#fffdf8e0;border:1px solid rgba(18,60,61,.08);text-align:center;padding-top:12px;padding-bottom:12px}.progress-block{background:#fff6ea;border:1px solid rgba(239,122,63,.22)}.progress-heading{display:flex;justify-content:space-between;gap:12px;margin-bottom:10px;font-size:.94rem}.progress-bar{height:10px;border-radius:999px;overflow:hidden;background:#14232214}.progress-fill{height:100%;background:linear-gradient(90deg,#ef7a3f,#f0b44a)}.error-banner{background:#ffe8eb;border:1px solid rgba(186,47,63,.28);color:#7c1d2a}.workspace{grid-template-columns:repeat(2,minmax(0,1fr));margin-top:4px;gap:16px}.editor-card{display:grid;gap:12px;padding:14px;border-radius:18px;background:#fffcf7e0;border:1px solid rgba(18,60,61,.06)}.editor-head{display:flex;justify-content:space-between;gap:12px;align-items:center}.editor-title{color:#143d3e;font-size:1.06rem;line-height:1.2}.editor-actions{display:flex;gap:10px;align-items:center}.editor-stat{color:#6e6759;font-size:.86rem}.workspace textarea{min-height:280px;padding:16px 18px;resize:vertical;border-radius:16px;border:1px solid rgba(18,60,61,.08);background:#fffdf9eb;color:#142322;box-shadow:inset 0 1px #ffffffa6}.workspace textarea::placeholder{color:#9a9183}.workspace textarea:focus{outline:none;border-color:#143d3e47;box-shadow:inset 0 1px #ffffffb3,0 0 0 3px #143d3e14}.ghost-chip{min-height:38px;padding:0 14px;border-radius:999px;background:#fffdf8;color:#143d3e;font-weight:600}.actions{justify-content:center;margin-top:2px}.actions-dual{grid-template-columns:minmax(240px,1fr) minmax(260px,1.3fr)}.actions-single{grid-template-columns:minmax(240px,360px)}.actions button{min-height:52px;border-radius:15px;font-weight:700}.primary-action{background:#1a4747;color:#f8f3eb;border-color:#1a4747}.secondary-action{background:#e9f0ea;color:#143d3e}.direction-tab:hover,.swap-button:hover,.ghost-chip:hover,.ghost-button:hover,.actions button:hover{transform:translateY(-1px);border-color:#123c3d4d}.direction-tab:disabled,.swap-button:disabled,.ghost-chip:disabled,.ghost-button:disabled,.actions button:disabled{opacity:.58;cursor:not-allowed;transform:none}@media(max-width:900px){.shell{width:min(100vw - 20px,100%);padding:14px 0 120px}.direction-bar,.status-strip,.workspace,.actions{grid-template-columns:1fr}.editor-card,.inline-status,.progress-block,.error-banner{border-radius:16px}.status-strip{grid-template-columns:1fr;gap:8px}.direction-bar{padding:0;background:transparent;border:0}.status-cluster{align-items:center;flex-direction:row;flex-wrap:wrap;gap:8px}.manage-button{justify-self:start}.editor-head{flex-direction:column;align-items:flex-start}.editor-actions{width:100%;justify-content:space-between}.workspace textarea{min-height:180px;padding:14px;font-size:16px}.actions{position:fixed;left:10px;right:10px;bottom:calc(10px + env(safe-area-inset-bottom));z-index:20;gap:8px;padding:8px;border-radius:18px;background:#faf7f1f2;border:1px solid rgba(18,60,61,.12);box-shadow:0 16px 40px #123c3d2e;-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px)}.shell-editing{padding-bottom:20px}.shell-editing .actions{position:static;left:auto;right:auto;bottom:auto;z-index:auto;padding:0;background:transparent;border:0;box-shadow:none;-webkit-backdrop-filter:none;backdrop-filter:none}.swap-button,.direction-tab,.actions button{min-height:48px}.direction-bar{grid-template-columns:1fr}}@media(max-width:900px)and (orientation:landscape){.shell{padding-bottom:84px}.app-shell{gap:10px}.direction-bar{grid-template-columns:minmax(0,1fr) auto minmax(0,1fr);gap:10px;padding:0;background:transparent;border:0}.direction-tab,.swap-button{min-height:44px}.status-strip{grid-template-columns:1fr auto;gap:8px;align-items:center}.status-cluster{flex-direction:row;align-items:center;gap:10px}.workspace{grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}.editor-card{padding:12px}.editor-head{flex-direction:row;align-items:center}.editor-actions{width:auto;justify-content:flex-end}.workspace textarea{min-height:120px}.actions{grid-template-columns:minmax(220px,360px);left:10px;right:10px;bottom:calc(8px + env(safe-area-inset-bottom));padding:8px 10px;gap:8px;justify-content:center}.actions button{min-height:44px}.shell-editing .actions{position:static;left:auto;right:auto;bottom:auto;padding:0;background:transparent;border:0;box-shadow:none;-webkit-backdrop-filter:none;backdrop-filter:none}}@media(prefers-reduced-motion:reduce){.direction-tab,.swap-button,.ghost-chip,.ghost-button,.actions button{transition:none}}:root{font-family:IBM Plex Sans,Noto Sans SC,PingFang SC,Hiragino Sans GB,sans-serif;line-height:1.5;font-weight:400;color:#142322;background:radial-gradient(circle at top,rgba(239,122,63,.12),transparent 30%),linear-gradient(180deg,#f5f2ea,#efe8db);font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}*{box-sizing:border-box}html{min-width:320px}body{margin:0;min-width:320px;min-height:100vh}button,select,textarea{font:inherit}textarea{line-height:1.55}
