:root{color:#20303a;background:#16242a;font-family:"Source Han Serif SC",Songti SC,STSong,"Noto Serif CJK SC",Georgia,serif;font-synthesis:none;text-rendering:geometricPrecision;-webkit-font-smoothing:antialiased;--paper: #efe9d8;--paper-light: #f6f1e3;--paper-dim: #e6ddc7;--ink: #1f2d34;--ink-soft: #51616a;--teal: #21333b;--teal-hi: #2c4754;--teal-deep: #15232a;--bronze: #b08d57;--bronze-soft: #cdb588;--hairline: #d2c4a3;--seal: #9e3b2f;--surface-shadow: 0 18px 48px rgba(0, 0, 0, .36)}*{box-sizing:border-box}html,body,#root{min-height:100%}body{margin:0;min-width:320px;min-height:100vh;overflow:hidden;background:radial-gradient(circle at top right,rgba(205,181,136,.08),transparent 32%),linear-gradient(180deg,#132128 0%,var(--teal-deep) 100%);color:var(--ink)}button,input,select,textarea{font:inherit}button,select,input[type=range]{cursor:pointer}button:disabled{cursor:wait}.app{position:relative;height:100vh;overflow:hidden;background:radial-gradient(circle at top left,rgba(205,181,136,.05),transparent 28%),linear-gradient(180deg,#132128 0%,var(--teal-deep) 100%)}.workspace{position:relative;height:100vh;padding:22px}.map-stage{position:relative;height:100%}.map-shell{position:relative;width:100%;height:100%;min-height:560px;background:var(--paper-light);border:1px solid rgba(176,141,87,.6);border-radius:24px;outline:5px solid rgba(16,30,37,.94);outline-offset:4px;box-shadow:var(--surface-shadow);overflow:hidden}.map-canvas{position:relative;z-index:1;width:100%;height:100%;display:block}.map-vector-overlay{position:absolute;inset:0;z-index:2;width:100%;height:100%;pointer-events:none}.empty-map,.map-busy{position:absolute;z-index:10;display:flex;align-items:center;justify-content:center;gap:14px}.empty-map{inset:0;flex-direction:column;background:#efe9d8db;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);color:var(--teal);font-weight:700;font-size:15px;letter-spacing:3px;text-transform:uppercase}.map-busy{right:18px;bottom:18px;padding:11px 15px;border:1px solid var(--bronze);border-radius:999px;background:#f6f1e3f0;box-shadow:0 8px 20px #0003;color:var(--teal);font-size:12px;font-weight:700;letter-spacing:1.2px}.spinner,.loading-mark{width:22px;height:22px;border:2px solid var(--bronze-soft);border-top-color:var(--teal);border-radius:50%;animation:spin .9s linear infinite}.loading-mark{width:44px;height:44px}.map-top-left,.map-top-right,.map-type-dock,.center-slider-dock,.export-dock{position:absolute;z-index:22}.map-top-left{top:18px;left:18px;display:flex;flex-direction:column;align-items:flex-start;gap:10px}.generation-toggle,.icon-toggle,.map-type-button,.export-dock button,.panel-close,.icon-button,.toast-close{border:1px solid rgba(205,181,136,.32);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);transition:transform .12s ease,background .18s ease,border-color .18s ease}.generation-toggle{min-height:42px;display:inline-flex;align-items:center;gap:8px;padding:0 14px;color:var(--paper-light);background:#15232ad6;border-radius:999px;box-shadow:0 14px 30px #00000038}.generation-toggle span{font-size:12px;font-weight:700;letter-spacing:.8px}.generation-toggle.active,.generation-toggle:hover{background:#2c4754f0;border-color:#cdb58880}.generation-window{width:min(360px,calc(100vw - 48px));max-height:min(78vh,760px);display:grid;grid-template-rows:auto minmax(0,1fr);background:#f6f1e3f5;border:1px solid rgba(176,141,87,.38);border-radius:20px;box-shadow:0 20px 44px #00000047;overflow:hidden}.generation-window-header{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:14px 14px 12px;border-bottom:1px solid rgba(210,196,163,.72)}.generation-window-header strong{color:var(--teal);font-size:15px;letter-spacing:1.4px}.generation-window-body{min-height:0;display:grid;gap:12px;padding:14px;overflow-y:auto}.map-top-right{top:18px;right:18px;display:flex;align-items:flex-end}.view-mode-dock{display:flex;flex-direction:row;align-items:center;gap:8px}.icon-toggle{width:42px;height:42px;display:inline-grid;place-items:center;color:var(--paper-light);background:#15232ad6;border-radius:14px;box-shadow:0 14px 30px #00000038}.icon-toggle:hover,.panel-close:hover,.icon-button:hover,.toast-close:hover{transform:translateY(-1px);border-color:#cdb58880}.icon-toggle.active{background:#2c4754f0}.map-type-dock{right:18px;bottom:18px;display:flex;flex-direction:row;flex-wrap:wrap;justify-content:flex-end;align-items:flex-end;gap:10px;width:min(420px,calc(100% - 220px))}.map-type-button{min-height:40px;display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:0 14px;color:var(--paper-light);background:#15232ad1;border-radius:999px;box-shadow:0 14px 30px #00000038}.map-type-button span{font-size:12px;font-weight:700;letter-spacing:.6px;white-space:nowrap}.map-type-button:hover{transform:translateY(-1px);border-color:#cdb58880}.map-type-button.active{background:#2c4754f0}.center-slider-dock{left:50%;bottom:18px;display:flex;align-items:center;gap:12px;width:min(420px,calc(100% - 220px));padding:10px 14px;color:var(--paper-light);background:#15232adb;border:1px solid rgba(205,181,136,.32);border-radius:999px;box-shadow:0 14px 30px #00000038;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);transform:translate(-50%)}.center-slider-dock span,.center-slider-dock strong{font-size:12px;white-space:nowrap}.center-slider-dock strong{font-variant-numeric:tabular-nums}.center-slider-dock input[type=range]{flex:1 1 auto;width:auto;height:16px;margin:0;appearance:none;background:transparent}.center-slider-dock input[type=range]::-webkit-slider-runnable-track,.slider input[type=range]::-webkit-slider-runnable-track{height:3px;border-radius:999px;background:linear-gradient(90deg,#b08d5780,#cdb588cc)}.center-slider-dock input[type=range]::-webkit-slider-thumb,.slider input[type=range]::-webkit-slider-thumb{appearance:none;width:15px;height:15px;margin-top:-6px;border-radius:50%;background:var(--paper-light);border:2px solid var(--teal)}.export-dock{left:18px;bottom:18px;display:flex;align-items:center;gap:8px}.export-dock button{min-height:40px;display:inline-flex;align-items:center;justify-content:center;gap:7px;padding:0 12px;color:var(--paper-light);background:#15232ad1;border-radius:999px;box-shadow:0 14px 30px #00000038}.export-dock button:hover:not(:disabled){background:#2c4754f0}.export-dock button span{font-size:12px;font-weight:700}.map-hover-tag{position:absolute;z-index:21;max-width:220px;padding:7px 10px;color:var(--paper-light);font-size:11px;line-height:1.35;background:#15232aeb;border:1px solid rgba(205,181,136,.42);border-radius:999px;box-shadow:0 10px 20px #00000038;pointer-events:none;transform:translateY(-50%)}.field{display:grid;gap:7px;color:var(--ink-soft);font-size:12px;font-weight:600}.field input,.field select{width:100%;height:38px;padding:0 12px;color:var(--ink);border:1px solid var(--hairline);border-radius:10px;background:var(--paper);outline:none;font-family:inherit}.field input:focus,.field select:focus{border-color:var(--teal);box-shadow:0 0 0 2px #21333b1f}.field-inline{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:8px}.slider{display:grid;gap:7px;color:var(--ink-soft);font-size:12px;font-weight:600}.slider span{display:flex;align-items:center;justify-content:space-between;gap:12px}.slider strong{color:var(--teal);font-size:12px;font-weight:700;font-variant-numeric:tabular-nums}.slider input[type=range]{width:100%;height:16px;margin:0;appearance:none;background:transparent}.advanced-toggle{display:flex;align-items:center;justify-content:center;gap:6px;width:100%;padding:10px 0;background:transparent;border:none;border-top:1px solid var(--hairline);color:var(--bronze);font-size:11px;font-weight:700;letter-spacing:1.5px;text-transform:uppercase}.advanced-toggle:hover{color:var(--teal)}.advanced-panel{display:grid;gap:12px;padding-top:4px;animation:fade .24s ease-out}.primary-button{display:flex;align-items:center;justify-content:center;gap:8px;width:100%;height:46px;color:var(--paper-light);font-weight:700;font-size:14px;letter-spacing:1.6px;border:1px solid var(--teal-deep);border-radius:12px;background:linear-gradient(180deg,var(--teal-hi),var(--teal))}.primary-button:hover:not(:disabled){background:linear-gradient(180deg,#355464,var(--teal-hi))}.primary-button:active:not(:disabled){transform:translateY(1px)}.primary-button:disabled{opacity:.55}.panel-close,.icon-button,.toast-close{width:36px;height:36px;display:inline-grid;place-items:center;color:var(--teal);background:var(--paper-light);border-radius:12px}.toast{position:fixed;right:24px;bottom:24px;z-index:40;display:flex;align-items:center;gap:10px;max-width:min(360px,calc(100vw - 32px));padding:12px 14px;border-radius:16px;color:var(--paper-light);border:1px solid rgba(255,255,255,.08);box-shadow:0 16px 32px #00000047}.toast p{flex:1 1 auto;margin:0;font-size:12px;line-height:1.5}.toast.success{background:#3e6757f5}.toast.info{background:#395565f5}.toast.error{background:#9e3b2ff5}@keyframes spin{to{transform:rotate(360deg)}}@keyframes fade{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}@media(max-width:1180px){.workspace{padding:16px}.map-shell{min-height:520px}}@media(max-width:960px){body{overflow:auto}.app{height:auto;min-height:100vh}.workspace{height:auto;min-height:100vh;padding:12px}.map-stage{min-height:calc(100vh - 24px)}.map-shell{min-height:calc(100vh - 24px);border-radius:18px}.map-top-left{top:12px;left:12px}.map-top-right{top:12px;right:12px}.generation-window{width:min(360px,calc(100vw - 24px));max-height:min(72vh,760px)}.map-type-dock{right:12px;bottom:78px;width:min(360px,calc(100% - 150px))}.center-slider-dock{right:12px;bottom:12px;left:12px;width:auto;transform:none}.export-dock{left:12px;bottom:78px;flex-direction:column;align-items:flex-start}.toast{right:16px;left:16px;bottom:16px;max-width:none}}@media(max-width:720px){.workspace{padding:8px}.map-stage{min-height:calc(100vh - 16px)}.map-shell{min-height:calc(100vh - 16px);outline-width:3px;outline-offset:2px}.map-top-left{top:8px;left:8px}.map-top-right{top:8px;right:8px}.view-mode-dock{gap:6px}.icon-toggle{width:40px;height:40px}.generation-toggle span,.export-dock button span{display:none}.generation-toggle{width:42px;justify-content:center;padding:0}.generation-window{width:min(320px,calc(100vw - 16px))}.map-type-dock{right:8px;bottom:118px;width:min(280px,calc(100% - 112px))}.map-type-button{padding:0 10px}.center-slider-dock{right:8px;bottom:8px;left:8px;gap:8px}.center-slider-dock span:first-child{display:none}.export-dock{left:8px;bottom:118px}}
