:root{
	/* Brand Greens */
	--green-700: #204051; /* Use for headings, strong text on light bg, button hover */
	--green-500: #3b6978; /* Primary brand color: links, primary buttons, active controls */
	--green-100: #d8f3dc; /* Subtle brand tint: section backgrounds, info panels */

	/* Brand Yellows (accent) */
	--yellow-400: #f6bf4f; /* Accent highlight: badges, chips, callouts, inline highlights */
	--yellow-100: #f1efea; /* Soft accent background: warnings, promo bands */

	/* Optional Info Blues (nice to have) */
	--blue-500: #3a7ca5;  /* Info links, neutral “info” state */
	--blue-100: #d9ecf5;  /* Info background */

	/* Feedback Reds */
	--red-500: #c45c54;   /* Errors/destructive actions */
	--red-100: #f8d4d2;   /* Error background */

	/* Neutrals */
	--gray-900: #333333;  /* Primary text */
	--gray-700: #393939;  /* Strong UI text (labels), muted headings on white */
	--gray-600: #aaaaaa;  /* Secondary text, placeholders */
	--gray-300: #e3e3e3;  /* Dividers, borders */
	--gray-100: #f8f8f8;  /* App background */

	/* Base */
	--white: #ffffff;
	--black: #000000;

	/* Shadows & radii */
	--radius-sm: 6px;
	--radius-md: 10px;
	--radius-lg: 16px;

	/* Spacing scale (use utilities below) */
	--space-1: 4px;
	--space-2: 8px;
	--space-3: 12px;
	--space-4: 16px;
	--space-5: 24px;
	--space-6: 32px;

	--header-height: 64px;
	--aside-height: 78px;

	/* Typography scale */
	--font-sans: 
    ui-sans-serif, system-ui, -apple-system, 
    Segoe UI, Roboto, Helvetica, Arial, 
    "Apple Color Emoji", "Segoe UI Emoji";
	--fs-xs: 12px;
	--fs-sm: 14px;
	--fs-md: 16px; /* default body */
	--fs-lg: 18px;
	--fs-xl: 22px;
	--fs-2xl: 28px;
	--fs-3xl: 36px;
	--lh-tight: 1.2;
	--lh-normal: 1.5;

	/* Focus ring (accessible) */
	--focus-ring: 0 0 0 3px rgba(58, 124, 165, 0.35); /* blue-500 at ~35% */

	/* Elevation */
	--shadow-sm: 0 1px 2px rgba(0,0,0,0.06);
	--shadow-md: 0 4px 12px rgba(0,0,0,0.1);
	--shadow-lg: 0 10px 24px rgba(0,0,0,0.14);

	/*icons*/
	--z-icon: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'><path d='M0 0 L12 0 C5.4 0 0 5.4 0 12 L0 0 Z'/><path d='M24 24 L12 24 C18.6 24 24 18.6 24 12 L24 24 Z'/><path d='M20.4 0 L24 0 L3.6465 24 L0.0465 24 Z'/></svg>");
  --logout-icon: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'><g transform='scale(0.051136)'><path d='m234.832031 0c122.410157 0 222.804688 93.738281 233.601563 213.332031h-190.933594v-64c0-8.617187-5.207031-16.402343-13.164062-19.710937-7.976563-3.304688-17.152344-1.472656-23.25 4.628906l-85.335938 85.335938c-8.339844 8.339843-8.339844 21.820312 0 30.164062l85.335938 85.332031c6.097656 6.101563 15.273437 7.9375 23.25 4.628907 7.957031-3.304688 13.164062-11.09375 13.164062-19.710938v-64h190.933594c-10.796875 119.59375-111.191406 213.332031-233.601563 213.332031-129.597656 0-234.664062-105.066406-234.664062-234.664062 0-129.601563 105.066406-234.667969 234.664062-234.667969zm0 0'/></g></svg>");
  --user-icon: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'><g transform='scale(0.068571)'><path d='M175,171.173c38.914,0,70.463-38.318,70.463-85.586C245.463,38.318,235.105,0,175,0s-70.465,38.318-70.465,85.587 C104.535,132.855,136.084,171.173,175,171.173z'/><path d='M307.935,298.397c-1.305-82.342-12.059-105.805-94.352-120.657c0,0-11.584,14.761-38.584,14.761 s-38.586-14.761-38.586-14.761c-81.395,14.69-92.803,37.805-94.303,117.982c-0.123,6.547-0.18,6.891-0.202,6.131 c0.005,1.424,0.011,4.058,0.011,8.651c0,0,19.592,39.496,133.08,39.496c113.486,0,133.08-39.496,133.08-39.496 c0-2.951,0.002-5.003,0.005-6.399C308.062,304.575,308.018,303.664,307.935,298.397z'/></g></svg>");
  --delete-icon: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'><g transform='scale(0.0625)'><path d='M64,341.333C64,364.907,83.093,384,106.667,384h170.667C300.907,384,320,364.907,320,341.333v-256H64V341.333z'/><polygon points='266.667,21.333 245.333,0 138.667,0 117.333,21.333 42.667,21.333 42.667,64 341.333,64 341.333,21.333'/></g></svg>");
  --password-icon: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'><path clip-rule='evenodd' fill-rule='evenodd' d='M20.002,24.001H4.014c-1.104,0-1.998-0.896-1.998-2.001V11.994c0-1.105,0.895-2.002,1.998-2.002h0.999V6.991 c0-3.868,3.132-7.004,6.995-7.004s6.995,3.136,6.995,7.004v3.001h0.999c1.104,0,1.998,0.896,1.998,2.002V22 C22,23.104,21.105,24.001,20.002,24.001z M16.005,6.991c0-2.21-1.79-4.002-3.997-4.002S8.011,4.781,8.011,6.991v3.001h7.994V6.991z'/></svg>");
  --edit-icon: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'><g transform='scale(0.129032)'><path d='M186,24.333C186,10.894,175.106,0,161.667,0H24.333C10.894,0,0,10.894,0,24.333v137.333C0,175.106,10.894,186,24.333,186 h137.333C175.106,186,186,175.106,186,161.667V24.333z M41.751,151.882c-4.03,1.081-7.718-2.607-6.637-6.637l6.683-24.91 l24.863,24.863L41.751,151.882z M149.126,61.293l-73.584,73.585l-24.749-24.749l73.584-73.584c3.49-3.49,9.147-3.49,12.637,0 l12.112,12.112C152.615,52.146,152.615,57.803,149.126,61.293z'/></g></svg>");
  --x-icon: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'><path d='M18.3 5.7 12 12l6.3 6.3-1.4 1.4L10.6 13.4 4.3 19.7 2.9 18.3 9.2 12 2.9 5.7 4.3 4.3 10.6 10.6 16.9 4.3z'/></svg>");
  --search-icon: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'><path d='M21 20l-4.6-4.6m1.1-4.5a6.5 6.5 0 11-13 0 6.5 6.5 0 0113 0z' fill='none' stroke='currentColor' stroke-width='2'/></svg>");
  --camera-icon: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'><path d='M9 4l1.5-2h3L15 4h3a2 2 0 012 2v12a2 2 0 01-2 2H6a2 2 0 01-2-2V6a2 2 0 012-2h3zm3 4a5 5 0 100 10 5 5 0 000-10z'/></svg>");
  --star-icon: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'><path transform='translate(0,0.5714286) scale(1.1428571) translate(-43,-160)' d='M60.556381,172.206 C60.1080307,172.639 59.9043306,173.263 60.0093306,173.875 L60.6865811,177.791 C60.8976313,179.01 59.9211306,180 58.8133798,180 C58.5214796,180 58.2201294,179.931 57.9282291,179.779 L54.3844766,177.93 C54.1072764,177.786 53.8038262,177.714 53.499326,177.714 C53.1958758,177.714 52.8924256,177.786 52.6152254,177.93 L49.0714729,179.779 C48.7795727,179.931 48.4782224,180 48.1863222,180 C47.0785715,180 46.1020708,179.01 46.3131209,177.791 L46.9903714,173.875 C47.0953715,173.263 46.8916713,172.639 46.443321,172.206 L43.575769,169.433 C42.4480682,168.342 43.0707186,166.441 44.6289197,166.216 L48.5916225,165.645 C49.211123,165.556 49.7466233,165.17 50.0227735,164.613 L51.7951748,161.051 C52.143775,160.35 52.8220755,160 53.499326,160 C54.1776265,160 54.855927,160.35 55.2045272,161.051 L56.9769285,164.613 C57.2530787,165.17 57.7885791,165.556 58.4080795,165.645 L62.3707823,166.216 C63.9289834,166.441 64.5516338,168.342 63.423933,169.433 L60.556381,172.206 Z'/></svg>");
  --dots-icon: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'><circle cx='12' cy='5' r='2'/><circle cx='12' cy='12' r='2'/><circle cx='12' cy='19' r='2'/></svg>");
  --add-icon: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'><path d='M12 5v14M5 12h14' stroke-width='2' fill='none' stroke='currentColor' stroke-linecap='round'/></svg>");
  --cart-icon: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'><g transform='translate(2,2) translate(-164,-2959)'><path d='M180.846448,2977 L167.153448,2977 C166.544448,2977 166.077448,2976.461 166.163448,2975.859 L167.306448,2967.859 C167.376448,2967.366 167.798448,2967 168.296448,2967 L168.999448,2967 L168.999448,2969 C168.999448,2969.552 169.447448,2970 169.999448,2970 C170.552448,2970 170.999448,2969.552 170.999448,2969 L170.999448,2967 L176.999448,2967 L176.999448,2969 C176.999448,2969.552 177.447448,2970 177.999448,2970 C178.552448,2970 178.999448,2969.552 178.999448,2969 L178.999448,2967 L179.703448,2967 C180.201448,2967 180.623448,2967.366 180.693448,2967.859 L181.836448,2975.859 C181.922448,2976.461 181.455448,2977 180.846448,2977 Z M170.999448,2964 C170.999448,2962.346 172.345448,2961 173.999448,2961 C175.654448,2961 176.999448,2962 176.999448,2964 L176.999448,2965 L170.999448,2965 Z M183.979448,2976.717 L182.550448,2966.717 C182.410448,2965.732 181.566448,2965 180.570448,2965 L178.999448,2965 L178.999448,2964 C178.999448,2961 176.756448,2959 173.999448,2959 C171.243448,2959 168.999448,2961.243 168.999448,2964 L168.999448,2965 L167.734448,2965 C166.739448,2965 165.589448,2965.732 165.448448,2966.717 L164.020448,2976.717 C163.848448,2977.922 164.783448,2979 166.000448,2979 L181.999448,2979 C183.216448,2979 184.151448,2977.922 183.979448,2976.717 Z'/></g></svg>");
  --filter-icon: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'><path d='M11 18h2c.55 0 1-.45 1-1s-.45-1-1-1h-2c-.55 0-1 .45-1 1s.45 1 1 1zm-8-11c0 .55.45 1 1 1h16c.55 0 1-.45 1-1s-.45-1-1-1H4c-.55 0-1 .45-1 1zm4 6h10c.55 0 1-.45 1-1s-.45-1-1-1H7c-.55 0-1 .45-1 1s.45 1 1 1z'/></svg>");
  --pin-icon: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'><path d='M12 2C8.13 2 5 5.13 5 9c0 4.17 4.42 9.92 6.24 12.11.4.48 1.13.48 1.53 0C14.58 18.92 19 13.17 19 9c0-3.87-3.13-7-7-7zm0 9.5c-1.38 0-2.5-1.12-2.5-2.5S10.62 6.5 12 6.5s2.5 1.12 2.5 2.5S13.38 11.5 12 11.5z'/></svg>");
  --email-icon: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 32 32'><path d='M16,16.8l13.8-9.2C29.2,5.5,27.3,4,25,4H7C4.7,4,2.8,5.5,2.2,7.6L16,16.8z'/><path d='M16.6,18.8C16.4,18.9,16.2,19,16,19s-0.4-0.1-0.6-0.2L2,9.9V23c0,2.8,2.2,5,5,5h18c2.8,0,5-2.2,5-5V9.9L16.6,18.8z'/></svg>");
  --phone-icon: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'><path d='M19.23 15.26L16.69 14.97c-.61-.07-1.21.14-1.64.57l-1.84 1.84c-2.83-1.44-5.15-3.75-6.59-6.59l1.85-1.85c.43-.43.64-1.03.57-1.64l-.29-2.52c-.12-1.01-.97-1.77-1.99-1.77H5.03C3.9 3.01 2.96 3.95 3.03 5.08c.53 8.54 7.36 15.36 15.89 15.89 1.13.07 2.07-.87 2.07-2v-1.73c0-1.01-.76-1.87-1.76-1.98z'/></svg>");
  --success-icon: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'><g transform='scale(0.375)'><path d='M32 5.5C24.9742 5.50794 18.2384 8.30245 13.2704 13.2704C8.30245 18.2384 5.50794 24.9742 5.5 32C7 67.16 57.05 67.15 58.5 32C58.4921 24.9742 55.6976 18.2384 50.7296 13.2704C45.7616 8.30245 39.0258 5.50794 32 5.5ZM46.13 22.66L30.06 43.19C29.9208 43.3705 29.742 43.5167 29.5375 43.6173C29.3329 43.7179 29.108 43.7702 28.88 43.7702C28.652 43.7702 28.4271 43.7179 28.2225 43.6173C28.018 43.5167 27.8392 43.3705 27.7 43.19L17.87 30.69C17.6385 30.376 17.5385 29.9841 17.5911 29.5975C17.6438 29.211 17.845 28.8601 18.152 28.6195C18.459 28.3788 18.8478 28.2672 19.2357 28.3084C19.6237 28.3495 19.9803 28.5402 20.23 28.84L28.87 39.84L43.76 20.84C44.0137 20.5641 44.3616 20.3933 44.735 20.361C45.1084 20.3288 45.4804 20.4375 45.7776 20.6658C46.0749 20.894 46.2759 21.2253 46.3411 21.5944C46.4064 21.9635 46.331 22.3437 46.13 22.66Z' fill='currentColor'/></g></svg>");
 	--error-icon: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'><path fill='%23000' d='M12,2 C6.48,2 2,6.48 2,12 C2,17.52 6.48,22 12,22 C17.52,22 22,17.52 22,12 C22,6.48 17.52,2 12,2 Z M12,13 C11.45,13 11,12.55 11,12 L11,8 C11,7.45 11.45,7 12,7 C12.55,7 13,7.45 13,8 L13,12 C13,12.55 12.55,13 12,13 Z M13,17 L11,17 L11,15 L13,15 L13,17 Z'/></svg>");
	--info-icon: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'><path fill='%23000' fill-rule='evenodd' clip-rule='evenodd' d='M12,1.25c-5.933,0 -10.75,4.817 -10.75,10.75c0,5.933 4.817,10.75 10.75,10.75c5.933,0 10.75,-4.817 10.75,-10.75c0,-5.933 -4.817,-10.75 -10.75,-10.75Zm-0,8.75c-0.398,0 -0.779,0.158 -1.061,0.439c-0.281,0.282 -0.439,0.663 -0.439,1.061c0,1.888 0,4.612 0,6.5c-0,0.398 0.158,0.779 0.439,1.061c0.282,0.281 0.663,0.439 1.061,0.439c0.398,-0 0.779,-0.158 1.061,-0.439c0.281,-0.282 0.439,-0.663 0.439,-1.061c0,-1.888 0,-4.612 0,-6.5c0,-0.398 -0.158,-0.779 -0.439,-1.061c-0.282,-0.281 -0.663,-0.439 -1.061,-0.439Zm0,-5.75c0.966,0 1.75,0.784 1.75,1.75c0,0.966 -0.784,1.75 -1.75,1.75c-0.966,0 -1.75,-0.784 -1.75,-1.75c0,-0.966 0.784,-1.75 1.75,-1.75Z'/></svg>");
	--warning-icon: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'><path fill='%23000' d='M19.6719 21.0001H4.3279C3.73536 21.0071 3.15157 20.8568 2.63612 20.5645C2.12066 20.2721 1.69201 19.8483 1.3939 19.3361C1.1282 18.8726 0.992165 18.3461 1.00008 17.8119C1.008 17.2778 1.15958 16.7555 1.4389 16.3001L9.1109 3.58412C9.42063 3.0987 9.84768 2.69915 10.3526 2.42236C10.8575 2.14558 11.4241 2.00049 11.9999 2.00049C12.5757 2.00049 13.1423 2.14558 13.6472 2.42236C14.1521 2.69915 14.5792 3.0987 14.8889 3.58412L22.5609 16.3001C22.8397 16.7552 22.9909 17.2769 22.9988 17.8105C23.0067 18.3441 22.871 18.87 22.6059 19.3331C22.3082 19.8458 21.8797 20.2703 21.3642 20.5632C20.8487 20.856 20.2647 21.0068 19.6719 21.0001V21.0001ZM12.0009 15.0001C11.8031 15.0001 11.6098 15.0588 11.4453 15.1686C11.2809 15.2785 11.1527 15.4347 11.077 15.6174C11.0013 15.8002 10.9815 16.0012 11.0201 16.1952C11.0587 16.3892 11.1539 16.5674 11.2938 16.7072C11.4336 16.8471 11.6118 16.9423 11.8058 16.9809C11.9998 17.0195 12.2009 16.9997 12.3836 16.924C12.5663 16.8483 12.7225 16.7201 12.8324 16.5557C12.9423 16.3912 13.0009 16.1979 13.0009 16.0001C13.0009 15.7349 12.8955 15.4805 12.708 15.293C12.5205 15.1055 12.2661 15.0001 12.0009 15.0001ZM12.0009 8.00012C11.7357 8.00012 11.4813 8.10548 11.2938 8.29301C11.1063 8.48055 11.0009 8.7349 11.0009 9.00012V13.0001C11.0009 13.2653 11.1063 13.5197 11.2938 13.7072C11.4813 13.8948 11.7357 14.0001 12.0009 14.0001C12.2661 14.0001 12.5205 13.8948 12.708 13.7072C12.8955 13.5197 13.0009 13.2653 13.0009 13.0001V9.00012C13.0009 8.7349 12.8955 8.48055 12.708 8.29301C12.5205 8.10548 12.2661 8.00012 12.0009 8.00012Z'/></svg>");
}

@media (prefers-color-scheme: dark) {
  :root {
    --gray-900: #f1f1f1; /* primary text becomes light */
    --gray-700: #e0e0e0;
    --gray-600: #bdbdbd;
    --gray-300: #2a2a2a;
    --gray-100: #161616; /* app background */
    --white: #111315;    /* “card” background in dark */
    --focus-ring: 0 0 0 3px rgba(58, 124, 165, 0.55);
    --shadow-sm: 0 1px 2px rgba(0,0,0,0.5);
    --shadow-md: 0 4px 12px rgba(0,0,0,0.55);
    --shadow-lg: 0 10px 24px rgba(0,0,0,0.6);
  }
}