*,*:before,*:after{box-sizing:border-box}*{margin:0}html{-moz-text-size-adjust:none;-webkit-text-size-adjust:none;text-size-adjust:none;scroll-behavior:smooth}body{line-height:1.5;-webkit-font-smoothing:antialiased}img,picture,video,canvas,svg{display:block;max-width:100%}input,button,textarea,select{font:inherit}p,h1,h2,h3,h4,h5,h6{overflow-wrap:break-word}ul[role=list],ol[role=list]{list-style:none;padding:0}:focus-visible{outline:2px solid var(--color-focus, #005fcc);outline-offset:3px}#root{isolation:isolate}:root{--color-brand-primary: #1a2b3c;--color-brand-secondary: #2d4a6b;--color-brand-accent: #c8702a;--color-brand-accent-hover: #a85c22;--color-neutral-900: #1c1c1c;--color-neutral-700: #3d3d3d;--color-neutral-500: #717171;--color-neutral-300: #c4c4c4;--color-neutral-100: #f5f2ee;--color-neutral-050: #faf8f5;--color-success: #2e7d32;--color-error: #c62828;--color-warning: #f57c00;--color-info: #0277bd;--color-bg-page: var(--color-neutral-050);--color-bg-surface: #ffffff;--color-bg-subtle: var(--color-neutral-100);--color-text-primary: var(--color-neutral-900);--color-text-secondary: var(--color-neutral-700);--color-text-muted: var(--color-neutral-500);--color-text-on-dark: #ffffff;--color-text-on-accent: #ffffff;--color-border: var(--color-neutral-300);--color-focus: #005fcc;--font-display: "Playfair Display", Georgia, "Times New Roman", serif;--font-body: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;--font-mono: "JetBrains Mono", "Courier New", monospace;--text-xs: .64rem;--text-sm: .8rem;--text-base: 1rem;--text-md: 1.25rem;--text-lg: 1.563rem;--text-xl: 1.953rem;--text-2xl: 2.441rem;--text-3xl: 3.052rem;--font-weight-regular: 400;--font-weight-medium: 500;--font-weight-semibold: 600;--font-weight-bold: 700;--leading-tight: 1.2;--leading-snug: 1.375;--leading-normal: 1.5;--leading-relaxed: 1.625;--leading-loose: 2;--tracking-tight: -.02em;--tracking-normal: 0;--tracking-wide: .04em;--tracking-wider: .08em;--tracking-widest: .15em;--space-1: .25rem;--space-2: .5rem;--space-3: .75rem;--space-4: 1rem;--space-5: 1.25rem;--space-6: 1.5rem;--space-8: 2rem;--space-10: 2.5rem;--space-12: 3rem;--space-16: 4rem;--space-20: 5rem;--space-24: 6rem;--space-32: 8rem;--section-padding-y: var(--space-16);--section-padding-x: var(--space-4);--container-max: 1280px;--container-padding: var(--space-4);--radius-sm: .25rem;--radius-md: .5rem;--radius-lg: 1rem;--radius-xl: 1.5rem;--radius-full: 9999px;--border-width: 1px;--border-width-thick: 2px;--shadow-sm: 0 1px 3px 0 rgb(0 0 0 / .1), 0 1px 2px -1px rgb(0 0 0 / .1);--shadow-md: 0 4px 6px -1px rgb(0 0 0 / .1), 0 2px 4px -2px rgb(0 0 0 / .1);--shadow-lg: 0 10px 15px -3px rgb(0 0 0 / .1), 0 4px 6px -4px rgb(0 0 0 / .1);--shadow-xl: 0 20px 25px -5px rgb(0 0 0 / .1), 0 8px 10px -6px rgb(0 0 0 / .1);--transition-fast: .15s ease;--transition-base: .25s ease;--transition-slow: .4s ease;--transition-bounce: .4s cubic-bezier(.34, 1.56, .64, 1);--z-below: -1;--z-base: 0;--z-raised: 10;--z-dropdown: 100;--z-sticky: 200;--z-overlay: 300;--z-modal: 400;--z-toast: 500}html{font-size:16px}body{font-family:var(--font-body);font-size:var(--text-base);font-weight:var(--font-weight-regular);line-height:var(--leading-normal);color:var(--color-text-primary);background-color:var(--color-bg-page);display:flex;flex-direction:column;min-height:100dvh}h1,h2,h3,h4,h5,h6{font-family:var(--font-display);font-weight:var(--font-weight-bold);line-height:var(--leading-tight);color:var(--color-text-primary)}a{color:var(--color-brand-accent);text-decoration:underline;text-underline-offset:3px;transition:color var(--transition-fast)}a:hover{color:var(--color-brand-accent-hover)}main{flex:1}.container{width:100%;max-width:var(--container-max);margin-inline:auto;padding-inline:var(--space-4)}@media(min-width:768px){.container{padding-inline:var(--space-8)}}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border-width:0}.site-header{background-color:var(--color-brand-primary);position:sticky;top:0;z-index:var(--z-sticky);box-shadow:var(--shadow-md)}.nav{display:flex;align-items:center;justify-content:space-between;gap:var(--space-8);padding-block:var(--space-4)}.nav__logo{font-family:var(--font-display);font-size:var(--text-md);font-weight:var(--font-weight-bold);color:var(--color-text-on-dark);text-decoration:none;letter-spacing:var(--tracking-tight);white-space:nowrap}.nav__logo:hover{color:var(--color-brand-accent)}.nav__links{display:flex;align-items:center;gap:var(--space-6)}.nav__links a{font-size:var(--text-sm);font-weight:var(--font-weight-medium);color:var(--color-neutral-300);text-decoration:none;letter-spacing:var(--tracking-wide);text-transform:uppercase;transition:color var(--transition-fast)}.nav__links a:hover,.nav__links a[aria-current=page]{color:var(--color-brand-accent)}.nav__hamburger{display:none;background:none;border:none;cursor:pointer;color:var(--color-text-on-dark);padding:var(--space-2);line-height:0}@media(max-width:767px){.nav__links{display:none;position:fixed;right:0;bottom:0;left:0;top:57px;background-color:var(--color-brand-primary);flex-direction:column;align-items:center;justify-content:center;gap:var(--space-8);z-index:var(--z-overlay)}.nav__links--open{display:flex}.nav__links a{font-size:var(--text-lg)}.nav__hamburger{display:block}}.site-footer{background-color:var(--color-brand-primary);color:var(--color-neutral-300);padding-block:var(--space-10);margin-top:auto}.site-footer .container{display:flex;flex-direction:column;gap:var(--space-3)}@media(min-width:768px){.site-footer .container{flex-direction:row;align-items:center;justify-content:space-between}}.site-footer address{font-style:normal;display:flex;flex-direction:column;gap:var(--space-1);font-size:var(--text-sm)}.site-footer a{color:var(--color-neutral-300);text-decoration:none;transition:color var(--transition-fast)}.site-footer a:hover{color:var(--color-brand-accent)}.site-footer small{font-size:var(--text-xs);color:var(--color-neutral-500)}.hero{background-color:var(--color-brand-primary);color:var(--color-text-on-dark);padding-block:var(--space-24) var(--space-20);text-align:center}.hero h1{font-size:var(--text-2xl);color:var(--color-text-on-dark);margin-bottom:var(--space-6);max-width:14ch;margin-inline:auto}@media(min-width:768px){.hero h1{font-size:var(--text-3xl)}}.hero__tagline{font-size:var(--text-md);color:var(--color-neutral-300);max-width:60ch;margin-inline:auto;line-height:var(--leading-relaxed)}.services{padding-block:var(--section-padding-y);background-color:var(--color-bg-surface)}.services h2{font-size:var(--text-xl);margin-bottom:var(--space-10);text-align:center}.services__list{display:grid;gap:var(--space-6);list-style:none;padding:0}@media(min-width:768px){.services__list{grid-template-columns:repeat(3,1fr)}}.services__item{background-color:var(--color-bg-subtle);border-left:3px solid var(--color-brand-accent);padding:var(--space-6);border-radius:var(--radius-md);font-size:var(--text-base);line-height:var(--leading-relaxed);color:var(--color-text-secondary)}.about{padding-block:var(--section-padding-y)}.about h1{font-size:var(--text-2xl);margin-bottom:var(--space-8)}.about p{font-size:var(--text-md);line-height:var(--leading-relaxed);color:var(--color-text-secondary);max-width:70ch;margin-bottom:var(--space-5)}.products{padding-block:var(--section-padding-y)}.products h1{font-size:var(--text-2xl);margin-bottom:var(--space-4)}.products__intro{color:var(--color-text-secondary);font-size:var(--text-md);margin-bottom:var(--space-12);max-width:60ch}.products__grid{display:grid;gap:var(--space-6);list-style:none;padding:0}@media(min-width:640px){.products__grid{grid-template-columns:repeat(2,1fr)}}@media(min-width:1024px){.products__grid{grid-template-columns:repeat(3,1fr)}}.product-card{background-color:var(--color-bg-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-sm);transition:box-shadow var(--transition-base),transform var(--transition-base)}.product-card:hover{box-shadow:var(--shadow-lg);transform:translateY(-2px)}.product-card__link{display:flex;flex-direction:column;height:100%;text-decoration:none;color:inherit;padding:var(--space-6);gap:var(--space-3)}.product-card__image{background-color:var(--color-bg-subtle);border-radius:var(--radius-md);height:220px;overflow:hidden;margin-bottom:var(--space-2)}.product-card__image img{width:100%;height:100%;object-fit:cover;transition:transform var(--transition-slow)}.product-card:hover .product-card__image img{transform:scale(1.04)}.product-card__name{font-family:var(--font-display);font-size:var(--text-md);font-weight:var(--font-weight-bold);color:var(--color-brand-primary)}.product-card__desc{font-size:var(--text-sm);color:var(--color-text-secondary);line-height:var(--leading-relaxed);flex:1}.product-card__cta{font-size:var(--text-sm);font-weight:var(--font-weight-semibold);color:var(--color-brand-accent);margin-top:var(--space-2)}.contact{padding-block:var(--section-padding-y)}.contact h1{font-size:var(--text-2xl);margin-bottom:var(--space-8)}.contact__info{font-style:normal;display:flex;flex-direction:column;gap:var(--space-2);margin-bottom:var(--space-10);padding:var(--space-6);background-color:var(--color-bg-subtle);border-radius:var(--radius-md);border-left:3px solid var(--color-brand-accent);font-size:var(--text-base);color:var(--color-text-secondary);max-width:400px}.contact-form{display:flex;flex-direction:column;gap:var(--space-5);max-width:560px}.form-group{display:flex;flex-direction:column;gap:var(--space-2)}.form-group label{font-size:var(--text-sm);font-weight:var(--font-weight-medium);color:var(--color-text-primary)}.form-group input,.form-group textarea{padding:var(--space-3) var(--space-4);border:var(--border-width) solid var(--color-border);border-radius:var(--radius-md);background-color:var(--color-bg-surface);color:var(--color-text-primary);font-size:var(--text-base);transition:border-color var(--transition-fast),box-shadow var(--transition-fast)}.form-group input:focus,.form-group textarea:focus{outline:none;border-color:var(--color-brand-accent);box-shadow:0 0 0 3px #c8702a26}.form-group textarea{resize:vertical;min-height:140px}.contact__map{margin-top:var(--space-12);border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-md)}.product-detail{padding-block:var(--section-padding-y)}.product-detail__back{display:inline-flex;align-items:center;gap:var(--space-2);font-size:var(--text-sm);font-weight:var(--font-weight-medium);color:var(--color-text-muted);text-decoration:none;margin-bottom:var(--space-6);transition:color var(--transition-fast)}.product-detail__back:hover{color:var(--color-brand-accent)}.product-detail h1{font-size:var(--text-2xl);margin-bottom:var(--space-4)}.product-detail__desc{font-size:var(--text-md);color:var(--color-text-secondary);line-height:var(--leading-relaxed);max-width:65ch;margin-bottom:var(--space-10)}.product-detail__gallery{display:grid;gap:var(--space-4);margin-bottom:var(--space-10)}@media(min-width:640px){.product-detail__gallery{grid-template-columns:repeat(2,1fr)}}@media(min-width:1024px){.product-detail__gallery{grid-template-columns:repeat(3,1fr)}}.product-detail__gallery img{width:100%;height:auto;border-radius:var(--radius-md);box-shadow:var(--shadow-sm)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-2);padding:var(--space-3) var(--space-8);border-radius:var(--radius-md);font-size:var(--text-base);font-weight:var(--font-weight-semibold);cursor:pointer;border:none;transition:background-color var(--transition-fast),box-shadow var(--transition-fast),transform var(--transition-fast)}.btn--primary{background-color:var(--color-brand-accent);color:var(--color-text-on-accent)}.btn--primary:hover{background-color:var(--color-brand-accent-hover);box-shadow:var(--shadow-md);transform:translateY(-1px)}.btn--primary:active{transform:translateY(0)}
