*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--bg: #f4f8f5;--surface: #ffffff;--surface-muted: #eaf3ed;--text: #102018;--text-secondary: #5e6b63;--primary: #199c68;--primary-hover: #117a51;--accent: #0b5b96;--border: #d9e5dc;--header-bg: rgba(255, 255, 255, .94);--contact-bg: #ffffff;--map-bg: #e9eeee;--map-copy-bg: transparent;--contact-text: #000000;--shadow: 0 1px 3px rgba(16, 32, 24, .08);--shadow-lg: 0 16px 40px rgba(16, 32, 24, .14);--radius: 8px}[data-theme=dark]{--bg: #101c17;--surface: #17251e;--surface-muted: #22362b;--text: #eef7f1;--text-secondary: #b9cbbf;--primary: #43c58d;--primary-hover: #31a978;--accent: #7cb7ff;--border: #2d4638;--header-bg: rgba(18, 31, 25, .95);--contact-bg: #14221b;--map-bg: #111e19;--map-copy-bg: transparent;--contact-text: #eef7f1;--shadow: 0 1px 3px rgba(0, 0, 0, .2);--shadow-lg: 0 18px 44px rgba(0, 0, 0, .34)}body{min-height:100vh;color:var(--text);background:var(--bg);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Arial,sans-serif;line-height:1.6}a{color:inherit;text-decoration:none}button,input{font:inherit}button{border:0;cursor:pointer}img{display:block;max-width:100%}main{min-height:calc(100vh - 137px)}.container{width:min(1180px,calc(100% - 40px));margin:0 auto}.header{position:sticky;top:0;z-index:50;background:var(--header-bg);border-bottom:1px solid var(--border);-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px)}.header-inner{display:flex;align-items:center;justify-content:space-between;min-height:92px;gap:20px}.logo{display:inline-flex;align-items:center;flex:0 0 auto}.logo-badge{width:74px;height:82px;border-radius:999px;background:#fff;display:inline-flex;align-items:center;justify-content:center;box-shadow:0 2px 12px #10201824}.logo-image{width:59px;height:auto;display:block;border-radius:4px}.nav-links{display:flex;align-items:center;gap:8px}.nav-link,.cart-nav-button,.btn-secondary,.theme-toggle{display:inline-flex;align-items:center;justify-content:center;min-height:40px;padding:0 16px;border:1px solid transparent;border-radius:var(--radius);background:transparent;color:var(--text-secondary);font-size:.92rem;font-weight:650;white-space:nowrap}.nav-link:hover,.cart-nav-button:hover,.theme-toggle:hover{background:var(--surface-muted);color:var(--text)}.nav-link.active{background:#1f6f631a;color:var(--primary)}.cart-nav-button{gap:8px}.theme-toggle{color:var(--primary);border-color:var(--border);background:var(--surface-muted)}.header-phone{margin-left:16px;color:var(--text);font-size:1rem;white-space:nowrap}.header-phone:hover{color:var(--primary)}.cart-count,.cart-open-button span{min-width:22px;height:22px;padding:0 6px;border-radius:999px;background:var(--accent);color:#fff;font-size:.76rem;line-height:22px;text-align:center}.hero{background:linear-gradient(90deg,#08211857,#0947322e),url(/assets/magic-color-hero.png);background-position:center;background-size:cover;color:#fff}.hero-inner{min-height:520px;display:flex;flex-direction:column;justify-content:center;align-items:center;padding:70px 0 92px;text-align:center}.eyebrow{margin-bottom:10px;color:currentColor;font-size:.78rem;font-weight:800;letter-spacing:.08em;text-transform:uppercase;opacity:.72}.hero h1{max-width:720px;font-size:clamp(2.7rem,7vw,5.8rem);line-height:1;font-weight:700}.hero p:not(.eyebrow){max-width:840px;margin:20px 0 30px;font-size:clamp(1.2rem,3vw,2rem);color:#ffffffe6}.hero-actions{display:flex;justify-content:center;flex-wrap:wrap;gap:10px}.btn-primary,.btn-checkout,.btn-add-cart,.btn-modal{display:inline-flex;align-items:center;justify-content:center;min-height:44px;padding:0 22px;border-radius:var(--radius);background:var(--primary);color:#fff;font-weight:750;transition:background .18s ease,transform .18s ease}.btn-primary:hover,.btn-checkout:hover,.btn-add-cart:hover,.btn-modal:hover{background:var(--primary-hover)}.btn-primary{background:#fff;color:#000;text-transform:uppercase}.hero-service-button{background:#f60;color:#fff}.btn-primary:hover{background:#eef1eb}.hero-service-button:hover{background:#e85c00}.btn-secondary{border-color:var(--border);background:var(--surface);color:var(--text)}.btn-secondary:hover{border-color:#c9d0c3;background:var(--surface-muted)}.features,.about-section,.contact-band,.shop-section{padding:56px 0}.features-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:18px}.feature-card,.product-card,.checkout-card{border:1px solid var(--border);border-radius:var(--radius);background:var(--surface);box-shadow:var(--shadow)}.feature-card{padding:28px}.feature-media{display:block;width:100%;aspect-ratio:4 / 3;margin-bottom:18px;border-radius:calc(var(--radius) - 4px);object-fit:cover;background:var(--surface-muted)}.feature-icon{width:44px;height:44px;margin-bottom:18px;border-radius:50%;background:#199c681a;color:var(--primary);display:flex;align-items:center;justify-content:center;font-weight:850}.feature-card h3,.checkout-card h3{margin-bottom:8px;font-size:1.08rem}.feature-card p,.about-copy,.stock-label,.product-desc,.cart-item-info p,.footer{color:var(--text-secondary)}.about-grid,.contact-inner{display:grid;grid-template-columns:.8fr 1.2fr;gap:36px;align-items:start}.about-grid h2,.contact-inner h2,.shop-header h1{font-size:clamp(1.7rem,3vw,2.45rem);line-height:1.15}.about-copy{display:grid;gap:16px;font-size:1.02rem}.contact-band{border-top:1px solid var(--border);background:var(--contact-bg)}.map-section{padding:56px 0;background:var(--map-bg)}.map-grid{display:grid;grid-template-columns:minmax(260px,.65fr) minmax(360px,1.35fr);gap:24px;align-items:stretch}.map-copy{display:flex;flex-direction:column;align-items:flex-start;justify-content:center;padding:44px 36px;background:var(--map-copy-bg)}.map-copy h2{margin-bottom:28px;color:var(--contact-text);font-size:clamp(1.55rem,2.5vw,2rem);line-height:1.12;font-weight:850}.contact-lines{display:grid;gap:6px;margin-bottom:36px}.contact-lines a{color:var(--contact-text);font-size:clamp(1.1rem,2vw,1.35rem);line-height:1.25}.contact-lines a:hover{color:var(--primary)}.contact-actions{display:flex;align-items:center;gap:12px}.contact-icon{width:22px;height:22px;display:inline-flex;align-items:center;justify-content:center;color:#1c211f;color:var(--contact-text)}.contact-icon svg{width:22px;height:22px;fill:currentColor}.contact-icon:hover{color:var(--primary)}.map-frame{width:100%;min-height:380px;border:1px solid var(--border);border-radius:var(--radius);background:var(--surface-muted);box-shadow:var(--shadow)}.contact-inner{grid-template-columns:1fr auto;align-items:center}.shop-header{display:flex;justify-content:space-between;align-items:flex-end;gap:18px;margin-bottom:28px}.catalog-toolbar{display:grid;grid-template-columns:minmax(240px,1fr) minmax(220px,320px);gap:16px;align-items:end;margin-bottom:24px;padding:16px;border:1px solid var(--border);border-radius:var(--radius);background:var(--surface);box-shadow:var(--shadow)}.search-field,.type-select-field{display:grid;gap:6px;color:var(--text-secondary);font-size:.86rem;font-weight:700}.search-field input,.type-select-field select{width:100%;min-height:42px;border:1px solid var(--border);border-radius:var(--radius);background:var(--bg);color:var(--text);padding:0 12px}.type-select-field select{cursor:pointer}.search-field input:focus,.type-select-field select:focus{outline:3px solid rgba(31,111,99,.16);border-color:var(--primary)}.cart-open-button{gap:10px}.state-message{padding:56px 0;color:var(--text-secondary);text-align:center}.error-message{color:var(--accent)}.products-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:20px}.product-card{overflow:hidden;display:flex;flex-direction:column;transition:box-shadow .18s ease,transform .18s ease}.product-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg)}.product-image{width:100%;aspect-ratio:4 / 3;object-fit:fill;background:#fff;padding:0}.product-info{flex:1;display:flex;flex-direction:column;padding:20px}.product-title-row{display:grid;gap:10px;margin-bottom:8px}.product-name{min-height:1.3em;font-size:1.05rem;line-height:1.3}.type-badge{width:fit-content;max-width:100%;padding:4px 10px;border-radius:999px;background:#1f6f631a;color:var(--primary);font-size:.78rem;font-weight:800}.product-extra{display:flex;flex-wrap:wrap;gap:8px;min-height:24px;margin-bottom:10px;color:var(--text-secondary);font-size:.82rem;font-weight:700}.product-extra span{padding:3px 8px;border-radius:999px;background:var(--surface-muted)}.product-desc{min-height:4.4em;max-height:4.4em;margin-bottom:8px;font-size:.92rem;line-height:1.45;overflow:hidden;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical}.desc-toggle{width:fit-content;margin-bottom:16px;background:transparent;color:var(--primary);font-size:.88rem;font-weight:800}.desc-toggle:hover{color:var(--primary-hover);text-decoration:underline}.product-meta{margin-top:auto;display:flex;justify-content:space-between;align-items:baseline;gap:12px;margin-bottom:16px}.product-price{color:var(--primary);font-size:1.22rem;font-weight:850}.stock-label{font-size:.82rem;white-space:nowrap}.product-controls,.cart-item-actions{display:flex;align-items:center;gap:8px}.product-controls{gap:6px}.qty-btn,.icon-button{width:34px;height:34px;flex:0 0 34px;border:1px solid var(--border);border-radius:var(--radius);background:var(--surface);color:var(--text);font-weight:800}.qty-btn:hover,.icon-button:hover{border-color:var(--primary);color:var(--primary)}.qty-input{width:52px;height:34px;border:1px solid var(--border);border-radius:var(--radius);background:var(--surface);color:var(--text);caret-color:var(--text);text-align:center}.qty-input:focus,.form-input:focus{outline:3px solid rgba(31,111,99,.16);border-color:var(--primary)}.btn-add-cart{flex:1;min-height:34px;padding:0 8px;font-size:.78rem;font-weight:700;line-height:1;white-space:nowrap}.drawer-overlay,.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:100;background:#20231f70}.cart-drawer{width:min(520px,100%);height:100%;margin-left:auto;overflow-y:auto;background:var(--bg);box-shadow:var(--shadow-lg);padding:28px}.drawer-header{display:flex;justify-content:space-between;align-items:flex-start;gap:18px;margin-bottom:24px}.cart-empty{border:1px dashed var(--border);border-radius:var(--radius);padding:32px;background:var(--surface);text-align:center}.cart-empty p{margin-bottom:18px}.cart-items{display:grid;gap:12px;margin-bottom:18px}.cart-item{display:grid;grid-template-columns:76px 1fr auto;gap:14px;align-items:center;padding:14px;border:1px solid var(--border);border-radius:var(--radius);background:var(--surface)}.cart-item-image{width:76px;height:76px;border-radius:6px;object-fit:cover}.cart-item-info h3{margin-bottom:2px;font-size:.98rem}.cart-item-actions{margin-top:10px;flex-wrap:wrap}.btn-remove{min-height:34px;padding:0 10px;border-radius:var(--radius);background:#b6462f14;color:var(--accent);font-weight:700}.cart-item-subtotal{color:var(--primary);font-weight:850;white-space:nowrap}.checkout-card{padding:22px}.form-group{display:grid;gap:6px;margin-bottom:14px;color:var(--text-secondary);font-size:.9rem;font-weight:650}.form-input{width:100%;min-height:42px;border:1px solid var(--border);border-radius:var(--radius);background:var(--surface);color:var(--text);padding:0 12px}.total-row{display:flex;justify-content:space-between;align-items:center;margin:18px 0;padding-top:16px;border-top:1px solid var(--border)}.total-row strong{color:var(--primary);font-size:1.2rem}.btn-checkout{width:100%}.btn-checkout:disabled{opacity:.55;cursor:not-allowed}.toast{position:fixed;right:24px;bottom:24px;z-index:150;max-width:min(360px,calc(100vw - 40px));padding:14px 18px;border-radius:var(--radius);background:var(--text);color:#fff;box-shadow:var(--shadow-lg);font-weight:650}.modal-overlay{display:flex;align-items:center;justify-content:center;padding:20px}.modal{width:min(440px,100%);padding:32px;border-radius:var(--radius);background:var(--surface);box-shadow:var(--shadow-lg);text-align:center}.description-modal{width:min(720px,100%);max-height:min(760px,calc(100vh - 40px));overflow:auto;padding:30px;border:1px solid var(--border);border-radius:var(--radius);background:var(--surface);color:var(--text);box-shadow:var(--shadow-lg)}.description-modal-header{display:flex;align-items:flex-start;justify-content:space-between;gap:18px;margin-bottom:18px}.description-modal h2{font-size:clamp(1.25rem,3vw,1.75rem);line-height:1.2}.description-modal p:not(.eyebrow){color:var(--text-secondary);white-space:pre-line}.modal-mark{width:52px;height:52px;margin:0 auto 18px;border-radius:50%;background:#1f6f631f;color:var(--primary);display:flex;align-items:center;justify-content:center;font-weight:850}.modal h2{margin-bottom:10px}.modal p{margin-bottom:22px;color:var(--text-secondary)}.footer{border-top:1px solid var(--border);background:var(--surface)}.footer-inner{min-height:72px;display:flex;align-items:center;justify-content:space-between;gap:16px;font-size:.9rem}.fade-enter-active,.fade-leave-active,.slide-up-enter-active,.slide-up-leave-active{transition:opacity .2s ease,transform .2s ease}.fade-enter-from,.fade-leave-to{opacity:0}.slide-up-enter-from,.slide-up-leave-to{opacity:0;transform:translateY(16px)}@media(max-width:820px){.container{width:min(100% - 28px,1180px)}.header-inner{min-height:auto;padding:12px 0;align-items:flex-start;flex-direction:column}.nav-links{width:100%;display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px}.nav-link,.cart-nav-button,.header-phone,.theme-toggle{padding:0 8px;font-size:.86rem}.header-phone{min-height:40px;display:inline-flex;align-items:center;justify-content:center;margin-left:0;border-radius:var(--radius);background:var(--surface-muted)}.theme-toggle,.cart-nav-button{width:100%}.hero-inner{min-height:460px;padding:54px 0 72px}.features-grid,.about-grid,.contact-inner,.map-grid{grid-template-columns:1fr}.map-frame{min-height:320px}.contact-inner{align-items:stretch}.shop-header{align-items:stretch;flex-direction:column}.catalog-toolbar{grid-template-columns:1fr}.cart-open-button{width:100%}.cart-drawer{padding:20px 14px}.cart-item{grid-template-columns:68px 1fr}.cart-item-subtotal{grid-column:2;justify-self:start}.footer-inner{min-height:88px;flex-direction:column;justify-content:center;text-align:center}}@media(max-width:480px){.products-grid{grid-template-columns:1fr}.product-controls{flex-wrap:wrap}.btn-add-cart{flex-basis:100%}}
